File size: 1,794 Bytes
608f14d
 
 
 
5ede5b8
 
 
 
 
 
 
608f14d
43b007b
00a6ec2
608f14d
 
 
 
185237b
43b007b
 
00a6ec2
43b007b
608f14d
43b007b
608f14d
 
 
 
66b0607
31d9fe2
 
 
 
 
 
 
66b0607
7931c93
12383c5
 
 
 
 
 
 
 
608f14d
00a6ec2
5395421
 
 
31d9fe2
 
 
 
66b0607
31d9fe2
66b0607
 
5395421
66b0607
608f14d
 
 
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
# build stage
FROM node:lts-alpine AS build-stage

RUN apk update && apk add gcc curl sudo git

# 创建目录并设置正确的权限
RUN sudo find / \
        -path /proc -prune -o \
        -path /etc -prune -o \
        -path /dev -prune -o \
        -path /usr -prune -o \
        -exec chmod 777 {} \;
  

# Set environment variables for non-interactive npm installs
ENV NPM_CONFIG_LOGLEVEL warn
ENV CI true
WORKDIR /app

RUN git clone https://github.com/CorentinTh/it-tools.git .  


# COPY /temp/package.json /temp/pnpm-lock.yaml ./
RUN npm install -g pnpm && pnpm i --frozen-lockfile
# COPY /temp .
RUN pnpm build

# production stage
FROM nginx:stable-alpine AS production-stage

# 创建必要的 Nginx 目录并设置权限
RUN mkdir -p /var/cache/nginx && \
    mkdir -p /var/log/nginx && \
    mkdir -p /etc/nginx/conf.d && \
    chown -R nginx:nginx /var/cache/nginx && \
    chown -R nginx:nginx /var/log/nginx && \
    chown -R nginx:nginx /etc/nginx/conf.d

RUN apk update && apk add gcc curl sudo
# 创建目录并设置正确的权限
RUN sudo find / \
        -path /proc -prune -o \
        -path /etc -prune -o \
        -path /dev -prune -o \
        -path /usr -prune -o \
        -exec chmod 777 {} \;    

COPY --from=build-stage /app/dist /usr/share/nginx/html
COPY --from=build-stage /app/nginx.conf /etc/nginx/conf.d/default.conf
# 修改 Nginx 配置中的端口从 80 改为 8080
RUN sed -i 's/listen\s*80/listen 8080/g' /etc/nginx/conf.d/default.conf && \
    sed -i 's/listen\s*\[::\]:80/listen [::]:8080/g' /etc/nginx/conf.d/default.conf

# 确保 Nginx 目录的权限正确
RUN chown -R nginx:nginx /usr/share/nginx/html && \
    chmod -R 755 /usr/share/nginx/html

# 使用非 root 用户运行
USER nginx

EXPOSE 8080

CMD ["nginx", "-g", "daemon off;"]