You've already forked postgres
mirror of
https://github.com/docker-library/postgres.git
synced 2025-11-17 13:02:40 +03:00
add postgres:9.5-alpine variant
build it from source
This commit is contained in:
committed by
Tianon Gravi
parent
4aef66e640
commit
442a92590b
81
9.5/alpine/Dockerfile
Normal file
81
9.5/alpine/Dockerfile
Normal file
@@ -0,0 +1,81 @@
|
|||||||
|
# vim:set ft=dockerfile:
|
||||||
|
FROM alpine:3.3
|
||||||
|
|
||||||
|
# explicitly set user/group IDs
|
||||||
|
#RUN adduser -S -G postgres -u 999 postgres
|
||||||
|
|
||||||
|
# make the "en_US.UTF-8" locale so postgres will be utf-8 enabled by default
|
||||||
|
ENV LANG en_US.utf8
|
||||||
|
|
||||||
|
RUN mkdir /docker-entrypoint-initdb.d
|
||||||
|
|
||||||
|
ENV PG_MAJOR 9.5
|
||||||
|
ENV PG_VERSION 9.5.0
|
||||||
|
ENV PG_SHA256 f1c0d3a1a8aa8c92738cab0153fbfffcc4d4158b3fee84f7aa6bfea8283978bc
|
||||||
|
|
||||||
|
|
||||||
|
# configure options taken from:
|
||||||
|
# https://anonscm.debian.org/cgit/pkg-postgresql/postgresql.git/tree/debian/rules?h=9.5
|
||||||
|
RUN set -x \
|
||||||
|
&& apk add --no-cache --virtual .build-deps \
|
||||||
|
su-exec \
|
||||||
|
bash \
|
||||||
|
bison \
|
||||||
|
curl \
|
||||||
|
flex \
|
||||||
|
gcc \
|
||||||
|
krb5-dev \
|
||||||
|
libc-dev \
|
||||||
|
libedit-dev \
|
||||||
|
libxml2-dev \
|
||||||
|
libxslt-dev \
|
||||||
|
make \
|
||||||
|
openldap-dev \
|
||||||
|
openssl-dev \
|
||||||
|
perl \
|
||||||
|
perl-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 \
|
||||||
|
&& ./configure \
|
||||||
|
--enable-integer-datetimes \
|
||||||
|
--enable-tap-tests \
|
||||||
|
--enable-thread-safety \
|
||||||
|
--prefix=/usr/local \
|
||||||
|
--with-libedit-preferred \
|
||||||
|
--with-openssl \
|
||||||
|
--with-uuid=e2fs \
|
||||||
|
&& 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 --virtual .postgresql-rundeps $runDeps 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"]
|
||||||
96
9.5/alpine/docker-entrypoint.sh
Executable file
96
9.5/alpine/docker-entrypoint.sh
Executable file
@@ -0,0 +1,96 @@
|
|||||||
|
#!/bin/sh -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" = 'postgres' ]; then
|
||||||
|
mkdir -p "$PGDATA"
|
||||||
|
chmod 700 "$PGDATA"
|
||||||
|
chown -R postgres "$PGDATA"
|
||||||
|
|
||||||
|
chmod g+s /var/run/postgresql
|
||||||
|
chown -R postgres /var/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
|
||||||
|
|
||||||
|
# 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"; } >> "$PGDATA/pg_hba.conf"
|
||||||
|
|
||||||
|
# internal start of server in order to allow set-up using psql-client
|
||||||
|
# does not listen on TCP/IP and waits until start finishes
|
||||||
|
su-exec postgres pg_ctl -D "$PGDATA" \
|
||||||
|
-o "-c listen_addresses=''" \
|
||||||
|
-w start
|
||||||
|
|
||||||
|
: ${POSTGRES_USER:=postgres}
|
||||||
|
: ${POSTGRES_DB:=$POSTGRES_USER}
|
||||||
|
export POSTGRES_USER POSTGRES_DB
|
||||||
|
|
||||||
|
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
|
||||||
|
|
||||||
|
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" ;;
|
||||||
|
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.'
|
||||||
|
echo
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec su-exec postgres "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec "$@"
|
||||||
Reference in New Issue
Block a user