10.前端打包与nginx部署

文章目录

打包

首先,确保你的项目是可以运行的,以若依为例,运行npm run dev 是可以正常运行起来前端的。然后前端的打包命令是

复制代码
# 构建测试环境
npm run build:stage
# 构建生产环境
npm run build:prod

打包好之后,在项目代码路径下会出现一个dist文件夹,这里面的代码粘贴到nginx的html目录下即可。

部署

nginx

配置nginx,写好的配置文件如下:

复制代码
# 如果有前端上传文件的要求,需要加这个文件大小的限制,默认的大小不足以支撑项目需求。
client_max_body_size 200m;
server {
    # 使用docker将80映射成你想要的端口
    listen       80;
    listen  [::]:80;
    server_name  localhost;

    #access_log  /var/log/nginx/host.access.log  main;
	# 对于前端的所有静态资源和界面,映射在nginx的html路径下
    location / {  
        root   /usr/share/nginx/html;
        try_files $uri $uri/ /index.html;
        index  index.html index.htm;
    }
    # 对于需要访问后端的字段,都是使用api开头的,走这里替换一下访问的路径
    location /prod-api/ {
			proxy_set_header Host $http_host;
			proxy_set_header X-Real-IP $remote_addr;
			proxy_set_header REMOTE-HOST $remote_addr;
			proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
			proxy_pass http://192.168.1.15:28000/;
		}
   
   # 对于其它的后端界面,通过这里配置对应的访问路径
    location /nvr-api/ {
			proxy_pass http://183.249.83.27:10800/;
		}

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    #    proxy_pass   http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ \.php$ {
    #    root           html;
    #    fastcgi_pass   127.0.0.1:9000;
    #    fastcgi_index  index.php;
    #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
    #    include        fastcgi_params;
    #}

    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    #location ~ /\.ht {
    #    deny  all;
    #}
}

替换html

然后将打包好的dist目录丢在nginx的html下面。然后重启docker的nginx虚拟容器。

复制代码
sudo docker restart 容器id
相关推荐
Net蚂蚁代码1 小时前
Angular入门的环境准备步骤工作
前端·javascript·angular.js
小着3 小时前
vue项目页面最底部出现乱码
前端·javascript·vue.js·前端框架
lichenyang4536 小时前
React ajax中的跨域以及代理服务器
前端·react.js·ajax
呆呆的小草6 小时前
Cesium距离测量、角度测量、面积测量
开发语言·前端·javascript
夜影风6 小时前
Linux系统中自签名HTTPS证书
linux·运维·https
wb1896 小时前
流编辑器sed
运维·笔记·ubuntu·云计算
一 乐7 小时前
民宿|基于java的民宿推荐系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·源码
成工小白7 小时前
【Linux】C语言模拟实现shell命令行(程序替换原理)
linux·运维·服务器
testleaf8 小时前
前端面经整理【1】
前端·面试
好了来看下一题8 小时前
使用 React+Vite+Electron 搭建桌面应用
前端·react.js·electron