-
Notifications
You must be signed in to change notification settings - Fork 1
/
Dockerfile.template
77 lines (65 loc) · 3.46 KB
/
Dockerfile.template
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
# vim:set ft=dockerfile:
ARG UBI_VERSION=%%UBI_VERSION%%
ARG PGBOUNCER_VERSION=%%PGBOUNCER_VERSION%%
FROM registry.access.redhat.com/ubi9/ubi-minimal:${UBI_VERSION} AS build
ARG PGBOUNCER_VERSION
# Install build dependencies. EPEL repository is required by udns
RUN set -xe ; \
rpm -i https://dl.fedoraproject.org/pub/epel/epel-release-latest-9.noarch.rpm ; \
microdnf -y install make libevent libevent-devel pkg-config openssl openssl-devel \
tar gzip gcc udns udns-devel ; \
microdnf -y clean all --enablerepo='*' ; \
curl -sL http://www.pgbouncer.org/downloads/files/${PGBOUNCER_VERSION}/pgbouncer-${PGBOUNCER_VERSION}.tar.gz > pgbouncer.tar.gz ; \
tar xzf pgbouncer.tar.gz ; \
cd pgbouncer-${PGBOUNCER_VERSION} ; \
./configure --without-cares --with-udns ; \
make
FROM registry.access.redhat.com/ubi9/ubi-minimal:${UBI_VERSION}
ARG PGBOUNCER_VERSION
ARG TARGETARCH
LABEL name="PgBouncer Container Images" \
vendor="EnterpriseDB" \
url="https://www.enterprisedb.com/" \
version="%%PGBOUNCER_VERSION%%" \
release="%%IMAGE_RELEASE_VERSION%%" \
summary="Container images for PgBouncer (connection pooler for PostgreSQL)." \
description="This Docker image contains PgBouncer based on RedHat Universal Base Images (UBI) 9 minimal."
COPY root/ /
RUN --mount=type=secret,id=cs_token \
set -xe ; \
rpm -i https://dl.fedoraproject.org/pub/epel/epel-release-latest-9.noarch.rpm ; \
ARCH="${TARGETARCH}" ; \
base_url="https://download.postgresql.org/pub/repos/yum/reporpms" ; \
case $ARCH in \
amd64) \
rpm -i "${base_url}/EL-9-x86_64/pgdg-redhat-repo-latest.noarch.rpm" ;; \
arm64) \
rpm -i "${base_url}/EL-9-aarch64/pgdg-redhat-repo-latest.noarch.rpm" ;; \
ppc64le) \
curl -u token:$(cat /run/secrets/cs_token) -1sLf https://downloads.enterprisedb.com/basic/enterprise/setup.rpm.sh | bash ;; \
s390x) \
curl -u token:$(cat /run/secrets/cs_token) -1sLf https://downloads.enterprisedb.com/basic/edb/setup.rpm.sh | bash ;; \
*) \
exit 1 ;; \
esac ; \
microdnf -y install libevent openssl udns shadow-utils findutils ; \
microdnf -y install --setopt=install_weak_deps=0 --setopt=tsflags=nodocs --nodocs --noplugins postgresql16 ; \
microdnf -y clean all --enablerepo='*' ; \
rm -fr /etc/yum.repos.d/enterprisedb-edb.repo ; \
rm -fr /tmp/* ; \
groupadd -r --gid 996 pgbouncer ; \
useradd -r --uid 998 --gid 996 pgbouncer ; \
mkdir -p /var/log/pgbouncer ; \
mkdir -p /var/run/pgbouncer ; \
chown pgbouncer:pgbouncer /var/log/pgbouncer ; \
chown pgbouncer:pgbouncer /var/run/pgbouncer
COPY --from=build ["/pgbouncer-${PGBOUNCER_VERSION}/pgbouncer", "/usr/bin/"]
COPY --from=build ["/pgbouncer-${PGBOUNCER_VERSION}/etc/pgbouncer.ini", "/etc/pgbouncer/pgbouncer.ini.example"]
COPY --from=build ["/pgbouncer-${PGBOUNCER_VERSION}/etc/userlist.txt", "/etc/pgbouncer/userlist.txt.example"]
RUN touch /etc/pgbouncer/pgbouncer.ini /etc/pgbouncer/userlist.txt
# DoD 2.3 - remove setuid/setgid from any binary that not strictly requires it, and before doing that list them on the stdout
RUN find / -not -path "/proc/*" -perm /6000 -type f -exec ls -ld {} \; -exec chmod a-s {} \; || true
EXPOSE 6432
USER pgbouncer
COPY entrypoint.sh .
ENTRYPOINT ["./entrypoint.sh"]