diff --git a/Dockerfile b/Dockerfile index 194e546..2ca2166 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,6 +1,6 @@ ARG ALPINE="alpine:3.17" ARG RUST="rust:1.67-alpine3.17" -ARG GOLANG="golang:1.18-alpine3.16" +ARG GOLANG="golang:1.19-alpine3.17" FROM ${ALPINE} AS upx RUN apk add build-base cmake @@ -11,32 +11,47 @@ RUN make UPX_CMAKE_CONFIG_FLAGS=-DCMAKE_EXE_LINKER_FLAGS=-static WORKDIR ./build/release/ RUN strip upx && mv upx /tmp/ -FROM ${GOLANG} AS adguard -ENV ADGUARD="0.107.20" -RUN apk add git make npm yarn -RUN git clone https://github.com/AdguardTeam/AdGuardHome.git -b v${ADGUARD} --depth=1 -WORKDIR ./AdGuardHome/ -RUN make js-deps -RUN make js-build -RUN make CHANNEL="release" VERBOSE=1 go-build && mv AdGuardHome /tmp/ +FROM ${GOLANG} AS dnsproxy +ENV DNSPROXY="0.48.0" +RUN wget https://github.com/AdguardTeam/dnsproxy/archive/refs/tags/v${DNSPROXY}.tar.gz && tar xf v${DNSPROXY}.tar.gz +WORKDIR ./dnsproxy-${DNSPROXY}/ +RUN go get +RUN env CGO_ENABLED=0 go build -v -trimpath -ldflags "-X main.VersionString=${DNSPROXY} -s -w" && mv dnsproxy /tmp/ COPY --from=upx /tmp/upx /usr/bin/ -RUN upx -9 /tmp/AdGuardHome +RUN upx -9 /tmp/dnsproxy FROM ${GOLANG} AS overture ENV OVERTURE="1.8" RUN wget https://github.com/shawn1m/overture/archive/refs/tags/v${OVERTURE}.tar.gz && tar xf v${OVERTURE}.tar.gz WORKDIR ./overture-${OVERTURE}/main/ +RUN go get RUN env CGO_ENABLED=0 go build -v -trimpath -ldflags "-X main.version=v${OVERTURE} -s -w" && mv main /tmp/overture COPY --from=upx /tmp/upx /usr/bin/ RUN upx -9 /tmp/overture -FROM ${GOLANG} AS dnsproxy -ENV DNSPROXY="0.46.4" -RUN wget https://github.com/AdguardTeam/dnsproxy/archive/refs/tags/v${DNSPROXY}.tar.gz && tar xf v${DNSPROXY}.tar.gz -WORKDIR ./dnsproxy-${DNSPROXY}/ -RUN env CGO_ENABLED=0 go build -v -trimpath -ldflags "-X main.VersionString=${DNSPROXY} -s -w" && mv dnsproxy /tmp/ +FROM ${ALPINE} AS adguard-src +RUN apk add git +ENV ADGUARD="0.107.25" +RUN git clone https://github.com/AdguardTeam/AdGuardHome.git -b v${ADGUARD} --depth=1 + +FROM ${ALPINE} AS adguard-web +RUN apk add make npm +COPY --from=adguard-src /AdGuardHome/ /AdGuardHome/ +WORKDIR /AdGuardHome/ +RUN make js-deps +# TODO: for node18, remove the OpenSSL compatibility option after AdGuardHome project upgrade +RUN env NODE_OPTIONS="--openssl-legacy-provider" make js-build +RUN mv ./build/static/ /tmp/ + +FROM ${GOLANG} AS adguard +RUN apk add git make +COPY --from=adguard-src /AdGuardHome/ /AdGuardHome/ +WORKDIR /AdGuardHome/ +RUN go get +COPY --from=adguard-web /tmp/static/ ./build/static/ +RUN make CHANNEL="release" VERBOSE=1 go-build && mv AdGuardHome /tmp/ COPY --from=upx /tmp/upx /usr/bin/ -RUN upx -9 /tmp/dnsproxy +RUN upx -9 /tmp/AdGuardHome FROM ${RUST} AS rust-mods RUN apk add libc-dev openssl-dev @@ -53,8 +68,7 @@ COPY --from=rust-mods /tmp/libto_json.a /cleardns/src/target/release/ WORKDIR /cleardns/bin/ RUN cmake -DCMAKE_EXE_LINKER_FLAGS=-static .. && make && mv cleardns /tmp/ COPY --from=upx /tmp/upx /usr/bin/ -WORKDIR /tmp/ -RUN strip cleardns && upx -9 cleardns +RUN strip /tmp/cleardns && upx -9 /tmp/cleardns FROM ${ALPINE} AS build RUN apk add xz @@ -63,10 +77,10 @@ RUN wget https://res.dnomd343.top/Share/cleardns/gfwlist.txt.xz && \ wget https://res.dnomd343.top/Share/cleardns/china-ip.txt.xz && \ wget https://res.dnomd343.top/Share/cleardns/chinalist.txt.xz && \ xz -d *.xz && tar cJf assets.tar.xz *.txt && rm *.txt -COPY --from=adguard /tmp/AdGuardHome /release/usr/bin/ -COPY --from=overture /tmp/overture /release/usr/bin/ -COPY --from=dnsproxy /tmp/dnsproxy /release/usr/bin/ COPY --from=cleardns /tmp/cleardns /release/usr/bin/ +COPY --from=dnsproxy /tmp/dnsproxy /release/usr/bin/ +COPY --from=overture /tmp/overture /release/usr/bin/ +COPY --from=adguard /tmp/AdGuardHome /release/usr/bin/ FROM ${ALPINE} COPY --from=build /release/ / diff --git a/src/utils/process.c b/src/utils/process.c index 7ee110c..9552385 100644 --- a/src/utils/process.c +++ b/src/utils/process.c @@ -55,7 +55,6 @@ void process_exec(process *proc) { log_perror("%s fork error -> ", proc->name); server_exit(EXIT_FORK_ERROR); } else if (pid == 0) { // child process - log_debug("Subprocess fork success -> PID = %d", getpid()); if (chdir(proc->cwd)) { // change working directory log_perror("%s with invalid cwd `%s` -> ", proc->name, proc->cwd); exit(EXIT_EXEC_ERROR); @@ -155,11 +154,11 @@ void get_exit_signal() { // get SIGINT or SIGTERM signal void get_sub_exit() { // catch child process exit if (EXITING) { - log_debug("Skip SIGCHLD signal"); + log_debug("Skip handle SIGCHLD"); return; } int status; - log_debug("Handle SIGCHLD begin"); + log_debug("Start handle SIGCHLD"); for (process **proc = process_list; *proc != NULL; ++proc) { if ((*proc)->pid == 0) { continue; // skip not running process