From d0fff5147b1590838c616f81200fa5cbaf6021d6 Mon Sep 17 00:00:00 2001 From: Mathieu Velten Date: Thu, 22 Sep 2022 11:51:20 +0200 Subject: [PATCH 1/4] Dockerfile for tests: align comments with current behavior Signed-off-by: Mathieu Velten --- changelog.d/13867.misc | 1 + docker/complement/Dockerfile | 8 ++++---- 2 files changed, 5 insertions(+), 4 deletions(-) create mode 100644 changelog.d/13867.misc diff --git a/changelog.d/13867.misc b/changelog.d/13867.misc new file mode 100644 index 000000000000..bb48c77dbb5c --- /dev/null +++ b/changelog.d/13867.misc @@ -0,0 +1 @@ +Align comments with current behavior for the Docker build used for testing purpose. diff --git a/docker/complement/Dockerfile b/docker/complement/Dockerfile index 0e13722d1c00..b69abac8b5f4 100644 --- a/docker/complement/Dockerfile +++ b/docker/complement/Dockerfile @@ -8,16 +8,16 @@ ARG SYNAPSE_VERSION=latest -# first of all, we create a base image with a postgres server and database, -# which we can copy into the target image. For repeated rebuilds, this is -# much faster than apt installing postgres each time. +# First of all, we copy postgres server from the official postgres image, +# since for repeated rebuilds, this is much faster than apt installing +# postgres each time. # # This trick only works because (a) the Synapse image happens to have all the # shared libraries that postgres wants, (b) we use a postgres image based on # the same debian version as Synapse's docker image (so the versions of the # shared libraries match). -# now build the final image, based on the Synapse image. +# We also initialize the database itself at build and not runtime for speed reason. FROM matrixdotorg/synapse-workers:$SYNAPSE_VERSION # copy the postgres installation over from the image we built above From c42a2c8cab56f9ab124b21a2b6478a06261e992a Mon Sep 17 00:00:00 2001 From: Mathieu Velten Date: Thu, 22 Sep 2022 16:41:42 +0200 Subject: [PATCH 2/4] Update changelog.d/13867.misc Co-authored-by: Richard van der Hoff <1389908+richvdh@users.noreply.github.com> --- changelog.d/13867.misc | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/changelog.d/13867.misc b/changelog.d/13867.misc index bb48c77dbb5c..1205214598e7 100644 --- a/changelog.d/13867.misc +++ b/changelog.d/13867.misc @@ -1 +1 @@ -Align comments with current behavior for the Docker build used for testing purpose. +Correct the comments in the complement dockerfile. From 7b204b0b5021501f0615fe6a0c32520081f305ea Mon Sep 17 00:00:00 2001 From: Mathieu Velten Date: Thu, 22 Sep 2022 16:46:39 +0200 Subject: [PATCH 3/4] Put comments nearby the code --- docker/complement/Dockerfile | 22 +++++++++------------- 1 file changed, 9 insertions(+), 13 deletions(-) diff --git a/docker/complement/Dockerfile b/docker/complement/Dockerfile index b69abac8b5f4..551229a3a6c0 100644 --- a/docker/complement/Dockerfile +++ b/docker/complement/Dockerfile @@ -8,19 +8,15 @@ ARG SYNAPSE_VERSION=latest -# First of all, we copy postgres server from the official postgres image, -# since for repeated rebuilds, this is much faster than apt installing -# postgres each time. -# -# This trick only works because (a) the Synapse image happens to have all the -# shared libraries that postgres wants, (b) we use a postgres image based on -# the same debian version as Synapse's docker image (so the versions of the -# shared libraries match). - -# We also initialize the database itself at build and not runtime for speed reason. - FROM matrixdotorg/synapse-workers:$SYNAPSE_VERSION - # copy the postgres installation over from the image we built above + # First of all, we copy postgres server from the official postgres image, + # since for repeated rebuilds, this is much faster than apt installing + # postgres each time. + + # This trick only works because (a) the Synapse image happens to have all the + # shared libraries that postgres wants, (b) we use a postgres image based on + # the same debian version as Synapse's docker image (so the versions of the + # shared libraries match). RUN adduser --system --uid 999 postgres --home /var/lib/postgresql COPY --from=postgres:13-bullseye /usr/lib/postgresql /usr/lib/postgresql COPY --from=postgres:13-bullseye /usr/share/postgresql /usr/share/postgresql @@ -28,7 +24,7 @@ FROM matrixdotorg/synapse-workers:$SYNAPSE_VERSION ENV PATH="${PATH}:/usr/lib/postgresql/13/bin" ENV PGDATA=/var/lib/postgresql/data - # initialise the database cluster in /var/lib/postgresql + # We also initialize the database at build and not runtime for speed reason. RUN gosu postgres initdb --locale=C --encoding=UTF-8 --auth-host password # Configure a password and create a database for Synapse From 66f56ae7a4b39d42004ce007ba64855cec78654c Mon Sep 17 00:00:00 2001 From: Mathieu Velten Date: Fri, 23 Sep 2022 19:55:07 +0200 Subject: [PATCH 4/4] Update docker/complement/Dockerfile Co-authored-by: Richard van der Hoff <1389908+richvdh@users.noreply.github.com> --- docker/complement/Dockerfile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docker/complement/Dockerfile b/docker/complement/Dockerfile index 551229a3a6c0..c0935c99a8b7 100644 --- a/docker/complement/Dockerfile +++ b/docker/complement/Dockerfile @@ -24,7 +24,7 @@ FROM matrixdotorg/synapse-workers:$SYNAPSE_VERSION ENV PATH="${PATH}:/usr/lib/postgresql/13/bin" ENV PGDATA=/var/lib/postgresql/data - # We also initialize the database at build and not runtime for speed reason. + # We also initialize the database at build time, rather than runtime, so that it's faster to spin up the image. RUN gosu postgres initdb --locale=C --encoding=UTF-8 --auth-host password # Configure a password and create a database for Synapse