forked from WeAreAmaze/amc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDockerfile
45 lines (34 loc) · 1.35 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
# Build
FROM docker.io/library/golang:1.19-alpine3.15 AS builder
# Add aliyun repos
RUN echo http://mirrors.aliyun.com/alpine/v3.13/main/ > /etc/apk/repositories && echo http://mirrors.aliyun.com/alpine/v3.13/community/ >> /etc/apk/repositories
# GO PROXY
RUN go env -w GOPROXY=https://goproxy.cn,direct
# RUN apk add --no-cache gcc musl-dev linux-headers git make
RUN apk add --no-cache build-base linux-headers git bash ca-certificates libstdc++
WORKDIR /amc
ADD . .
ENV GO111MODULE="on"
ENV GOPROXY="https://goproxy.cn,direct"
RUN go mod tidy && go build -o ./build/bin/AmazeChain-linux-amd64 ./cmd/amc
FROM docker.io/library/alpine:3.15
#libstdc++
RUN apk add --no-cache ca-certificates curl tzdata
# copy compiled artifacts from builder
COPY --from=builder /amc/build/bin/* /usr/local/bin/
# Setup user and group
#
# from the perspective of the container, uid=1000, gid=1000 is a sensible choice, but if caller creates a .env
# (example in repo root), these defaults will get overridden when make calls docker-compose
ARG UID=1000
ARG GID=1000
RUN adduser -D -u $UID -g $GID amc
ENV AMCDATA /home/amc/data
# this 777 will be replaced by 700 at runtime (allows semi-arbitrary "--user" values)
RUN mkdir -p "$AMCDATA" && chown -R amc:amc "$AMCDATA" && chmod 777 "$AMCDATA"
VOLUME /home/amc/data
USER amc
WORKDIR /home/amc
RUN echo $UID
EXPOSE 20012
EXPOSE 20013