zoukankan      html  css  js  c++  java
  • 从部署上做到前后端分离

    前言

    记得在让Nodejs支持H5 History模式(connect-history-api-fallback源码分析)一文中提到了HTML5History Mode。然而在最近的使用过程中发现connect-history-api-fallback这个包效果并不是那么理想,用一段时间就会报错。而且本身我的博客项目前后端并未完全分离,虽然开发时是独立的工程,但是前端工程打包后还是放在了express的静态资源文件夹下进行部署。考虑到这两个痛点,我决定在nginx配置中对前后端进行部署分离。

    前端独立部署

    前端工程npm run build打包后,不再copy到后端工程public目录下。而是独立部署在nginx的静态资源目录下,我放置的目录是/usr/nginx/share/html/blog

    1564989575700

    相关nginx配置如下:

    #博客转发 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,也算是半自动化部署了(后面也准备研究下全自动化部署)。

    后端接口转发

    blog.wbjiang.cn/api前缀的视为接口请求,统一转发到express后台服务。配置如下:

    #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;
    }
    

    负载均衡池配置(虽然只有一个服务,手动“狗头”)

    upstream blog_pool{
    	server 127.0.0.1:8002;
    }
    

    重启服务

    pm2重启

    pm2 restart blog
    

    nginx重启

    nginx -s reload
    

    首发链接

  • 相关阅读:
    为什么非全站升级HTTPS不可?
    使用JSON实现分页
    Git常用命令
    chrome浏览器tab页内存占用变大,网站变慢为哪般?
    我们前端跟后端是怎么合作的
    关于响应式布局
    AngularJS(1)
    关于php语言的使用!
    你必须收藏的Github技巧
    CSS3 动画
  • 原文地址:https://www.cnblogs.com/wenbinjiang/p/11312502.html
Copyright © 2011-2022 走看看