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;"]
|