forked from evcc-io/evcc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Dockerfile
76 lines (54 loc) · 1.53 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
# STEP 1 build ui
FROM node:16-alpine as node
RUN apk update && apk add --no-cache make alpine-sdk python3
WORKDIR /build
# install node tools
COPY Makefile .
COPY package*.json ./
RUN make install-ui
# build ui
COPY assets assets
COPY vue.config.js vue.config.js
COPY .eslintrc.js .eslintrc.js
RUN make clean ui
# STEP 2 build executable binary
FROM golang:1.17-alpine as builder
# Install git + SSL ca certificates.
# Git is required for fetching the dependencies.
# Ca-certificates is required to call HTTPS endpoints.
RUN apk update && apk add --no-cache git ca-certificates tzdata alpine-sdk && update-ca-certificates
WORKDIR /build
# define --build-arg RELEASE=1 to hide commit hash
ARG RELEASE
# install go tools and cache modules
COPY Makefile .
COPY go.mod .
COPY go.sum .
COPY tools.go .
RUN make install
RUN go mod download
# prepare
COPY . .
RUN make assets
# copy ui
COPY --from=node /build/dist /build/dist
# build
RUN RELEASE=${RELEASE} make build
# STEP 3 build a small image including module support
FROM alpine:3.15
WORKDIR /app
ENV TZ=Europe/Berlin
# Import from builder
COPY --from=builder /usr/share/zoneinfo /usr/share/zoneinfo
COPY --from=builder /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/
COPY --from=builder /build/evcc /usr/local/bin/evcc
COPY docker/bin/* /app/
# UI and /api
EXPOSE 7070/tcp
# KEBA charger
EXPOSE 7090/udp
# SMA Energy Manager
EXPOSE 9522/udp
HEALTHCHECK --interval=60s --start-period=60s --timeout=30s --retries=3 CMD [ "evcc", "health" ]
ENTRYPOINT [ "/app/entrypoint.sh" ]
CMD [ "evcc" ]