記得在讓Nodejs支持H5 History模式(connect-history-api-fallback源碼分析)一文中提到了HTML5
的History Mode
。然而在最近的使用過程當中發現connect-history-api-fallback
這個包效果並非那麼理想,用一段時間就會報錯。並且自己個人博客項目先後端並未徹底分離,雖然開發時是獨立的工程,可是前端工程打包後仍是放在了express
的靜態資源文件夾下進行部署。考慮到這兩個痛點,我決定在nginx
配置中對先後端進行部署分離。html
前端工程npm run build
打包後,再也不copy
到後端工程public
目錄下。而是獨立部署在nginx
的靜態資源目錄下,我放置的目錄是/usr/nginx/share/html/blog
前端
相關nginx
配置以下:linux
#博客轉發 blog.wbjiang.cn server { listen 80; server_name blog.wbjiang.cn; root /usr/share/nginx/html/blog; access_log logs/blog.log; error_log logs/blog.error; #博客靜態文件 location / { try_files $uri /index.html; } }
**小建議:**能夠在開發新功能完畢後,就將打包完畢的代碼提交到倉庫的release
分支,而後直接在linux
服務器上對應目錄下的Git
倉庫中git pull
,也算是半自動化部署了(後面也準備研究下全自動化部署)。nginx
blog.wbjiang.cn/api
前綴的視爲接口請求,統一轉發到express
後臺服務。配置以下:git
#api轉發 location /api { proxy_pass http://blog_pool; proxy_http_version 1.1; proxy_set_header Host $host; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; rewrite ^/api/(.*)$ /$1 break; }
負載均衡池配置(雖然只有一個服務,手動「狗頭」)shell
upstream blog_pool{ server 127.0.0.1:8002; }
pm2
重啓express
pm2 restart blog
nginx
重啓npm
nginx -s reload
首發連接後端
原文出處:https://www.cnblogs.com/wenbinjiang/p/11312502.htmlapi