-
Notifications
You must be signed in to change notification settings - Fork 7
Expand file tree
/
Copy pathdockerfile
More file actions
71 lines (55 loc) · 2.11 KB
/
dockerfile
File metadata and controls
71 lines (55 loc) · 2.11 KB
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
# 第一阶段:构建环境
FROM golang:1.22-bullseye AS builder
WORKDIR /build
# 安装系统依赖
RUN apt-get update && apt-get install -y \
build-essential \
pkg-config \
&& rm -rf /var/lib/apt/lists/*
# 复制源代码
COPY shieldml_scan.html .
COPY shieldml_scan.js .
COPY shieldml_server.go .
COPY bt-shieldml .
COPY go.mod .
# 安装Go依赖
# RUN go mod download
# 只编译shieldml_server
RUN go mod tidy && \
go build -tags netgo,osusergo -ldflags '-s -w -extldflags "-static"' -o shieldml_server ./shieldml_server.go
# 第二阶段:运行环境
FROM debian:11-slim
WORKDIR /www/dk_project/dk_app/shieldml/
# 安装必要的运行时依赖
RUN apt-get update && apt-get install -y \
ca-certificates \
tzdata \
wget \
&& rm -rf /var/lib/apt/lists/* \
&& mkdir -p /www/dk_project/dk_app/shieldml/data \
&& mkdir -p /www/dk_project/dk_app/shieldml/data/tmp
# 设置时区
ENV TZ=Asia/Shanghai
# 从构建阶段复制编译好的程序和HTML/JS文件
COPY --from=builder /build/shieldml_server /www/dk_project/dk_app/shieldml/
COPY --from=builder /build/shieldml_scan.html /www/dk_project/dk_app/shieldml/
COPY --from=builder /build/shieldml_scan.js /www/dk_project/dk_app/shieldml/
COPY --from=builder /build/bt-shieldml /www/dk_project/dk_app/shieldml/
# 创建非特权用户
RUN groupadd -r shieldml && useradd -r -g shieldml shieldml
# 设置权限
RUN chmod +x /www/dk_project/dk_app/shieldml/shieldml_server && \
chmod +x /www/dk_project/dk_app/shieldml/bt-shieldml && \
echo '{"results":[]}' > /www/dk_project/dk_app/shieldml/data/webshellJson.json && \
chmod 755 /www/dk_project/dk_app/shieldml/data/webshellJson.json && \
chmod 755 /www/dk_project/dk_app/shieldml/data && \
chmod 755 /www/dk_project/dk_app/shieldml/data/tmp && \
chown -R shieldml:shieldml /www/dk_project/dk_app/shieldml
# 暴露端口
EXPOSE 6528
# 健康检查
HEALTHCHECK --interval=30s --timeout=5s --start-period=5s --retries=3 \
CMD wget -qO- http://localhost:6528/shieldml_scan.html || exit 1
USER shieldml
# 启动服务
CMD ["/www/dk_project/dk_app/shieldml/shieldml_server"]