From 61270b8bffa9694c32442f989e14a9f6cf1d1aa3 Mon Sep 17 00:00:00 2001 From: Curtis Yung <6743839+curtis18@users.noreply.github.com> Date: Sun, 19 Mar 2023 04:45:25 +0800 Subject: [PATCH] Add support to PostgreSQL 15 (#356) * Update Dockerfile add support to PostgreSQL 15 and alter encryption method to scram-sha-256 instead of md5 * Update run.sh add support to PostgreSQL 15 --- Dockerfile | 35 +++++++++++++++++++++-------------- run.sh | 8 ++++---- 2 files changed, 25 insertions(+), 18 deletions(-) diff --git a/Dockerfile b/Dockerfile index 2df9201..0c0cd0d 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,11 +1,17 @@ FROM ubuntu:22.04 AS compiler-common ENV DEBIAN_FRONTEND=noninteractive +ENV LANG C.UTF-8 +ENV LC_ALL C.UTF-8 RUN apt-get update \ && apt-get install -y --no-install-recommends \ - git-core \ - ca-certificates \ -&& apt-get update + ca-certificates gnupg lsb-release locales \ + wget curl \ + git-core unzip unrar \ +&& locale-gen $LANG && update-locale LANG=$LANG \ +&& sh -c 'echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list' \ +&& wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc | apt-key add - \ +&& apt-get update && apt-get -y upgrade ########################################################################################################### @@ -31,7 +37,7 @@ RUN mkdir -p /home/renderer/src \ ########################################################################################################### -FROM ubuntu:22.04 AS final +FROM compiler-common AS final # Based on # https://switch2osm.org/serving-tiles/manually-building-a-tile-server-18-04-lts/ @@ -40,6 +46,7 @@ ENV AUTOVACUUM=on ENV UPDATES=disabled ENV REPLICATION_URL=https://planet.openstreetmap.org/replication/hour/ ENV MAX_INTERVAL_SECONDS=3600 +ENV PG_VERSION 15 RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone @@ -63,9 +70,9 @@ RUN apt-get update \ osm2pgsql \ osmium-tool \ osmosis \ - postgresql-14 \ - postgresql-14-postgis-3 \ - postgresql-14-postgis-3-scripts \ + postgresql-$PG_VERSION \ + postgresql-$PG_VERSION-postgis-3 \ + postgresql-$PG_VERSION-postgis-3-scripts \ postgis \ python-is-python3 \ python3-mapnik \ @@ -75,7 +82,7 @@ RUN apt-get update \ python3-pip \ renderd \ sudo \ - wget \ + vim \ && apt-get clean autoclean \ && apt-get autoremove --yes \ && rm -rf /var/lib/{apt,dpkg,cache,log}/ @@ -124,11 +131,11 @@ RUN chmod +x /usr/bin/openstreetmap-tiles-update-expire.sh \ && echo "* * * * * renderer openstreetmap-tiles-update-expire.sh\n" >> /etc/crontab # Configure PosgtreSQL -COPY postgresql.custom.conf.tmpl /etc/postgresql/14/main/ +COPY postgresql.custom.conf.tmpl /etc/postgresql/$PG_VERSION/main/ RUN chown -R postgres:postgres /var/lib/postgresql \ -&& chown postgres:postgres /etc/postgresql/14/main/postgresql.custom.conf.tmpl \ -&& echo "host all all 0.0.0.0/0 md5" >> /etc/postgresql/14/main/pg_hba.conf \ -&& echo "host all all ::/0 md5" >> /etc/postgresql/14/main/pg_hba.conf +&& chown postgres:postgres /etc/postgresql/$PG_VERSION/main/postgresql.custom.conf.tmpl \ +&& echo "host all all 0.0.0.0/0 scram-sha-256" >> /etc/postgresql/$PG_VERSION/main/pg_hba.conf \ +&& echo "host all all ::/0 scram-sha-256" >> /etc/postgresql/$PG_VERSION/main/pg_hba.conf # Create volume directories RUN mkdir -p /run/renderd/ \ @@ -138,10 +145,10 @@ RUN mkdir -p /run/renderd/ \ && chown -R renderer: /data/ \ && chown -R renderer: /home/renderer/src/ \ && chown -R renderer: /run/renderd \ - && mv /var/lib/postgresql/14/main/ /data/database/postgres/ \ + && mv /var/lib/postgresql/$PG_VERSION/main/ /data/database/postgres/ \ && mv /var/cache/renderd/tiles/ /data/tiles/ \ && chown -R renderer: /data/tiles \ - && ln -s /data/database/postgres /var/lib/postgresql/14/main \ + && ln -s /data/database/postgres /var/lib/postgresql/$PG_VERSION/main \ && ln -s /data/style /home/renderer/src/openstreetmap-carto \ && ln -s /data/tiles /var/cache/renderd/tiles \ ; diff --git a/run.sh b/run.sh index 69d54a1..ddd9af9 100755 --- a/run.sh +++ b/run.sh @@ -3,9 +3,9 @@ set -euo pipefail function createPostgresConfig() { - cp /etc/postgresql/14/main/postgresql.custom.conf.tmpl /etc/postgresql/14/main/conf.d/postgresql.custom.conf - sudo -u postgres echo "autovacuum = $AUTOVACUUM" >> /etc/postgresql/14/main/conf.d/postgresql.custom.conf - cat /etc/postgresql/14/main/conf.d/postgresql.custom.conf + cp /etc/postgresql/$PG_VERSION/main/postgresql.custom.conf.tmpl /etc/postgresql/$PG_VERSION/main/conf.d/postgresql.custom.conf + sudo -u postgres echo "autovacuum = $AUTOVACUUM" >> /etc/postgresql/$PG_VERSION/main/conf.d/postgresql.custom.conf + cat /etc/postgresql/$PG_VERSION/main/conf.d/postgresql.custom.conf } function setPostgresPassword() { @@ -46,7 +46,7 @@ if [ "$1" == "import" ]; then chown renderer: /data/database/ chown -R postgres: /var/lib/postgresql /data/database/postgres/ if [ ! -f /data/database/postgres/PG_VERSION ]; then - sudo -u postgres /usr/lib/postgresql/14/bin/pg_ctl -D /data/database/postgres/ initdb -o "--locale C.UTF-8" + sudo -u postgres /usr/lib/postgresql/$PG_VERSION/bin/pg_ctl -D /data/database/postgres/ initdb -o "--locale C.UTF-8" fi # Initialize PostgreSQL