You've already forked postgres
mirror of
https://github.com/docker-library/postgres.git
synced 2025-07-25 12:22:02 +03:00
Sync a bit more with the Debian configure flags (adding comments for where we differ) and add all versions (including "update.sh" and "generate-stackbrew-library.sh" changes, with our new template)
This commit is contained in:
@ -3,11 +3,15 @@ services: docker
|
|||||||
|
|
||||||
env:
|
env:
|
||||||
- VERSION=9.6
|
- VERSION=9.6
|
||||||
|
- VERSION=9.6 VARIANT=alpine
|
||||||
- VERSION=9.5
|
- VERSION=9.5
|
||||||
- VERSION=9.5 VARIANT=alpine
|
- VERSION=9.5 VARIANT=alpine
|
||||||
- VERSION=9.4
|
- VERSION=9.4
|
||||||
|
- VERSION=9.4 VARIANT=alpine
|
||||||
- VERSION=9.3
|
- VERSION=9.3
|
||||||
|
- VERSION=9.3 VARIANT=alpine
|
||||||
- VERSION=9.2
|
- VERSION=9.2
|
||||||
|
- VERSION=9.2 VARIANT=alpine
|
||||||
|
|
||||||
install:
|
install:
|
||||||
- git clone https://github.com/docker-library/official-images.git ~/official-images
|
- git clone https://github.com/docker-library/official-images.git ~/official-images
|
||||||
|
119
9.2/alpine/Dockerfile
Normal file
119
9.2/alpine/Dockerfile
Normal file
@ -0,0 +1,119 @@
|
|||||||
|
# vim:set ft=dockerfile:
|
||||||
|
FROM alpine:3.4
|
||||||
|
|
||||||
|
# alpine includes "postgres" user/group in base install
|
||||||
|
# /etc/passwd:22:postgres:x:70:70::/var/lib/postgresql:/bin/sh
|
||||||
|
# /etc/group:34:postgres:x:70:
|
||||||
|
|
||||||
|
# su-exec (gosu-compatible) is installed further down
|
||||||
|
|
||||||
|
# make the "en_US.UTF-8" locale so postgres will be utf-8 enabled by default
|
||||||
|
# alpine doesn't require explicit locale-file generation
|
||||||
|
ENV LANG en_US.utf8
|
||||||
|
|
||||||
|
RUN mkdir /docker-entrypoint-initdb.d
|
||||||
|
|
||||||
|
ENV PG_MAJOR 9.2
|
||||||
|
ENV PG_VERSION 9.2.19
|
||||||
|
ENV PG_SHA256 1d29d73a4f590fcc348280f13ac2ff6a0f72c94908c54e3c20b7ab1560e8dbad
|
||||||
|
|
||||||
|
RUN set -ex \
|
||||||
|
\
|
||||||
|
&& apk add --no-cache --virtual .fetch-deps \
|
||||||
|
ca-certificates \
|
||||||
|
openssl \
|
||||||
|
tar \
|
||||||
|
\
|
||||||
|
&& wget -O postgresql.tar.bz2 "https://ftp.postgresql.org/pub/source/v$PG_VERSION/postgresql-$PG_VERSION.tar.bz2" \
|
||||||
|
&& echo "$PG_SHA256 *postgresql.tar.bz2" | sha256sum -c - \
|
||||||
|
&& mkdir -p /usr/src/postgresql \
|
||||||
|
&& tar \
|
||||||
|
--extract \
|
||||||
|
--file postgresql.tar.bz2 \
|
||||||
|
--directory /usr/src/postgresql \
|
||||||
|
--strip-components 1 \
|
||||||
|
&& rm postgresql.tar.bz2 \
|
||||||
|
\
|
||||||
|
&& apk add --no-cache --virtual .build-deps \
|
||||||
|
bison \
|
||||||
|
flex \
|
||||||
|
gcc \
|
||||||
|
# krb5-dev \
|
||||||
|
libc-dev \
|
||||||
|
libedit-dev \
|
||||||
|
libxml2-dev \
|
||||||
|
libxslt-dev \
|
||||||
|
make \
|
||||||
|
# openldap-dev \
|
||||||
|
openssl-dev \
|
||||||
|
perl \
|
||||||
|
# perl-dev \
|
||||||
|
# python-dev \
|
||||||
|
# python3-dev \
|
||||||
|
# tcl-dev \
|
||||||
|
util-linux-dev \
|
||||||
|
zlib-dev \
|
||||||
|
\
|
||||||
|
&& cd /usr/src/postgresql \
|
||||||
|
# configure options taken from:
|
||||||
|
# https://anonscm.debian.org/cgit/pkg-postgresql/postgresql.git/tree/debian/rules?h=9.5
|
||||||
|
&& ./configure \
|
||||||
|
# "/usr/src/postgresql/src/backend/access/common/tupconvert.c:105: undefined reference to `libintl_gettext'"
|
||||||
|
# --enable-nls \
|
||||||
|
--enable-integer-datetimes \
|
||||||
|
--enable-thread-safety \
|
||||||
|
--enable-tap-tests \
|
||||||
|
# skip debugging info -- we want tiny size instead
|
||||||
|
# --enable-debug \
|
||||||
|
--disable-rpath \
|
||||||
|
--with-uuid=e2fs \
|
||||||
|
--with-gnu-ld \
|
||||||
|
--with-pgport=5432 \
|
||||||
|
--with-system-tzdata=/usr/share/zoneinfo \
|
||||||
|
--prefix=/usr/local \
|
||||||
|
\
|
||||||
|
# these make our image abnormally large (at least 100MB larger), which seems uncouth for an "Alpine" (ie, "small") variant :)
|
||||||
|
# --with-krb5 \
|
||||||
|
# --with-gssapi \
|
||||||
|
# --with-ldap \
|
||||||
|
# --with-tcl \
|
||||||
|
# --with-perl \
|
||||||
|
# --with-python \
|
||||||
|
# --with-pam \
|
||||||
|
--with-openssl \
|
||||||
|
--with-libxml \
|
||||||
|
--with-libxslt \
|
||||||
|
&& make -j "$(getconf _NPROCESSORS_ONLN)" world \
|
||||||
|
&& make install-world \
|
||||||
|
&& make -C contrib install \
|
||||||
|
\
|
||||||
|
&& runDeps="$( \
|
||||||
|
scanelf --needed --nobanner --recursive /usr/local \
|
||||||
|
| awk '{ gsub(/,/, "\nso:", $2); print "so:" $2 }' \
|
||||||
|
| sort -u \
|
||||||
|
| xargs -r apk info --installed \
|
||||||
|
| sort -u \
|
||||||
|
)" \
|
||||||
|
&& apk add --no-cache --virtual .postgresql-rundeps \
|
||||||
|
$runDeps \
|
||||||
|
bash \
|
||||||
|
su-exec \
|
||||||
|
&& apk del .build-deps \
|
||||||
|
&& cd / \
|
||||||
|
&& rm -rf \
|
||||||
|
/usr/src/postgresql \
|
||||||
|
/usr/local/include/* \
|
||||||
|
&& find /usr/local -name '*.a' -delete
|
||||||
|
|
||||||
|
RUN mkdir -p /var/run/postgresql && chown -R postgres /var/run/postgresql
|
||||||
|
|
||||||
|
ENV PATH /usr/lib/postgresql/$PG_MAJOR/bin:$PATH
|
||||||
|
ENV PGDATA /var/lib/postgresql/data
|
||||||
|
VOLUME /var/lib/postgresql/data
|
||||||
|
|
||||||
|
COPY docker-entrypoint.sh /
|
||||||
|
|
||||||
|
ENTRYPOINT ["/docker-entrypoint.sh"]
|
||||||
|
|
||||||
|
EXPOSE 5432
|
||||||
|
CMD ["postgres"]
|
100
9.2/alpine/docker-entrypoint.sh
Executable file
100
9.2/alpine/docker-entrypoint.sh
Executable file
@ -0,0 +1,100 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if [ "${1:0:1}" = '-' ]; then
|
||||||
|
set -- postgres "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$1" = 'postgres' ]; then
|
||||||
|
mkdir -p "$PGDATA"
|
||||||
|
chmod 700 "$PGDATA"
|
||||||
|
chown -R postgres "$PGDATA"
|
||||||
|
|
||||||
|
mkdir -p /run/postgresql
|
||||||
|
chmod g+s /run/postgresql
|
||||||
|
chown -R postgres /run/postgresql
|
||||||
|
|
||||||
|
# look specifically for PG_VERSION, as it is expected in the DB dir
|
||||||
|
if [ ! -s "$PGDATA/PG_VERSION" ]; then
|
||||||
|
eval "su-exec postgres initdb $POSTGRES_INITDB_ARGS"
|
||||||
|
|
||||||
|
# check password first so we can output the warning before postgres
|
||||||
|
# messes it up
|
||||||
|
if [ "$POSTGRES_PASSWORD" ]; then
|
||||||
|
pass="PASSWORD '$POSTGRES_PASSWORD'"
|
||||||
|
authMethod=md5
|
||||||
|
else
|
||||||
|
# The - option suppresses leading tabs but *not* spaces. :)
|
||||||
|
cat >&2 <<-'EOWARN'
|
||||||
|
****************************************************
|
||||||
|
WARNING: No password has been set for the database.
|
||||||
|
This will allow anyone with access to the
|
||||||
|
Postgres port to access your database. In
|
||||||
|
Docker's default configuration, this is
|
||||||
|
effectively any other container on the same
|
||||||
|
system.
|
||||||
|
|
||||||
|
Use "-e POSTGRES_PASSWORD=password" to set
|
||||||
|
it in "docker run".
|
||||||
|
****************************************************
|
||||||
|
EOWARN
|
||||||
|
|
||||||
|
pass=
|
||||||
|
authMethod=trust
|
||||||
|
fi
|
||||||
|
|
||||||
|
{ echo; echo "host all all 0.0.0.0/0 $authMethod"; } | su-exec postgres tee -a "$PGDATA/pg_hba.conf" > /dev/null
|
||||||
|
|
||||||
|
# internal start of server in order to allow set-up using psql-client
|
||||||
|
# does not listen on external TCP/IP and waits until start finishes
|
||||||
|
su-exec postgres pg_ctl -D "$PGDATA" \
|
||||||
|
-o "-c listen_addresses='localhost'" \
|
||||||
|
-w start
|
||||||
|
|
||||||
|
: ${POSTGRES_USER:=postgres}
|
||||||
|
: ${POSTGRES_DB:=$POSTGRES_USER}
|
||||||
|
export POSTGRES_USER POSTGRES_DB
|
||||||
|
|
||||||
|
psql=( psql -v ON_ERROR_STOP=1 )
|
||||||
|
|
||||||
|
if [ "$POSTGRES_DB" != 'postgres' ]; then
|
||||||
|
"${psql[@]}" --username postgres <<-EOSQL
|
||||||
|
CREATE DATABASE "$POSTGRES_DB" ;
|
||||||
|
EOSQL
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$POSTGRES_USER" = 'postgres' ]; then
|
||||||
|
op='ALTER'
|
||||||
|
else
|
||||||
|
op='CREATE'
|
||||||
|
fi
|
||||||
|
"${psql[@]}" --username postgres <<-EOSQL
|
||||||
|
$op USER "$POSTGRES_USER" WITH SUPERUSER $pass ;
|
||||||
|
EOSQL
|
||||||
|
echo
|
||||||
|
|
||||||
|
psql+=( --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" )
|
||||||
|
|
||||||
|
echo
|
||||||
|
for f in /docker-entrypoint-initdb.d/*; do
|
||||||
|
case "$f" in
|
||||||
|
*.sh) echo "$0: running $f"; . "$f" ;;
|
||||||
|
*.sql) echo "$0: running $f"; "${psql[@]}" < "$f"; echo ;;
|
||||||
|
*.sql.gz) echo "$0: running $f"; gunzip -c "$f" | "${psql[@]}"; echo ;;
|
||||||
|
*) echo "$0: ignoring $f" ;;
|
||||||
|
esac
|
||||||
|
echo
|
||||||
|
done
|
||||||
|
|
||||||
|
su-exec postgres pg_ctl -D "$PGDATA" -m fast -w stop
|
||||||
|
|
||||||
|
echo
|
||||||
|
echo 'PostgreSQL init process complete; ready for start up.'
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec su-exec postgres "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec "$@"
|
119
9.3/alpine/Dockerfile
Normal file
119
9.3/alpine/Dockerfile
Normal file
@ -0,0 +1,119 @@
|
|||||||
|
# vim:set ft=dockerfile:
|
||||||
|
FROM alpine:3.4
|
||||||
|
|
||||||
|
# alpine includes "postgres" user/group in base install
|
||||||
|
# /etc/passwd:22:postgres:x:70:70::/var/lib/postgresql:/bin/sh
|
||||||
|
# /etc/group:34:postgres:x:70:
|
||||||
|
|
||||||
|
# su-exec (gosu-compatible) is installed further down
|
||||||
|
|
||||||
|
# make the "en_US.UTF-8" locale so postgres will be utf-8 enabled by default
|
||||||
|
# alpine doesn't require explicit locale-file generation
|
||||||
|
ENV LANG en_US.utf8
|
||||||
|
|
||||||
|
RUN mkdir /docker-entrypoint-initdb.d
|
||||||
|
|
||||||
|
ENV PG_MAJOR 9.3
|
||||||
|
ENV PG_VERSION 9.3.15
|
||||||
|
ENV PG_SHA256 a9fcba1446a93aa95e3e1b6535756f0472d10b0f267a0845f8b2b29f89de5c4f
|
||||||
|
|
||||||
|
RUN set -ex \
|
||||||
|
\
|
||||||
|
&& apk add --no-cache --virtual .fetch-deps \
|
||||||
|
ca-certificates \
|
||||||
|
openssl \
|
||||||
|
tar \
|
||||||
|
\
|
||||||
|
&& wget -O postgresql.tar.bz2 "https://ftp.postgresql.org/pub/source/v$PG_VERSION/postgresql-$PG_VERSION.tar.bz2" \
|
||||||
|
&& echo "$PG_SHA256 *postgresql.tar.bz2" | sha256sum -c - \
|
||||||
|
&& mkdir -p /usr/src/postgresql \
|
||||||
|
&& tar \
|
||||||
|
--extract \
|
||||||
|
--file postgresql.tar.bz2 \
|
||||||
|
--directory /usr/src/postgresql \
|
||||||
|
--strip-components 1 \
|
||||||
|
&& rm postgresql.tar.bz2 \
|
||||||
|
\
|
||||||
|
&& apk add --no-cache --virtual .build-deps \
|
||||||
|
bison \
|
||||||
|
flex \
|
||||||
|
gcc \
|
||||||
|
# krb5-dev \
|
||||||
|
libc-dev \
|
||||||
|
libedit-dev \
|
||||||
|
libxml2-dev \
|
||||||
|
libxslt-dev \
|
||||||
|
make \
|
||||||
|
# openldap-dev \
|
||||||
|
openssl-dev \
|
||||||
|
perl \
|
||||||
|
# perl-dev \
|
||||||
|
# python-dev \
|
||||||
|
# python3-dev \
|
||||||
|
# tcl-dev \
|
||||||
|
util-linux-dev \
|
||||||
|
zlib-dev \
|
||||||
|
\
|
||||||
|
&& cd /usr/src/postgresql \
|
||||||
|
# configure options taken from:
|
||||||
|
# https://anonscm.debian.org/cgit/pkg-postgresql/postgresql.git/tree/debian/rules?h=9.5
|
||||||
|
&& ./configure \
|
||||||
|
# "/usr/src/postgresql/src/backend/access/common/tupconvert.c:105: undefined reference to `libintl_gettext'"
|
||||||
|
# --enable-nls \
|
||||||
|
--enable-integer-datetimes \
|
||||||
|
--enable-thread-safety \
|
||||||
|
--enable-tap-tests \
|
||||||
|
# skip debugging info -- we want tiny size instead
|
||||||
|
# --enable-debug \
|
||||||
|
--disable-rpath \
|
||||||
|
--with-uuid=e2fs \
|
||||||
|
--with-gnu-ld \
|
||||||
|
--with-pgport=5432 \
|
||||||
|
--with-system-tzdata=/usr/share/zoneinfo \
|
||||||
|
--prefix=/usr/local \
|
||||||
|
\
|
||||||
|
# these make our image abnormally large (at least 100MB larger), which seems uncouth for an "Alpine" (ie, "small") variant :)
|
||||||
|
# --with-krb5 \
|
||||||
|
# --with-gssapi \
|
||||||
|
# --with-ldap \
|
||||||
|
# --with-tcl \
|
||||||
|
# --with-perl \
|
||||||
|
# --with-python \
|
||||||
|
# --with-pam \
|
||||||
|
--with-openssl \
|
||||||
|
--with-libxml \
|
||||||
|
--with-libxslt \
|
||||||
|
&& make -j "$(getconf _NPROCESSORS_ONLN)" world \
|
||||||
|
&& make install-world \
|
||||||
|
&& make -C contrib install \
|
||||||
|
\
|
||||||
|
&& runDeps="$( \
|
||||||
|
scanelf --needed --nobanner --recursive /usr/local \
|
||||||
|
| awk '{ gsub(/,/, "\nso:", $2); print "so:" $2 }' \
|
||||||
|
| sort -u \
|
||||||
|
| xargs -r apk info --installed \
|
||||||
|
| sort -u \
|
||||||
|
)" \
|
||||||
|
&& apk add --no-cache --virtual .postgresql-rundeps \
|
||||||
|
$runDeps \
|
||||||
|
bash \
|
||||||
|
su-exec \
|
||||||
|
&& apk del .build-deps \
|
||||||
|
&& cd / \
|
||||||
|
&& rm -rf \
|
||||||
|
/usr/src/postgresql \
|
||||||
|
/usr/local/include/* \
|
||||||
|
&& find /usr/local -name '*.a' -delete
|
||||||
|
|
||||||
|
RUN mkdir -p /var/run/postgresql && chown -R postgres /var/run/postgresql
|
||||||
|
|
||||||
|
ENV PATH /usr/lib/postgresql/$PG_MAJOR/bin:$PATH
|
||||||
|
ENV PGDATA /var/lib/postgresql/data
|
||||||
|
VOLUME /var/lib/postgresql/data
|
||||||
|
|
||||||
|
COPY docker-entrypoint.sh /
|
||||||
|
|
||||||
|
ENTRYPOINT ["/docker-entrypoint.sh"]
|
||||||
|
|
||||||
|
EXPOSE 5432
|
||||||
|
CMD ["postgres"]
|
100
9.3/alpine/docker-entrypoint.sh
Executable file
100
9.3/alpine/docker-entrypoint.sh
Executable file
@ -0,0 +1,100 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if [ "${1:0:1}" = '-' ]; then
|
||||||
|
set -- postgres "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$1" = 'postgres' ]; then
|
||||||
|
mkdir -p "$PGDATA"
|
||||||
|
chmod 700 "$PGDATA"
|
||||||
|
chown -R postgres "$PGDATA"
|
||||||
|
|
||||||
|
mkdir -p /run/postgresql
|
||||||
|
chmod g+s /run/postgresql
|
||||||
|
chown -R postgres /run/postgresql
|
||||||
|
|
||||||
|
# look specifically for PG_VERSION, as it is expected in the DB dir
|
||||||
|
if [ ! -s "$PGDATA/PG_VERSION" ]; then
|
||||||
|
eval "su-exec postgres initdb $POSTGRES_INITDB_ARGS"
|
||||||
|
|
||||||
|
# check password first so we can output the warning before postgres
|
||||||
|
# messes it up
|
||||||
|
if [ "$POSTGRES_PASSWORD" ]; then
|
||||||
|
pass="PASSWORD '$POSTGRES_PASSWORD'"
|
||||||
|
authMethod=md5
|
||||||
|
else
|
||||||
|
# The - option suppresses leading tabs but *not* spaces. :)
|
||||||
|
cat >&2 <<-'EOWARN'
|
||||||
|
****************************************************
|
||||||
|
WARNING: No password has been set for the database.
|
||||||
|
This will allow anyone with access to the
|
||||||
|
Postgres port to access your database. In
|
||||||
|
Docker's default configuration, this is
|
||||||
|
effectively any other container on the same
|
||||||
|
system.
|
||||||
|
|
||||||
|
Use "-e POSTGRES_PASSWORD=password" to set
|
||||||
|
it in "docker run".
|
||||||
|
****************************************************
|
||||||
|
EOWARN
|
||||||
|
|
||||||
|
pass=
|
||||||
|
authMethod=trust
|
||||||
|
fi
|
||||||
|
|
||||||
|
{ echo; echo "host all all 0.0.0.0/0 $authMethod"; } | su-exec postgres tee -a "$PGDATA/pg_hba.conf" > /dev/null
|
||||||
|
|
||||||
|
# internal start of server in order to allow set-up using psql-client
|
||||||
|
# does not listen on external TCP/IP and waits until start finishes
|
||||||
|
su-exec postgres pg_ctl -D "$PGDATA" \
|
||||||
|
-o "-c listen_addresses='localhost'" \
|
||||||
|
-w start
|
||||||
|
|
||||||
|
: ${POSTGRES_USER:=postgres}
|
||||||
|
: ${POSTGRES_DB:=$POSTGRES_USER}
|
||||||
|
export POSTGRES_USER POSTGRES_DB
|
||||||
|
|
||||||
|
psql=( psql -v ON_ERROR_STOP=1 )
|
||||||
|
|
||||||
|
if [ "$POSTGRES_DB" != 'postgres' ]; then
|
||||||
|
"${psql[@]}" --username postgres <<-EOSQL
|
||||||
|
CREATE DATABASE "$POSTGRES_DB" ;
|
||||||
|
EOSQL
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$POSTGRES_USER" = 'postgres' ]; then
|
||||||
|
op='ALTER'
|
||||||
|
else
|
||||||
|
op='CREATE'
|
||||||
|
fi
|
||||||
|
"${psql[@]}" --username postgres <<-EOSQL
|
||||||
|
$op USER "$POSTGRES_USER" WITH SUPERUSER $pass ;
|
||||||
|
EOSQL
|
||||||
|
echo
|
||||||
|
|
||||||
|
psql+=( --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" )
|
||||||
|
|
||||||
|
echo
|
||||||
|
for f in /docker-entrypoint-initdb.d/*; do
|
||||||
|
case "$f" in
|
||||||
|
*.sh) echo "$0: running $f"; . "$f" ;;
|
||||||
|
*.sql) echo "$0: running $f"; "${psql[@]}" < "$f"; echo ;;
|
||||||
|
*.sql.gz) echo "$0: running $f"; gunzip -c "$f" | "${psql[@]}"; echo ;;
|
||||||
|
*) echo "$0: ignoring $f" ;;
|
||||||
|
esac
|
||||||
|
echo
|
||||||
|
done
|
||||||
|
|
||||||
|
su-exec postgres pg_ctl -D "$PGDATA" -m fast -w stop
|
||||||
|
|
||||||
|
echo
|
||||||
|
echo 'PostgreSQL init process complete; ready for start up.'
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec su-exec postgres "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec "$@"
|
119
9.4/alpine/Dockerfile
Normal file
119
9.4/alpine/Dockerfile
Normal file
@ -0,0 +1,119 @@
|
|||||||
|
# vim:set ft=dockerfile:
|
||||||
|
FROM alpine:3.4
|
||||||
|
|
||||||
|
# alpine includes "postgres" user/group in base install
|
||||||
|
# /etc/passwd:22:postgres:x:70:70::/var/lib/postgresql:/bin/sh
|
||||||
|
# /etc/group:34:postgres:x:70:
|
||||||
|
|
||||||
|
# su-exec (gosu-compatible) is installed further down
|
||||||
|
|
||||||
|
# make the "en_US.UTF-8" locale so postgres will be utf-8 enabled by default
|
||||||
|
# alpine doesn't require explicit locale-file generation
|
||||||
|
ENV LANG en_US.utf8
|
||||||
|
|
||||||
|
RUN mkdir /docker-entrypoint-initdb.d
|
||||||
|
|
||||||
|
ENV PG_MAJOR 9.4
|
||||||
|
ENV PG_VERSION 9.4.10
|
||||||
|
ENV PG_SHA256 7061678bed1981c681ce54c76b98b6ec17743f090a9775104a45e7e1a8826ecf
|
||||||
|
|
||||||
|
RUN set -ex \
|
||||||
|
\
|
||||||
|
&& apk add --no-cache --virtual .fetch-deps \
|
||||||
|
ca-certificates \
|
||||||
|
openssl \
|
||||||
|
tar \
|
||||||
|
\
|
||||||
|
&& wget -O postgresql.tar.bz2 "https://ftp.postgresql.org/pub/source/v$PG_VERSION/postgresql-$PG_VERSION.tar.bz2" \
|
||||||
|
&& echo "$PG_SHA256 *postgresql.tar.bz2" | sha256sum -c - \
|
||||||
|
&& mkdir -p /usr/src/postgresql \
|
||||||
|
&& tar \
|
||||||
|
--extract \
|
||||||
|
--file postgresql.tar.bz2 \
|
||||||
|
--directory /usr/src/postgresql \
|
||||||
|
--strip-components 1 \
|
||||||
|
&& rm postgresql.tar.bz2 \
|
||||||
|
\
|
||||||
|
&& apk add --no-cache --virtual .build-deps \
|
||||||
|
bison \
|
||||||
|
flex \
|
||||||
|
gcc \
|
||||||
|
# krb5-dev \
|
||||||
|
libc-dev \
|
||||||
|
libedit-dev \
|
||||||
|
libxml2-dev \
|
||||||
|
libxslt-dev \
|
||||||
|
make \
|
||||||
|
# openldap-dev \
|
||||||
|
openssl-dev \
|
||||||
|
perl \
|
||||||
|
# perl-dev \
|
||||||
|
# python-dev \
|
||||||
|
# python3-dev \
|
||||||
|
# tcl-dev \
|
||||||
|
util-linux-dev \
|
||||||
|
zlib-dev \
|
||||||
|
\
|
||||||
|
&& cd /usr/src/postgresql \
|
||||||
|
# configure options taken from:
|
||||||
|
# https://anonscm.debian.org/cgit/pkg-postgresql/postgresql.git/tree/debian/rules?h=9.5
|
||||||
|
&& ./configure \
|
||||||
|
# "/usr/src/postgresql/src/backend/access/common/tupconvert.c:105: undefined reference to `libintl_gettext'"
|
||||||
|
# --enable-nls \
|
||||||
|
--enable-integer-datetimes \
|
||||||
|
--enable-thread-safety \
|
||||||
|
--enable-tap-tests \
|
||||||
|
# skip debugging info -- we want tiny size instead
|
||||||
|
# --enable-debug \
|
||||||
|
--disable-rpath \
|
||||||
|
--with-uuid=e2fs \
|
||||||
|
--with-gnu-ld \
|
||||||
|
--with-pgport=5432 \
|
||||||
|
--with-system-tzdata=/usr/share/zoneinfo \
|
||||||
|
--prefix=/usr/local \
|
||||||
|
\
|
||||||
|
# these make our image abnormally large (at least 100MB larger), which seems uncouth for an "Alpine" (ie, "small") variant :)
|
||||||
|
# --with-krb5 \
|
||||||
|
# --with-gssapi \
|
||||||
|
# --with-ldap \
|
||||||
|
# --with-tcl \
|
||||||
|
# --with-perl \
|
||||||
|
# --with-python \
|
||||||
|
# --with-pam \
|
||||||
|
--with-openssl \
|
||||||
|
--with-libxml \
|
||||||
|
--with-libxslt \
|
||||||
|
&& make -j "$(getconf _NPROCESSORS_ONLN)" world \
|
||||||
|
&& make install-world \
|
||||||
|
&& make -C contrib install \
|
||||||
|
\
|
||||||
|
&& runDeps="$( \
|
||||||
|
scanelf --needed --nobanner --recursive /usr/local \
|
||||||
|
| awk '{ gsub(/,/, "\nso:", $2); print "so:" $2 }' \
|
||||||
|
| sort -u \
|
||||||
|
| xargs -r apk info --installed \
|
||||||
|
| sort -u \
|
||||||
|
)" \
|
||||||
|
&& apk add --no-cache --virtual .postgresql-rundeps \
|
||||||
|
$runDeps \
|
||||||
|
bash \
|
||||||
|
su-exec \
|
||||||
|
&& apk del .build-deps \
|
||||||
|
&& cd / \
|
||||||
|
&& rm -rf \
|
||||||
|
/usr/src/postgresql \
|
||||||
|
/usr/local/include/* \
|
||||||
|
&& find /usr/local -name '*.a' -delete
|
||||||
|
|
||||||
|
RUN mkdir -p /var/run/postgresql && chown -R postgres /var/run/postgresql
|
||||||
|
|
||||||
|
ENV PATH /usr/lib/postgresql/$PG_MAJOR/bin:$PATH
|
||||||
|
ENV PGDATA /var/lib/postgresql/data
|
||||||
|
VOLUME /var/lib/postgresql/data
|
||||||
|
|
||||||
|
COPY docker-entrypoint.sh /
|
||||||
|
|
||||||
|
ENTRYPOINT ["/docker-entrypoint.sh"]
|
||||||
|
|
||||||
|
EXPOSE 5432
|
||||||
|
CMD ["postgres"]
|
100
9.4/alpine/docker-entrypoint.sh
Executable file
100
9.4/alpine/docker-entrypoint.sh
Executable file
@ -0,0 +1,100 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if [ "${1:0:1}" = '-' ]; then
|
||||||
|
set -- postgres "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$1" = 'postgres' ]; then
|
||||||
|
mkdir -p "$PGDATA"
|
||||||
|
chmod 700 "$PGDATA"
|
||||||
|
chown -R postgres "$PGDATA"
|
||||||
|
|
||||||
|
mkdir -p /run/postgresql
|
||||||
|
chmod g+s /run/postgresql
|
||||||
|
chown -R postgres /run/postgresql
|
||||||
|
|
||||||
|
# look specifically for PG_VERSION, as it is expected in the DB dir
|
||||||
|
if [ ! -s "$PGDATA/PG_VERSION" ]; then
|
||||||
|
eval "su-exec postgres initdb $POSTGRES_INITDB_ARGS"
|
||||||
|
|
||||||
|
# check password first so we can output the warning before postgres
|
||||||
|
# messes it up
|
||||||
|
if [ "$POSTGRES_PASSWORD" ]; then
|
||||||
|
pass="PASSWORD '$POSTGRES_PASSWORD'"
|
||||||
|
authMethod=md5
|
||||||
|
else
|
||||||
|
# The - option suppresses leading tabs but *not* spaces. :)
|
||||||
|
cat >&2 <<-'EOWARN'
|
||||||
|
****************************************************
|
||||||
|
WARNING: No password has been set for the database.
|
||||||
|
This will allow anyone with access to the
|
||||||
|
Postgres port to access your database. In
|
||||||
|
Docker's default configuration, this is
|
||||||
|
effectively any other container on the same
|
||||||
|
system.
|
||||||
|
|
||||||
|
Use "-e POSTGRES_PASSWORD=password" to set
|
||||||
|
it in "docker run".
|
||||||
|
****************************************************
|
||||||
|
EOWARN
|
||||||
|
|
||||||
|
pass=
|
||||||
|
authMethod=trust
|
||||||
|
fi
|
||||||
|
|
||||||
|
{ echo; echo "host all all 0.0.0.0/0 $authMethod"; } | su-exec postgres tee -a "$PGDATA/pg_hba.conf" > /dev/null
|
||||||
|
|
||||||
|
# internal start of server in order to allow set-up using psql-client
|
||||||
|
# does not listen on external TCP/IP and waits until start finishes
|
||||||
|
su-exec postgres pg_ctl -D "$PGDATA" \
|
||||||
|
-o "-c listen_addresses='localhost'" \
|
||||||
|
-w start
|
||||||
|
|
||||||
|
: ${POSTGRES_USER:=postgres}
|
||||||
|
: ${POSTGRES_DB:=$POSTGRES_USER}
|
||||||
|
export POSTGRES_USER POSTGRES_DB
|
||||||
|
|
||||||
|
psql=( psql -v ON_ERROR_STOP=1 )
|
||||||
|
|
||||||
|
if [ "$POSTGRES_DB" != 'postgres' ]; then
|
||||||
|
"${psql[@]}" --username postgres <<-EOSQL
|
||||||
|
CREATE DATABASE "$POSTGRES_DB" ;
|
||||||
|
EOSQL
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$POSTGRES_USER" = 'postgres' ]; then
|
||||||
|
op='ALTER'
|
||||||
|
else
|
||||||
|
op='CREATE'
|
||||||
|
fi
|
||||||
|
"${psql[@]}" --username postgres <<-EOSQL
|
||||||
|
$op USER "$POSTGRES_USER" WITH SUPERUSER $pass ;
|
||||||
|
EOSQL
|
||||||
|
echo
|
||||||
|
|
||||||
|
psql+=( --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" )
|
||||||
|
|
||||||
|
echo
|
||||||
|
for f in /docker-entrypoint-initdb.d/*; do
|
||||||
|
case "$f" in
|
||||||
|
*.sh) echo "$0: running $f"; . "$f" ;;
|
||||||
|
*.sql) echo "$0: running $f"; "${psql[@]}" < "$f"; echo ;;
|
||||||
|
*.sql.gz) echo "$0: running $f"; gunzip -c "$f" | "${psql[@]}"; echo ;;
|
||||||
|
*) echo "$0: ignoring $f" ;;
|
||||||
|
esac
|
||||||
|
echo
|
||||||
|
done
|
||||||
|
|
||||||
|
su-exec postgres pg_ctl -D "$PGDATA" -m fast -w stop
|
||||||
|
|
||||||
|
echo
|
||||||
|
echo 'PostgreSQL init process complete; ready for start up.'
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec su-exec postgres "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec "$@"
|
@ -1,60 +1,92 @@
|
|||||||
# vim:set ft=dockerfile:
|
# vim:set ft=dockerfile:
|
||||||
FROM alpine:3.3
|
FROM alpine:3.4
|
||||||
|
|
||||||
# explicitly set user/group IDs
|
# alpine includes "postgres" user/group in base install
|
||||||
#RUN adduser -S -G postgres -u 999 postgres
|
# /etc/passwd:22:postgres:x:70:70::/var/lib/postgresql:/bin/sh
|
||||||
|
# /etc/group:34:postgres:x:70:
|
||||||
|
|
||||||
|
# su-exec (gosu-compatible) is installed further down
|
||||||
|
|
||||||
# make the "en_US.UTF-8" locale so postgres will be utf-8 enabled by default
|
# make the "en_US.UTF-8" locale so postgres will be utf-8 enabled by default
|
||||||
|
# alpine doesn't require explicit locale-file generation
|
||||||
ENV LANG en_US.utf8
|
ENV LANG en_US.utf8
|
||||||
|
|
||||||
RUN mkdir /docker-entrypoint-initdb.d
|
RUN mkdir /docker-entrypoint-initdb.d
|
||||||
|
|
||||||
ENV PG_MAJOR 9.5
|
ENV PG_MAJOR 9.5
|
||||||
ENV PG_VERSION 9.5.2
|
ENV PG_VERSION 9.5.5
|
||||||
ENV PG_SHA256 f8d132e464506b551ef498719f18cfe9d777709c7a1589dc360afc0b20e47c41
|
ENV PG_SHA256 02c65290be74de6604c3fed87c9fd3e6b32e949f0ab8105a75bd7ed5aa71f394
|
||||||
|
|
||||||
|
RUN set -ex \
|
||||||
# configure options taken from:
|
\
|
||||||
# https://anonscm.debian.org/cgit/pkg-postgresql/postgresql.git/tree/debian/rules?h=9.5
|
&& apk add --no-cache --virtual .fetch-deps \
|
||||||
RUN set -x \
|
ca-certificates \
|
||||||
|
openssl \
|
||||||
|
tar \
|
||||||
|
\
|
||||||
|
&& wget -O postgresql.tar.bz2 "https://ftp.postgresql.org/pub/source/v$PG_VERSION/postgresql-$PG_VERSION.tar.bz2" \
|
||||||
|
&& echo "$PG_SHA256 *postgresql.tar.bz2" | sha256sum -c - \
|
||||||
|
&& mkdir -p /usr/src/postgresql \
|
||||||
|
&& tar \
|
||||||
|
--extract \
|
||||||
|
--file postgresql.tar.bz2 \
|
||||||
|
--directory /usr/src/postgresql \
|
||||||
|
--strip-components 1 \
|
||||||
|
&& rm postgresql.tar.bz2 \
|
||||||
|
\
|
||||||
&& apk add --no-cache --virtual .build-deps \
|
&& apk add --no-cache --virtual .build-deps \
|
||||||
su-exec \
|
|
||||||
bash \
|
|
||||||
bison \
|
bison \
|
||||||
curl \
|
|
||||||
flex \
|
flex \
|
||||||
gcc \
|
gcc \
|
||||||
krb5-dev \
|
# krb5-dev \
|
||||||
libc-dev \
|
libc-dev \
|
||||||
libedit-dev \
|
libedit-dev \
|
||||||
libxml2-dev \
|
libxml2-dev \
|
||||||
libxslt-dev \
|
libxslt-dev \
|
||||||
make \
|
make \
|
||||||
openldap-dev \
|
# openldap-dev \
|
||||||
openssl-dev \
|
openssl-dev \
|
||||||
perl \
|
perl \
|
||||||
perl-dev \
|
# perl-dev \
|
||||||
python3-dev \
|
# python-dev \
|
||||||
tcl-dev \
|
# python3-dev \
|
||||||
|
# tcl-dev \
|
||||||
util-linux-dev \
|
util-linux-dev \
|
||||||
zlib-dev \
|
zlib-dev \
|
||||||
&& curl -fSL "https://ftp.postgresql.org/pub/source/v$PG_VERSION/postgresql-$PG_VERSION.tar.bz2" -o postgresql.tar.bz2 \
|
\
|
||||||
&& echo "$PG_SHA256 postgresql.tar.bz2" | sha256sum -c - \
|
&& cd /usr/src/postgresql \
|
||||||
&& mkdir -p /usr/src \
|
# configure options taken from:
|
||||||
&& tar -jxf postgresql.tar.bz2 -C /usr/src \
|
# https://anonscm.debian.org/cgit/pkg-postgresql/postgresql.git/tree/debian/rules?h=9.5
|
||||||
&& rm postgresql.tar.bz2 \
|
|
||||||
&& cd /usr/src/postgresql-$PG_VERSION \
|
|
||||||
&& ./configure \
|
&& ./configure \
|
||||||
|
# "/usr/src/postgresql/src/backend/access/common/tupconvert.c:105: undefined reference to `libintl_gettext'"
|
||||||
|
# --enable-nls \
|
||||||
--enable-integer-datetimes \
|
--enable-integer-datetimes \
|
||||||
--enable-tap-tests \
|
|
||||||
--enable-thread-safety \
|
--enable-thread-safety \
|
||||||
--prefix=/usr/local \
|
--enable-tap-tests \
|
||||||
--with-libedit-preferred \
|
# skip debugging info -- we want tiny size instead
|
||||||
--with-openssl \
|
# --enable-debug \
|
||||||
|
--disable-rpath \
|
||||||
--with-uuid=e2fs \
|
--with-uuid=e2fs \
|
||||||
&& make -j$(getconf _NPROCESSORS_ONLN) world \
|
--with-gnu-ld \
|
||||||
|
--with-pgport=5432 \
|
||||||
|
--with-system-tzdata=/usr/share/zoneinfo \
|
||||||
|
--prefix=/usr/local \
|
||||||
|
\
|
||||||
|
# these make our image abnormally large (at least 100MB larger), which seems uncouth for an "Alpine" (ie, "small") variant :)
|
||||||
|
# --with-krb5 \
|
||||||
|
# --with-gssapi \
|
||||||
|
# --with-ldap \
|
||||||
|
# --with-tcl \
|
||||||
|
# --with-perl \
|
||||||
|
# --with-python \
|
||||||
|
# --with-pam \
|
||||||
|
--with-openssl \
|
||||||
|
--with-libxml \
|
||||||
|
--with-libxslt \
|
||||||
|
&& make -j "$(getconf _NPROCESSORS_ONLN)" world \
|
||||||
&& make install-world \
|
&& make install-world \
|
||||||
&& make -C contrib install \
|
&& make -C contrib install \
|
||||||
|
\
|
||||||
&& runDeps="$( \
|
&& runDeps="$( \
|
||||||
scanelf --needed --nobanner --recursive /usr/local \
|
scanelf --needed --nobanner --recursive /usr/local \
|
||||||
| awk '{ gsub(/,/, "\nso:", $2); print "so:" $2 }' \
|
| awk '{ gsub(/,/, "\nso:", $2); print "so:" $2 }' \
|
||||||
@ -62,9 +94,15 @@ RUN set -x \
|
|||||||
| xargs -r apk info --installed \
|
| xargs -r apk info --installed \
|
||||||
| sort -u \
|
| sort -u \
|
||||||
)" \
|
)" \
|
||||||
&& apk add --virtual .postgresql-rundeps $runDeps su-exec \
|
&& apk add --no-cache --virtual .postgresql-rundeps \
|
||||||
|
$runDeps \
|
||||||
|
bash \
|
||||||
|
su-exec \
|
||||||
&& apk del .build-deps \
|
&& apk del .build-deps \
|
||||||
&& cd / && rm -rf /usr/src/postgresql-* /usr/local/include/* \
|
&& cd / \
|
||||||
|
&& rm -rf \
|
||||||
|
/usr/src/postgresql \
|
||||||
|
/usr/local/include/* \
|
||||||
&& find /usr/local -name '*.a' -delete
|
&& find /usr/local -name '*.a' -delete
|
||||||
|
|
||||||
RUN mkdir -p /var/run/postgresql && chown -R postgres /var/run/postgresql
|
RUN mkdir -p /var/run/postgresql && chown -R postgres /var/run/postgresql
|
||||||
|
@ -1,21 +1,22 @@
|
|||||||
#!/bin/sh -e
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
set_listen_addresses() {
|
if [ "${1:0:1}" = '-' ]; then
|
||||||
sedEscapedValue="$(echo "$1" | sed 's/[\/&]/\\&/g')"
|
set -- postgres "$@"
|
||||||
sed -ri "s/^#?(listen_addresses\s*=\s*)\S+/\1'$sedEscapedValue'/" "$PGDATA/postgresql.conf"
|
fi
|
||||||
}
|
|
||||||
|
|
||||||
if [ "$1" = 'postgres' ]; then
|
if [ "$1" = 'postgres' ]; then
|
||||||
mkdir -p "$PGDATA"
|
mkdir -p "$PGDATA"
|
||||||
chmod 700 "$PGDATA"
|
chmod 700 "$PGDATA"
|
||||||
chown -R postgres "$PGDATA"
|
chown -R postgres "$PGDATA"
|
||||||
|
|
||||||
chmod g+s /var/run/postgresql
|
mkdir -p /run/postgresql
|
||||||
chown -R postgres /var/run/postgresql
|
chmod g+s /run/postgresql
|
||||||
|
chown -R postgres /run/postgresql
|
||||||
|
|
||||||
# look specifically for PG_VERSION, as it is expected in the DB dir
|
# look specifically for PG_VERSION, as it is expected in the DB dir
|
||||||
if [ ! -s "$PGDATA/PG_VERSION" ]; then
|
if [ ! -s "$PGDATA/PG_VERSION" ]; then
|
||||||
su-exec postgres initdb
|
eval "su-exec postgres initdb $POSTGRES_INITDB_ARGS"
|
||||||
|
|
||||||
# check password first so we can output the warning before postgres
|
# check password first so we can output the warning before postgres
|
||||||
# messes it up
|
# messes it up
|
||||||
@ -42,20 +43,22 @@ if [ "$1" = 'postgres' ]; then
|
|||||||
authMethod=trust
|
authMethod=trust
|
||||||
fi
|
fi
|
||||||
|
|
||||||
{ echo; echo "host all all 0.0.0.0/0 $authMethod"; } >> "$PGDATA/pg_hba.conf"
|
{ echo; echo "host all all 0.0.0.0/0 $authMethod"; } | su-exec postgres tee -a "$PGDATA/pg_hba.conf" > /dev/null
|
||||||
|
|
||||||
# internal start of server in order to allow set-up using psql-client
|
# internal start of server in order to allow set-up using psql-client
|
||||||
# does not listen on TCP/IP and waits until start finishes
|
# does not listen on external TCP/IP and waits until start finishes
|
||||||
su-exec postgres pg_ctl -D "$PGDATA" \
|
su-exec postgres pg_ctl -D "$PGDATA" \
|
||||||
-o "-c listen_addresses=''" \
|
-o "-c listen_addresses='localhost'" \
|
||||||
-w start
|
-w start
|
||||||
|
|
||||||
: ${POSTGRES_USER:=postgres}
|
: ${POSTGRES_USER:=postgres}
|
||||||
: ${POSTGRES_DB:=$POSTGRES_USER}
|
: ${POSTGRES_DB:=$POSTGRES_USER}
|
||||||
export POSTGRES_USER POSTGRES_DB
|
export POSTGRES_USER POSTGRES_DB
|
||||||
|
|
||||||
|
psql=( psql -v ON_ERROR_STOP=1 )
|
||||||
|
|
||||||
if [ "$POSTGRES_DB" != 'postgres' ]; then
|
if [ "$POSTGRES_DB" != 'postgres' ]; then
|
||||||
psql --username postgres <<-EOSQL
|
"${psql[@]}" --username postgres <<-EOSQL
|
||||||
CREATE DATABASE "$POSTGRES_DB" ;
|
CREATE DATABASE "$POSTGRES_DB" ;
|
||||||
EOSQL
|
EOSQL
|
||||||
echo
|
echo
|
||||||
@ -66,24 +69,25 @@ if [ "$1" = 'postgres' ]; then
|
|||||||
else
|
else
|
||||||
op='CREATE'
|
op='CREATE'
|
||||||
fi
|
fi
|
||||||
|
"${psql[@]}" --username postgres <<-EOSQL
|
||||||
psql --username postgres <<-EOSQL
|
|
||||||
$op USER "$POSTGRES_USER" WITH SUPERUSER $pass ;
|
$op USER "$POSTGRES_USER" WITH SUPERUSER $pass ;
|
||||||
EOSQL
|
EOSQL
|
||||||
echo
|
echo
|
||||||
|
|
||||||
|
psql+=( --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" )
|
||||||
|
|
||||||
echo
|
echo
|
||||||
for f in /docker-entrypoint-initdb.d/*; do
|
for f in /docker-entrypoint-initdb.d/*; do
|
||||||
case "$f" in
|
case "$f" in
|
||||||
*.sh) echo "$0: running $f"; . "$f" ;;
|
*.sh) echo "$0: running $f"; . "$f" ;;
|
||||||
*.sql) echo "$0: running $f"; psql --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" < "$f" && echo ;;
|
*.sql) echo "$0: running $f"; "${psql[@]}" < "$f"; echo ;;
|
||||||
*) echo "$0: ignoring $f" ;;
|
*.sql.gz) echo "$0: running $f"; gunzip -c "$f" | "${psql[@]}"; echo ;;
|
||||||
|
*) echo "$0: ignoring $f" ;;
|
||||||
esac
|
esac
|
||||||
echo
|
echo
|
||||||
done
|
done
|
||||||
|
|
||||||
su-exec postgres pg_ctl -D "$PGDATA" -m fast -w stop
|
su-exec postgres pg_ctl -D "$PGDATA" -m fast -w stop
|
||||||
set_listen_addresses '*'
|
|
||||||
|
|
||||||
echo
|
echo
|
||||||
echo 'PostgreSQL init process complete; ready for start up.'
|
echo 'PostgreSQL init process complete; ready for start up.'
|
||||||
|
119
9.6/alpine/Dockerfile
Normal file
119
9.6/alpine/Dockerfile
Normal file
@ -0,0 +1,119 @@
|
|||||||
|
# vim:set ft=dockerfile:
|
||||||
|
FROM alpine:3.4
|
||||||
|
|
||||||
|
# alpine includes "postgres" user/group in base install
|
||||||
|
# /etc/passwd:22:postgres:x:70:70::/var/lib/postgresql:/bin/sh
|
||||||
|
# /etc/group:34:postgres:x:70:
|
||||||
|
|
||||||
|
# su-exec (gosu-compatible) is installed further down
|
||||||
|
|
||||||
|
# make the "en_US.UTF-8" locale so postgres will be utf-8 enabled by default
|
||||||
|
# alpine doesn't require explicit locale-file generation
|
||||||
|
ENV LANG en_US.utf8
|
||||||
|
|
||||||
|
RUN mkdir /docker-entrypoint-initdb.d
|
||||||
|
|
||||||
|
ENV PG_MAJOR 9.6
|
||||||
|
ENV PG_VERSION 9.6.1
|
||||||
|
ENV PG_SHA256 e5101e0a49141fc12a7018c6dad594694d3a3325f5ab71e93e0e51bd94e51fcd
|
||||||
|
|
||||||
|
RUN set -ex \
|
||||||
|
\
|
||||||
|
&& apk add --no-cache --virtual .fetch-deps \
|
||||||
|
ca-certificates \
|
||||||
|
openssl \
|
||||||
|
tar \
|
||||||
|
\
|
||||||
|
&& wget -O postgresql.tar.bz2 "https://ftp.postgresql.org/pub/source/v$PG_VERSION/postgresql-$PG_VERSION.tar.bz2" \
|
||||||
|
&& echo "$PG_SHA256 *postgresql.tar.bz2" | sha256sum -c - \
|
||||||
|
&& mkdir -p /usr/src/postgresql \
|
||||||
|
&& tar \
|
||||||
|
--extract \
|
||||||
|
--file postgresql.tar.bz2 \
|
||||||
|
--directory /usr/src/postgresql \
|
||||||
|
--strip-components 1 \
|
||||||
|
&& rm postgresql.tar.bz2 \
|
||||||
|
\
|
||||||
|
&& apk add --no-cache --virtual .build-deps \
|
||||||
|
bison \
|
||||||
|
flex \
|
||||||
|
gcc \
|
||||||
|
# krb5-dev \
|
||||||
|
libc-dev \
|
||||||
|
libedit-dev \
|
||||||
|
libxml2-dev \
|
||||||
|
libxslt-dev \
|
||||||
|
make \
|
||||||
|
# openldap-dev \
|
||||||
|
openssl-dev \
|
||||||
|
perl \
|
||||||
|
# perl-dev \
|
||||||
|
# python-dev \
|
||||||
|
# python3-dev \
|
||||||
|
# tcl-dev \
|
||||||
|
util-linux-dev \
|
||||||
|
zlib-dev \
|
||||||
|
\
|
||||||
|
&& cd /usr/src/postgresql \
|
||||||
|
# configure options taken from:
|
||||||
|
# https://anonscm.debian.org/cgit/pkg-postgresql/postgresql.git/tree/debian/rules?h=9.5
|
||||||
|
&& ./configure \
|
||||||
|
# "/usr/src/postgresql/src/backend/access/common/tupconvert.c:105: undefined reference to `libintl_gettext'"
|
||||||
|
# --enable-nls \
|
||||||
|
--enable-integer-datetimes \
|
||||||
|
--enable-thread-safety \
|
||||||
|
--enable-tap-tests \
|
||||||
|
# skip debugging info -- we want tiny size instead
|
||||||
|
# --enable-debug \
|
||||||
|
--disable-rpath \
|
||||||
|
--with-uuid=e2fs \
|
||||||
|
--with-gnu-ld \
|
||||||
|
--with-pgport=5432 \
|
||||||
|
--with-system-tzdata=/usr/share/zoneinfo \
|
||||||
|
--prefix=/usr/local \
|
||||||
|
\
|
||||||
|
# these make our image abnormally large (at least 100MB larger), which seems uncouth for an "Alpine" (ie, "small") variant :)
|
||||||
|
# --with-krb5 \
|
||||||
|
# --with-gssapi \
|
||||||
|
# --with-ldap \
|
||||||
|
# --with-tcl \
|
||||||
|
# --with-perl \
|
||||||
|
# --with-python \
|
||||||
|
# --with-pam \
|
||||||
|
--with-openssl \
|
||||||
|
--with-libxml \
|
||||||
|
--with-libxslt \
|
||||||
|
&& make -j "$(getconf _NPROCESSORS_ONLN)" world \
|
||||||
|
&& make install-world \
|
||||||
|
&& make -C contrib install \
|
||||||
|
\
|
||||||
|
&& runDeps="$( \
|
||||||
|
scanelf --needed --nobanner --recursive /usr/local \
|
||||||
|
| awk '{ gsub(/,/, "\nso:", $2); print "so:" $2 }' \
|
||||||
|
| sort -u \
|
||||||
|
| xargs -r apk info --installed \
|
||||||
|
| sort -u \
|
||||||
|
)" \
|
||||||
|
&& apk add --no-cache --virtual .postgresql-rundeps \
|
||||||
|
$runDeps \
|
||||||
|
bash \
|
||||||
|
su-exec \
|
||||||
|
&& apk del .build-deps \
|
||||||
|
&& cd / \
|
||||||
|
&& rm -rf \
|
||||||
|
/usr/src/postgresql \
|
||||||
|
/usr/local/include/* \
|
||||||
|
&& find /usr/local -name '*.a' -delete
|
||||||
|
|
||||||
|
RUN mkdir -p /var/run/postgresql && chown -R postgres /var/run/postgresql
|
||||||
|
|
||||||
|
ENV PATH /usr/lib/postgresql/$PG_MAJOR/bin:$PATH
|
||||||
|
ENV PGDATA /var/lib/postgresql/data
|
||||||
|
VOLUME /var/lib/postgresql/data
|
||||||
|
|
||||||
|
COPY docker-entrypoint.sh /
|
||||||
|
|
||||||
|
ENTRYPOINT ["/docker-entrypoint.sh"]
|
||||||
|
|
||||||
|
EXPOSE 5432
|
||||||
|
CMD ["postgres"]
|
100
9.6/alpine/docker-entrypoint.sh
Executable file
100
9.6/alpine/docker-entrypoint.sh
Executable file
@ -0,0 +1,100 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if [ "${1:0:1}" = '-' ]; then
|
||||||
|
set -- postgres "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$1" = 'postgres' ]; then
|
||||||
|
mkdir -p "$PGDATA"
|
||||||
|
chmod 700 "$PGDATA"
|
||||||
|
chown -R postgres "$PGDATA"
|
||||||
|
|
||||||
|
mkdir -p /run/postgresql
|
||||||
|
chmod g+s /run/postgresql
|
||||||
|
chown -R postgres /run/postgresql
|
||||||
|
|
||||||
|
# look specifically for PG_VERSION, as it is expected in the DB dir
|
||||||
|
if [ ! -s "$PGDATA/PG_VERSION" ]; then
|
||||||
|
eval "su-exec postgres initdb $POSTGRES_INITDB_ARGS"
|
||||||
|
|
||||||
|
# check password first so we can output the warning before postgres
|
||||||
|
# messes it up
|
||||||
|
if [ "$POSTGRES_PASSWORD" ]; then
|
||||||
|
pass="PASSWORD '$POSTGRES_PASSWORD'"
|
||||||
|
authMethod=md5
|
||||||
|
else
|
||||||
|
# The - option suppresses leading tabs but *not* spaces. :)
|
||||||
|
cat >&2 <<-'EOWARN'
|
||||||
|
****************************************************
|
||||||
|
WARNING: No password has been set for the database.
|
||||||
|
This will allow anyone with access to the
|
||||||
|
Postgres port to access your database. In
|
||||||
|
Docker's default configuration, this is
|
||||||
|
effectively any other container on the same
|
||||||
|
system.
|
||||||
|
|
||||||
|
Use "-e POSTGRES_PASSWORD=password" to set
|
||||||
|
it in "docker run".
|
||||||
|
****************************************************
|
||||||
|
EOWARN
|
||||||
|
|
||||||
|
pass=
|
||||||
|
authMethod=trust
|
||||||
|
fi
|
||||||
|
|
||||||
|
{ echo; echo "host all all 0.0.0.0/0 $authMethod"; } | su-exec postgres tee -a "$PGDATA/pg_hba.conf" > /dev/null
|
||||||
|
|
||||||
|
# internal start of server in order to allow set-up using psql-client
|
||||||
|
# does not listen on external TCP/IP and waits until start finishes
|
||||||
|
su-exec postgres pg_ctl -D "$PGDATA" \
|
||||||
|
-o "-c listen_addresses='localhost'" \
|
||||||
|
-w start
|
||||||
|
|
||||||
|
: ${POSTGRES_USER:=postgres}
|
||||||
|
: ${POSTGRES_DB:=$POSTGRES_USER}
|
||||||
|
export POSTGRES_USER POSTGRES_DB
|
||||||
|
|
||||||
|
psql=( psql -v ON_ERROR_STOP=1 )
|
||||||
|
|
||||||
|
if [ "$POSTGRES_DB" != 'postgres' ]; then
|
||||||
|
"${psql[@]}" --username postgres <<-EOSQL
|
||||||
|
CREATE DATABASE "$POSTGRES_DB" ;
|
||||||
|
EOSQL
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$POSTGRES_USER" = 'postgres' ]; then
|
||||||
|
op='ALTER'
|
||||||
|
else
|
||||||
|
op='CREATE'
|
||||||
|
fi
|
||||||
|
"${psql[@]}" --username postgres <<-EOSQL
|
||||||
|
$op USER "$POSTGRES_USER" WITH SUPERUSER $pass ;
|
||||||
|
EOSQL
|
||||||
|
echo
|
||||||
|
|
||||||
|
psql+=( --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" )
|
||||||
|
|
||||||
|
echo
|
||||||
|
for f in /docker-entrypoint-initdb.d/*; do
|
||||||
|
case "$f" in
|
||||||
|
*.sh) echo "$0: running $f"; . "$f" ;;
|
||||||
|
*.sql) echo "$0: running $f"; "${psql[@]}" < "$f"; echo ;;
|
||||||
|
*.sql.gz) echo "$0: running $f"; gunzip -c "$f" | "${psql[@]}"; echo ;;
|
||||||
|
*) echo "$0: ignoring $f" ;;
|
||||||
|
esac
|
||||||
|
echo
|
||||||
|
done
|
||||||
|
|
||||||
|
su-exec postgres pg_ctl -D "$PGDATA" -m fast -w stop
|
||||||
|
|
||||||
|
echo
|
||||||
|
echo 'PostgreSQL init process complete; ready for start up.'
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec su-exec postgres "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec "$@"
|
119
Dockerfile-alpine.template
Normal file
119
Dockerfile-alpine.template
Normal file
@ -0,0 +1,119 @@
|
|||||||
|
# vim:set ft=dockerfile:
|
||||||
|
FROM alpine:3.4
|
||||||
|
|
||||||
|
# alpine includes "postgres" user/group in base install
|
||||||
|
# /etc/passwd:22:postgres:x:70:70::/var/lib/postgresql:/bin/sh
|
||||||
|
# /etc/group:34:postgres:x:70:
|
||||||
|
|
||||||
|
# su-exec (gosu-compatible) is installed further down
|
||||||
|
|
||||||
|
# make the "en_US.UTF-8" locale so postgres will be utf-8 enabled by default
|
||||||
|
# alpine doesn't require explicit locale-file generation
|
||||||
|
ENV LANG en_US.utf8
|
||||||
|
|
||||||
|
RUN mkdir /docker-entrypoint-initdb.d
|
||||||
|
|
||||||
|
ENV PG_MAJOR %%PG_MAJOR%%
|
||||||
|
ENV PG_VERSION %%PG_VERSION%%
|
||||||
|
ENV PG_SHA256 %%PG_SHA256%%
|
||||||
|
|
||||||
|
RUN set -ex \
|
||||||
|
\
|
||||||
|
&& apk add --no-cache --virtual .fetch-deps \
|
||||||
|
ca-certificates \
|
||||||
|
openssl \
|
||||||
|
tar \
|
||||||
|
\
|
||||||
|
&& wget -O postgresql.tar.bz2 "https://ftp.postgresql.org/pub/source/v$PG_VERSION/postgresql-$PG_VERSION.tar.bz2" \
|
||||||
|
&& echo "$PG_SHA256 *postgresql.tar.bz2" | sha256sum -c - \
|
||||||
|
&& mkdir -p /usr/src/postgresql \
|
||||||
|
&& tar \
|
||||||
|
--extract \
|
||||||
|
--file postgresql.tar.bz2 \
|
||||||
|
--directory /usr/src/postgresql \
|
||||||
|
--strip-components 1 \
|
||||||
|
&& rm postgresql.tar.bz2 \
|
||||||
|
\
|
||||||
|
&& apk add --no-cache --virtual .build-deps \
|
||||||
|
bison \
|
||||||
|
flex \
|
||||||
|
gcc \
|
||||||
|
# krb5-dev \
|
||||||
|
libc-dev \
|
||||||
|
libedit-dev \
|
||||||
|
libxml2-dev \
|
||||||
|
libxslt-dev \
|
||||||
|
make \
|
||||||
|
# openldap-dev \
|
||||||
|
openssl-dev \
|
||||||
|
perl \
|
||||||
|
# perl-dev \
|
||||||
|
# python-dev \
|
||||||
|
# python3-dev \
|
||||||
|
# tcl-dev \
|
||||||
|
util-linux-dev \
|
||||||
|
zlib-dev \
|
||||||
|
\
|
||||||
|
&& cd /usr/src/postgresql \
|
||||||
|
# configure options taken from:
|
||||||
|
# https://anonscm.debian.org/cgit/pkg-postgresql/postgresql.git/tree/debian/rules?h=9.5
|
||||||
|
&& ./configure \
|
||||||
|
# "/usr/src/postgresql/src/backend/access/common/tupconvert.c:105: undefined reference to `libintl_gettext'"
|
||||||
|
# --enable-nls \
|
||||||
|
--enable-integer-datetimes \
|
||||||
|
--enable-thread-safety \
|
||||||
|
--enable-tap-tests \
|
||||||
|
# skip debugging info -- we want tiny size instead
|
||||||
|
# --enable-debug \
|
||||||
|
--disable-rpath \
|
||||||
|
--with-uuid=e2fs \
|
||||||
|
--with-gnu-ld \
|
||||||
|
--with-pgport=5432 \
|
||||||
|
--with-system-tzdata=/usr/share/zoneinfo \
|
||||||
|
--prefix=/usr/local \
|
||||||
|
\
|
||||||
|
# these make our image abnormally large (at least 100MB larger), which seems uncouth for an "Alpine" (ie, "small") variant :)
|
||||||
|
# --with-krb5 \
|
||||||
|
# --with-gssapi \
|
||||||
|
# --with-ldap \
|
||||||
|
# --with-tcl \
|
||||||
|
# --with-perl \
|
||||||
|
# --with-python \
|
||||||
|
# --with-pam \
|
||||||
|
--with-openssl \
|
||||||
|
--with-libxml \
|
||||||
|
--with-libxslt \
|
||||||
|
&& make -j "$(getconf _NPROCESSORS_ONLN)" world \
|
||||||
|
&& make install-world \
|
||||||
|
&& make -C contrib install \
|
||||||
|
\
|
||||||
|
&& runDeps="$( \
|
||||||
|
scanelf --needed --nobanner --recursive /usr/local \
|
||||||
|
| awk '{ gsub(/,/, "\nso:", $2); print "so:" $2 }' \
|
||||||
|
| sort -u \
|
||||||
|
| xargs -r apk info --installed \
|
||||||
|
| sort -u \
|
||||||
|
)" \
|
||||||
|
&& apk add --no-cache --virtual .postgresql-rundeps \
|
||||||
|
$runDeps \
|
||||||
|
bash \
|
||||||
|
su-exec \
|
||||||
|
&& apk del .build-deps \
|
||||||
|
&& cd / \
|
||||||
|
&& rm -rf \
|
||||||
|
/usr/src/postgresql \
|
||||||
|
/usr/local/include/* \
|
||||||
|
&& find /usr/local -name '*.a' -delete
|
||||||
|
|
||||||
|
RUN mkdir -p /var/run/postgresql && chown -R postgres /var/run/postgresql
|
||||||
|
|
||||||
|
ENV PATH /usr/lib/postgresql/$PG_MAJOR/bin:$PATH
|
||||||
|
ENV PGDATA /var/lib/postgresql/data
|
||||||
|
VOLUME /var/lib/postgresql/data
|
||||||
|
|
||||||
|
COPY docker-entrypoint.sh /
|
||||||
|
|
||||||
|
ENTRYPOINT ["/docker-entrypoint.sh"]
|
||||||
|
|
||||||
|
EXPOSE 5432
|
||||||
|
CMD ["postgres"]
|
@ -72,4 +72,20 @@ for version in "${versions[@]}"; do
|
|||||||
GitCommit: $commit
|
GitCommit: $commit
|
||||||
Directory: $version
|
Directory: $version
|
||||||
EOE
|
EOE
|
||||||
|
|
||||||
|
for variant in alpine; do
|
||||||
|
[ -f "$version/$variant/Dockerfile" ] || continue
|
||||||
|
|
||||||
|
commit="$(dirCommit "$version/$variant")"
|
||||||
|
|
||||||
|
variantAliases=( "${versionAliases[@]/%/-$variant}" )
|
||||||
|
variantAliases=( "${variantAliases[@]//latest-/}" )
|
||||||
|
|
||||||
|
echo
|
||||||
|
cat <<-EOE
|
||||||
|
Tags: $(join ', ' "${variantAliases[@]}")
|
||||||
|
GitCommit: $commit
|
||||||
|
Directory: $version/$variant
|
||||||
|
EOE
|
||||||
|
done
|
||||||
done
|
done
|
||||||
|
20
update.sh
20
update.sh
@ -19,9 +19,25 @@ for version in "${versions[@]}"; do
|
|||||||
(
|
(
|
||||||
set -x
|
set -x
|
||||||
cp docker-entrypoint.sh "$version/"
|
cp docker-entrypoint.sh "$version/"
|
||||||
sed 's/%%PG_MAJOR%%/'"$version"'/g; s/%%PG_VERSION%%/'"$fullVersion"'/g' Dockerfile.template > "$version/Dockerfile"
|
sed 's/%%PG_MAJOR%%/'"$version"'/g; s/%%PG_VERSION%%/'"$fullVersion"'/g' Dockerfile-debian.template > "$version/Dockerfile"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
# TODO figure out what to do with odd version numbers here, like release candidates
|
||||||
|
srcVersion="${fullVersion%%-*}"
|
||||||
|
srcSha256="$(curl -fsSL "https://ftp.postgresql.org/pub/source/v${srcVersion}/postgresql-${srcVersion}.tar.bz2.sha256" | cut -d' ' -f1)"
|
||||||
|
for variant in alpine; do
|
||||||
|
if [ ! -d "$version/$variant" ]; then
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
(
|
||||||
|
set -x
|
||||||
|
cp docker-entrypoint.sh "$version/$variant/"
|
||||||
|
sed -i 's/gosu/su-exec/g' "$version/$variant/docker-entrypoint.sh"
|
||||||
|
sed 's/%%PG_MAJOR%%/'"$version"'/g; s/%%PG_VERSION%%/'"$srcVersion"'/g; s/%%PG_SHA256%%/'"$srcSha256"'/g' Dockerfile-$variant.template > "$version/$variant/Dockerfile"
|
||||||
|
)
|
||||||
|
travisEnv="\n - VERSION=$version VARIANT=$variant$travisEnv"
|
||||||
|
done
|
||||||
|
|
||||||
travisEnv='\n - VERSION='"$version$travisEnv"
|
travisEnv='\n - VERSION='"$version$travisEnv"
|
||||||
done
|
done
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user