前后端分离Nginx部署解决方案

转自:前后端分离Nginx部署解决方案 · 语雀

一、获取前端代码编译发布步骤

  • 获取FE前端源码
  • 执行cnpm install/npm install安装项目依赖
  • 执行npm run build构建编译生成dist文件该文件即为【项目发版代码】

二、服务器安装部署

  • 硬件要求:1U2G20G(服务器最低配置)
  • 安装Nginx
  • 将代码放置在你认为合适的目录该目录为Nginx server 中需要执行项目的路径【参考下面配置示例】
  • Nginx server中需要如下配置

三、解决vue使用的是vue-router的history模式时需要此配置

    location / {
        try_files $uri $uri/ /index.html;
    }
    // 5.由于项目为前后分离部署需要为前端提供接口调用使用
    // Nginx server需要proxy如下配置 ,proxy 指向地址为后端服务地址
    // 配置proxy代理路径 可以配置多个proxy
    location ~ /api/ {
            proxy_pass   http://api.xxxxx.com;//此地址为后端API服务器地址
    }
    或
    location ~ /api/ {
            proxy_pass   http://api.xxxxx.com:8081;//此地址为后端API服务器地址
    }

    // Nginx server 配置示例如下:
    server {
        listen      80;//此为端口配置
        server_name localhost;//此为网站域名配置
        set         $root_path '/opt/fe-code/dist';//此为项目代码路径配置
        root        $root_path;

        index index.html index.htm index.php;

        try_files $uri $uri/ @rewrite;
        
        if ( $host ~* (.*)\.(.*)\.(.*) ) {
        set $domain $1; 
        }

        location @rewrite {
            rewrite ^/(.*)$ /index.php?_url=/$1&_ename=$domain;
        }

        location ~* ^/(css|img|js|flv|swf|download)/(.+)$ {
            root $root_path;
        }
        #解决vue使用的是vue-router的history模式时刷新页面出现404的问题
        location / {
            try_files $uri $uri/ /index.html;
        }
        
        //此为proxy 配置地址为API请求地址 proxy /api/ 为正则匹配路由如果匹配到则跳转到后端服务,否则走前段路由
        location ~ /api/ {
            proxy_pass   http://api.xxxxx.com;//此地址为API请求地址
        }
        //此为proxy 配置地址为API请求地址 proxy /upload/ 为正则匹配路由如果匹配到则跳转到后端服务,否则走前段路由
        location ~ /upload/ {
            proxy_pass   http://127.0.0.1:8080;//此地址为API请求地址
        }

        location ~ /\.ht {
            deny all;
        }
    }

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
为提高网站的高并发性能,提高开发效率及运营效率,主要按如下几个思路进行规划设计: 2.1.1负载均衡 1)四层交换负载均衡: 采用负载均衡器来实现硬件级的四层交换负载均衡,或采用LVS来实现软件的四层交换负载均衡。 2)通过第三方软件来实现负载均衡,同时实现页面请求的缓存。 通过Nginx实现反向代理服务器集群,同时搭建squid集群以作为静态页面和图片的缓存。 3)通过web服务器的配置来实现负载均衡 即通过apache或是Nginx 将客户请求均衡的分给tomcat1,tomcat2....去处理。 2.1.2WEB应用开发架构思路 1)应用开发实现MVC架构三层架构进行web应用开发 2)页面尽可能静态化以减少动态数据访问,如果是资讯类的网站可以考虑采用第三方开源的CMS系统来生成静态的内容页面。 3)采用Oscache实现页面缓存,采用Memcached实现数据缓存 4)采用独立的图片服务器集群来实现图片资源的存储及WEB请求 2.1.3数据存储的设计思路 1)数据库拆分,把生产数据库和查询数据库分离,对生产数据库采用RAC实现数据库的集群。 2)采用高效的网络文件共享策略,采用图片服务器来实现页面的图片存储。 2.1.4不同网络用户访问考虑 1)通过引入CDN来解决不同网络服务商的接入速度问题,一般只能解决静态页面的访问问题。 在不同运营商机房部署服务器,通过镜像技术来实现不同网络服务商的接入速度问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值