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:
|
||||
- VERSION=9.6
|
||||
- VERSION=9.6 VARIANT=alpine
|
||||
- VERSION=9.5
|
||||
- VERSION=9.5 VARIANT=alpine
|
||||
- VERSION=9.4
|
||||
- VERSION=9.4 VARIANT=alpine
|
||||
- VERSION=9.3
|
||||
- VERSION=9.3 VARIANT=alpine
|
||||
- VERSION=9.2
|
||||
- VERSION=9.2 VARIANT=alpine
|
||||
|
||||
install:
|
||||
- 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:
|
||||
FROM alpine:3.3
|
||||
FROM alpine:3.4
|
||||
|
||||
# explicitly set user/group IDs
|
||||
#RUN adduser -S -G postgres -u 999 postgres
|
||||
# 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.5
|
||||
ENV PG_VERSION 9.5.2
|
||||
ENV PG_SHA256 f8d132e464506b551ef498719f18cfe9d777709c7a1589dc360afc0b20e47c41
|
||||
ENV PG_VERSION 9.5.5
|
||||
ENV PG_SHA256 02c65290be74de6604c3fed87c9fd3e6b32e949f0ab8105a75bd7ed5aa71f394
|
||||
|
||||
|
||||
# configure options taken from:
|
||||
# https://anonscm.debian.org/cgit/pkg-postgresql/postgresql.git/tree/debian/rules?h=9.5
|
||||
RUN set -x \
|
||||
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 \
|
||||
su-exec \
|
||||
bash \
|
||||
bison \
|
||||
curl \
|
||||
flex \
|
||||
gcc \
|
||||
krb5-dev \
|
||||
# krb5-dev \
|
||||
libc-dev \
|
||||
libedit-dev \
|
||||
libxml2-dev \
|
||||
libxslt-dev \
|
||||
make \
|
||||
openldap-dev \
|
||||
# openldap-dev \
|
||||
openssl-dev \
|
||||
perl \
|
||||
perl-dev \
|
||||
python3-dev \
|
||||
tcl-dev \
|
||||
# perl-dev \
|
||||
# python-dev \
|
||||
# python3-dev \
|
||||
# tcl-dev \
|
||||
util-linux-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 - \
|
||||
&& mkdir -p /usr/src \
|
||||
&& tar -jxf postgresql.tar.bz2 -C /usr/src \
|
||||
&& rm postgresql.tar.bz2 \
|
||||
&& cd /usr/src/postgresql-$PG_VERSION \
|
||||
\
|
||||
&& 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-tap-tests \
|
||||
--enable-thread-safety \
|
||||
--prefix=/usr/local \
|
||||
--with-libedit-preferred \
|
||||
--with-openssl \
|
||||
--enable-tap-tests \
|
||||
# skip debugging info -- we want tiny size instead
|
||||
# --enable-debug \
|
||||
--disable-rpath \
|
||||
--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 -C contrib install \
|
||||
\
|
||||
&& runDeps="$( \
|
||||
scanelf --needed --nobanner --recursive /usr/local \
|
||||
| awk '{ gsub(/,/, "\nso:", $2); print "so:" $2 }' \
|
||||
@ -62,9 +94,15 @@ RUN set -x \
|
||||
| xargs -r apk info --installed \
|
||||
| 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 \
|
||||
&& cd / && rm -rf /usr/src/postgresql-* /usr/local/include/* \
|
||||
&& 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
|
||||
|
@ -1,21 +1,22 @@
|
||||
#!/bin/sh -e
|
||||
#!/bin/bash
|
||||
set -e
|
||||
|
||||
set_listen_addresses() {
|
||||
sedEscapedValue="$(echo "$1" | sed 's/[\/&]/\\&/g')"
|
||||
sed -ri "s/^#?(listen_addresses\s*=\s*)\S+/\1'$sedEscapedValue'/" "$PGDATA/postgresql.conf"
|
||||
}
|
||||
if [ "${1:0:1}" = '-' ]; then
|
||||
set -- postgres "$@"
|
||||
fi
|
||||
|
||||
if [ "$1" = 'postgres' ]; then
|
||||
mkdir -p "$PGDATA"
|
||||
chmod 700 "$PGDATA"
|
||||
chown -R postgres "$PGDATA"
|
||||
|
||||
chmod g+s /var/run/postgresql
|
||||
chown -R postgres /var/run/postgresql
|
||||
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
|
||||
su-exec postgres initdb
|
||||
eval "su-exec postgres initdb $POSTGRES_INITDB_ARGS"
|
||||
|
||||
# check password first so we can output the warning before postgres
|
||||
# messes it up
|
||||
@ -42,20 +43,22 @@ if [ "$1" = 'postgres' ]; then
|
||||
authMethod=trust
|
||||
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
|
||||
# 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" \
|
||||
-o "-c listen_addresses=''" \
|
||||
-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
|
||||
"${psql[@]}" --username postgres <<-EOSQL
|
||||
CREATE DATABASE "$POSTGRES_DB" ;
|
||||
EOSQL
|
||||
echo
|
||||
@ -66,24 +69,25 @@ if [ "$1" = 'postgres' ]; then
|
||||
else
|
||||
op='CREATE'
|
||||
fi
|
||||
|
||||
psql --username postgres <<-EOSQL
|
||||
"${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 --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" < "$f" && echo ;;
|
||||
*) echo "$0: ignoring $f" ;;
|
||||
*.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
|
||||
set_listen_addresses '*'
|
||||
|
||||
echo
|
||||
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
|
||||
Directory: $version
|
||||
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
|
||||
|
20
update.sh
20
update.sh
@ -19,9 +19,25 @@ for version in "${versions[@]}"; do
|
||||
(
|
||||
set -x
|
||||
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"
|
||||
done
|
||||
|
||||
|
Reference in New Issue
Block a user