postgres (latest)
Published 2024-12-16 00:49:23 +01:00 by getty
Installation
docker pull src.ci/srv/postgres:latest
sha256:8792fd5b9c4286972b8f703543eec32dc04f77c3c7f97cd54013527d01d96d6b
Image layers
# debian.sh --arch 'amd64' out/ 'bullseye' '@1733097600' |
RUN /bin/sh -c set -eux; apt-get update; apt-get install -y --no-install-recommends ca-certificates curl gnupg netbase wget ; rm -rf /var/lib/apt/lists/* # buildkit |
RUN /bin/sh -c set -eux; apt-get update; apt-get install -y --no-install-recommends git mercurial openssh-client subversion procps ; rm -rf /var/lib/apt/lists/* # buildkit |
RUN /bin/sh -c set -ex; apt-get update; apt-get install -y --no-install-recommends autoconf automake bzip2 default-libmysqlclient-dev dpkg-dev file g++ gcc imagemagick libbz2-dev libc6-dev libcurl4-openssl-dev libdb-dev libevent-dev libffi-dev libgdbm-dev libglib2.0-dev libgmp-dev libjpeg-dev libkrb5-dev liblzma-dev libmagickcore-dev libmagickwand-dev libmaxminddb-dev libncurses5-dev libncursesw5-dev libpng-dev libpq-dev libreadline-dev libsqlite3-dev libssl-dev libtool libwebp-dev libxml2-dev libxslt-dev libyaml-dev make patch unzip xz-utils zlib1g-dev ; rm -rf /var/lib/apt/lists/* # buildkit |
ARG SRV_UID=1000 |
ARG SRV_GID=100 |
ARG SRV_LOCALE=en_US |
ARG SRV_VERSION=0 |
ENV SRV_UID=1000 |
ENV SRV_GID=100 |
ENV SRV_LOCALE=en_US |
ENV SRV_VERSION=0 |
ENV SRV_APT_GET_INSTALL= |
ENV DEBIAN_FRONTEND=noninteractive |
ENV PGDATA=/data |
ENV POSTGRES_INITDB_ARGS=--locale=en_US.UTF-8 --lc-ctype=en_US.UTF-8 --lc-monetary=en_US.UTF-8 --lc-numeric=en_US.UTF-8 --lc-time=en_US.UTF-8 --lc-collate=en_US.UTF-8 --encoding=UTF8 |
RUN |4 SRV_UID=1000 SRV_GID=100 SRV_LOCALE=en_US SRV_VERSION=0 /bin/sh -c if [ -z "$( getent group $SRV_GID )" ] ; then groupadd -r postgres --gid=$SRV_GID ; fi && useradd -r -g $SRV_GID --uid=$SRV_UID --home-dir=/var/lib/postgresql --shell=/bin/bash postgres && mkdir -p $PGDATA && chown -R $SRV_UID:$SRV_GID $PGDATA && apt-get update -y && apt-get install -y apt-utils lsb-release && ( curl https://www.postgresql.org/media/keys/ACCC4CF8.asc | gpg --dearmor > /etc/apt/trusted.gpg.d/apt.postgresql.org.gpg ) && ( echo "deb http://apt.postgresql.org/pub/repos/apt $(lsb_release -cs)-pgdg main" > /etc/apt/sources.list.d/pgdg.list ) && apt-get update -y && mkdir -p /docker-entrypoint-initdb.d && apt-get install -y postgresql-16 postgresql-common postgresql-16-pglogical postgresql-16-cron postgresql-16-extra-window-functions postgresql-16-first-last-agg postgresql-16-jsquery postgresql-16-numeral postgresql-16-pglogical-ticker postgresql-16-pgmemcache postgresql-16-pgpcre postgresql-16-pgrouting postgresql-16-repack postgresql-16-pgrouting-scripts postgresql-16-pgsphere postgresql-16-postgis-3 postgresql-16-postgis-3-scripts postgresql-16-repack postgresql-16-set-user postgresql-16-similarity postgresql-16-pgpool2 postgresql-16-semver postgresql-16-repmgr postgresql-plperl-16 postgresql-plpython3-16 postgresql-16-age postgresql-16-pgvector postgresql-16-tablelog postgresql-16-wal2json apgdiff locales-all $SRV_APT_GET_INSTALL && apt-get clean && rm -rf ~/.cache && rm -rf /var/lib/apt/lists/* # buildkit |
ENV PATH=/usr/lib/postgresql/16/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin |
COPY docker-entrypoint.sh / # buildkit |
USER 1000:100 |
RUN |4 SRV_UID=1000 SRV_GID=100 SRV_LOCALE=en_US SRV_VERSION=0 /bin/sh -c ln -s $PGDATA/.bash_history $HOME/.bash_history # buildkit |
VOLUME [/data] |
WORKDIR /data |
ENTRYPOINT ["/docker-entrypoint.sh"] |
STOPSIGNAL SIGINT |
EXPOSE map[5432/tcp:{}] |
CMD ["postgres" "-c" "listen_addresses=*"] |
HEALTHCHECK &{["CMD-SHELL" "pg_isready -U \"${POSTGRES_USER:-postgres}\""] "30s" "3s" "0s" "0s" '\x04'} |