generated from cybozu-go/neco-template
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathDockerfile.daemon
30 lines (24 loc) · 993 Bytes
/
Dockerfile.daemon
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
ARG FLATCAR_VERSION
FROM ghcr.io/cybozu/golang:1.23-noble AS builder
WORKDIR /work
COPY go.mod go.mod
COPY go.sum go.sum
COPY cmd/necoperf-daemon cmd/necoperf-daemon
COPY internal internal
RUN CGO_ENABLED=0 go build -ldflags="-w -s" -o necoperf-daemon ./cmd/necoperf-daemon
FROM ghcr.io/flatcar/flatcar-sdk-amd64:${FLATCAR_VERSION} AS flatcar
FROM scratch
LABEL org.opencontainers.image.source https://github.com/cybozu-go/necoperf
ENV HOME=/home/necoperf
COPY --from=flatcar /bin/ /bin/
COPY --from=flatcar /sbin/setcap /sbin/setcap
COPY --from=flatcar /lib64 /lib64
COPY --from=flatcar /usr/lib64 /usr/lib64
COPY --from=flatcar /usr/bin/perf /usr/bin/sleep /usr/bin/
COPY --from=builder /work/necoperf-daemon /usr/local/bin/necoperf-daemon
RUN setcap "cap_perfmon,cap_sys_ptrace,cap_syslog,cap_sys_admin,cap_sys_chroot=ep" /usr/bin/perf \
&& mkdir -p ${HOME} \
&& chown -R 1000:1000 ${HOME}
WORKDIR ${HOME}
USER 1000:1000
ENTRYPOINT ["/usr/local/bin/necoperf-daemon", "start"]