From 94b14d12baa3157fa408d2755190ea3f20fa30a1 Mon Sep 17 00:00:00 2001 From: dnomd343 Date: Sat, 10 Sep 2022 01:39:59 +0800 Subject: [PATCH] build: docker build update --- Dockerfile | 39 ++++++++++++++++----------------------- 1 file changed, 16 insertions(+), 23 deletions(-) diff --git a/Dockerfile b/Dockerfile index acd1757..75ceab3 100644 --- a/Dockerfile +++ b/Dockerfile @@ -11,51 +11,44 @@ RUN make -C ./src/ && mkdir -p /upx/bin/ && mv ./src/upx.out /upx/bin/upx && \ FROM ${GOLANG_IMG} AS adguardhome ENV ADGUARD_VER="v0.107.12" -RUN apk add git make npm yarn -RUN git clone https://github.com/AdguardTeam/AdGuardHome.git +RUN apk add git make npm yarn && git clone https://github.com/AdguardTeam/AdGuardHome.git WORKDIR ./AdGuardHome/ -RUN git checkout ${ADGUARD_VER} && make CHANNEL="release" VERSION=${ADGUARD_VER} && mv ./AdGuardHome /tmp/ +RUN git checkout ${ADGUARD_VER} && make js-deps +RUN make js-build +RUN make CHANNEL="release" VERSION=${ADGUARD_VER} VERBOSE=1 go-build && mv ./AdGuardHome /tmp/ FROM ${GOLANG_IMG} AS dnsproxy ENV DNSPROXY_VER="0.44.0" RUN wget https://github.com/AdguardTeam/dnsproxy/archive/refs/tags/v${DNSPROXY_VER}.tar.gz && tar xf v${DNSPROXY_VER}.tar.gz WORKDIR ./dnsproxy-${DNSPROXY_VER}/ -RUN go mod download -x RUN env CGO_ENABLED=0 go build -v -trimpath -ldflags "-X main.VersionString=${DNSPROXY_VER} -s -w" && mv ./dnsproxy /tmp/ FROM ${GOLANG_IMG} AS overture ENV OVERTURE_VER="1.8" RUN wget https://github.com/shawn1m/overture/archive/refs/tags/v${OVERTURE_VER}.tar.gz && tar xf ./v${OVERTURE_VER}.tar.gz -WORKDIR ./overture-${OVERTURE_VER}/ -RUN env CGO_ENABLED=0 go build -o overture -trimpath -ldflags "-X main.version=v${OVERTURE_VER} -s -w" ./main/main.go && mv ./overture /tmp/ +WORKDIR ./overture-${OVERTURE_VER}/main/ +RUN env CGO_ENABLED=0 go build -o overture -trimpath -ldflags "-X main.version=v${OVERTURE_VER} -s -w" ./main.go && mv ./overture /tmp/ -FROM ${ALPINE_IMG} AS cleardns -COPY . /ClearDNS -RUN apk add build-base cmake glib-dev -RUN cd ./ClearDNS/ && mkdir ./build/ && \ - cd ./build/ && cmake -DCMAKE_BUILD_TYPE=Release .. && make && \ - mv ../bin/cleardns /tmp/ && strip /tmp/cleardns +#FROM ${ALPINE_IMG} AS cleardns +#COPY . /ClearDNS +#RUN apk add build-base cmake glib-dev +#RUN cd ./ClearDNS/ && mkdir ./build/ && \ +# cd ./build/ && cmake -DCMAKE_BUILD_TYPE=Release .. && make && \ +# mv ../bin/cleardns /tmp/ && strip /tmp/cleardns FROM ${ALPINE_IMG} AS asset -RUN apk add xz && \ +RUN apk add xz && mkdir -p /asset/ && \ wget https://res.dnomd343.top/Share/gfwlist/gfwlist.txt && \ wget https://res.dnomd343.top/Share/chinalist/china-ip.txt && \ wget https://res.dnomd343.top/Share/chinalist/chinalist.txt && \ - tar cJf /tmp/assets.tar.xz ./gfwlist.txt ./china-ip.txt ./chinalist.txt + tar cJf /asset/assets.tar.xz ./*.txt COPY --from=dnsproxy /tmp/dnsproxy /asset/usr/bin/ COPY --from=overture /tmp/overture /asset/usr/bin/ COPY --from=adguardhome /tmp/AdGuardHome /asset/usr/bin/ COPY --from=upx /upx/ /usr/ RUN ls /asset/usr/bin/* | xargs -P0 -n1 upx -9 -COPY --from=cleardns /tmp/cleardns /asset/usr/bin/ -COPY . /ClearDNS -RUN mkdir -p /asset/etc/ && \ - cp -r /ClearDNS/overture/ /asset/etc/ && \ - mv /tmp/assets.tar.xz /asset/etc/overture/asset.tar.xz && \ - mv /ClearDNS/load.sh /asset/usr/bin/load +#COPY --from=cleardns /tmp/cleardns /asset/usr/bin/ FROM ${ALPINE_IMG} -COPY --from=asset /asset / -RUN #apk add --no-cache ca-certificates glib && \ -#echo -e "0\t4\t*\t*\t*\t/etc/overture/update.sh" > /var/spool/cron/crontabs/root +COPY --from=asset /asset/ / #ENTRYPOINT ["cleardns"]