Browse Source

Merge branch 'dev'

dev
Dnomd343 2 years ago
parent
commit
cbf118754e
  1. 56
      Dockerfile
  2. 5
      src/utils/process.c

56
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/ /

5
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

Loading…
Cancel
Save