-
Notifications
You must be signed in to change notification settings - Fork 12
/
Dockerfile
119 lines (101 loc) · 2.82 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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
FROM ghcr.io/balena-io-modules/confd-releases:0.0.6-confd-v0-16-0 AS confd
FROM debian:bookworm AS runtime
ENV DEBIAN_FRONTEND noninteractive
ENV TERM xterm
COPY src/01_nodoc /etc/dpkg/dpkg.cfg.d/
COPY src/01_buildconfig /etc/apt/apt.conf.d/
#hadolint ignore=DL3008,DL3014,DL3015
RUN apt-get update \
&& apt-get install \
apt-transport-https \
avahi-daemon \
build-essential \
ca-certificates \
curl \
dbus \
dirmngr \
git \
gnupg \
htop \
ifupdown \
init \
iptables \
iptraf-ng \
jq \
less \
libnss-mdns \
libpq-dev \
libsqlite3-dev \
nano \
net-tools \
openssh-client \
openssh-server \
openvpn \
procmail \
python3 \
python3-dev \
rsyslog \
rsyslog-gnutls \
strace \
systemd \
vim \
wget \
&& rm -rf /var/lib/apt/lists/*
SHELL ["/bin/bash", "-o", "pipefail", "-c"]
ARG TARGETARCH
# renovate: datasource=node-version depName=node
ARG NODE_VERSION=22.12.0
# renovate: datasource=npm depName=npm
ARG NPM_VERSION=10.9.2
RUN if [ "${TARGETARCH}" = "amd64" ] ; \
then \
NODE_URL="https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION-linux-x64.tar.gz" ; \
else \
NODE_URL="https://nodejs.org/dist/v$NODE_VERSION/node-v$NODE_VERSION-linux-${TARGETARCH}.tar.gz" ; \
fi && \
curl -fsSL "${NODE_URL}" | tar xz -C /usr/local --strip-components=1 --no-same-owner \
&& npm install -g npm@"$NPM_VERSION" \
&& rm -rf /root/.npm/_cacache \
&& npm cache clear --force \
&& rm -rf /tmp/*
# Confd binary installation.
COPY --from=confd /confd /usr/local/bin/confd
RUN mkdir -p /usr/src/app
WORKDIR /usr/src/app
# Remove default nproc limit for Avahi for it to work in-container
RUN sed -i "s/rlimit-nproc=3//" /etc/avahi/avahi-daemon.conf
# systemd configuration
ENV container lxc
# Set the stop signal to SIGRTMIN+3 which systemd understands as the signal to halt
STOPSIGNAL SIGRTMIN+3
# We want to use the multi-user.target not graphical.target
RUN systemctl set-default multi-user.target \
# We never want these to run in a container
&& systemctl mask \
apt-daily.timer \
apt-daily-upgrade.timer \
dev-hugepages.mount \
dev-mqueue.mount \
sys-fs-fuse-connections.mount \
sys-kernel-config.mount \
sys-kernel-debug.mount \
display-manager.service \
systemd-logind.service \
systemd-remount-fs.service \
getty.target \
graphical.target \
&& systemctl disable ssh.service
COPY src/confd.service src/certs-watch.* /etc/systemd/system/
COPY src/configure-balena.sh /usr/sbin/
COPY src/journald.conf /etc/systemd/
COPY src/rsyslog.conf src/nsswitch.conf /etc/
COPY src/dbus-no-oom-adjust.conf /etc/systemd/system/dbus.service.d/
COPY src/entry.sh /usr/bin/
COPY src/htoprc /root/.config/htop/
COPY src/mdns.allow /etc/mdns.allow
RUN systemctl enable certs-watch.path
VOLUME ["/sys/fs/cgroup"]
VOLUME ["/run"]
VOLUME ["/run/lock"]
CMD ["/usr/bin/entry.sh"]