nginx运行前端项目
nginx 运行前端项目
环境
linux
docker
准备工具
nginx.conf
server {
listen 18180 default_server;
server_name _;
#保存前端项目的路径
root /usr/share/nginx/dist;
index index.html;
#access_log /var/log/nginx/host.access.log main;
location / {
try_files $uri /index.html;
}
#转发到后端的 springboot 程序
location /api/ {
proxy_pass http://127.0.0.1:8180;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
Dockefile
FROM m.daocloud.io/docker.io/nginx:1.20.2-perl
# 删除默认配置
RUN rm /etc/nginx/conf.d/default.conf
# 拷贝自定义 nginx 配置
COPY nginx.conf /etc/nginx/conf.d/default.conf
# 拷贝前端 dist 文件
COPY dist /usr/share/nginx/dist
CMD ["nginx", "-g", "daemon off;"]
前端打包文件(npm run build:prod)
dist/
laihz@i7:~/project/datax/datax-front$ ls dist
avatar.jpg favicon.ico index.html static
运行
构建镜像
sudo docker build -t datax-front-images:1.0 .
运行容器
sudo docker run -d --privileged --network=host -itd --name datax-front datax-front-images:1.0
注意事项
- nginx.conf的root配置项目一定要和真实的前端文件夹一致
- Dockerfile的
COPY dist /usr/share/nginx/dist,这样写才是把dist 放在/usr/share/nginx下面