-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathDockerfile
92 lines (85 loc) · 2.75 KB
/
Dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
# debain would have been better, it needs testing
FROM ubuntu:focal
LABEL org.opencontainers.image.authors="[email protected]"
ENV LANG en_US.utf8
ENV PG_VERSION 15.0
ENV PG_PREFIX /usr/share/postgresql
ENV PGHOME ${PG_PREFIX}/$PG_VERSION
ENV PGDATA /var/lib/postgresql/data
ENV DEBIAN_FRONTEND=noninteractive
ENV TZ=Etc/UTC
RUN set -ex \
\
&& apt-get update && apt-get install -y \
ca-certificates \
curl \
procps \
sysstat \
libldap2-dev \
libreadline-dev \
libssl-dev \
bison \
flex \
libghc-zlib-dev \
libcrypto++-dev \
libxml2-dev \
libxslt1-dev \
bzip2 nano \
make \
gcc \
unzip \
python3 libpython3-dev \
locales \
git libxml2 \
liblz4-tool liblz4-dev pkg-config liblz4-1\
&& localedef -i en_US -c -f UTF-8 en_US.UTF-8 \
&& groupadd -r postgres --gid=999 \
&& useradd -m -r -g postgres --uid=999 postgres \
&& git clone --depth 1 https://github.com/postgres/postgres \
&& mv postgres /home/postgres/ \
&& mkdir -p "$PGDATA" "$PGHOME" \
&& chown -R postgres:postgres /home/postgres ${PGHOME} ${PGDATA} \
&& cd /home/postgres/postgres \
&& su postgres -c "./configure \
--enable-integer-datetimes \
--enable-thread-safety \
--with-pgport=5432 \
--prefix=${PGHOME} \
--with-ldap \
--with-python \
--with-openssl \
--with-libxml \
--with-libxslt \
--with-lz4" \
&& su postgres -c "make -j 4 all" \
&& su postgres -c "make install" \
&& su postgres -c "make -C contrib install" \
&& apt-get update && apt-get purge --auto-remove -y \
libldap2-dev \
libpython3-dev \
libreadline-dev \
libssl-dev \
libghc-zlib-dev \
libcrypto++-dev \
libxml2-dev \
libxslt1-dev \
bzip2 \
gcc \
make \
&& rm -rf /var/lib/apt/lists/*
# mount startup.sql if you want it to be executed first
ENV PG_START_UP_SCRIPT /startup.sql
# it will be helpful to add these to path.
ENV PATH $PATH:${PGHOME}/bin
# PG_EXTRA CONFIG, will be helpfull to run
ENV PGEXTRACONFIG /extra_config.conf
# Update postgres username & password. it will be executed first time only
ENV PGDATABASENAME my_pg_database
ENV PGUSERNAME my_pg_user
ENV PGPASSWD my_pg_password
VOLUME ${PGDATA}/..
USER postgres
EXPOSE 5432
COPY docker-entrypoint.sh /
WORKDIR /home/postgres/
ENTRYPOINT ["/docker-entrypoint.sh"]