几个月前,公司架构优化,首先就是前后端分离。

所谓前后端分离,就是在传统的前后端代码都在一个项目里的基础上,将前后端代码抽离,把前端代码从后端项目了分离出来,前后端开发人员各自在自己的项目里开发。

为什么要前后端分离?

随着项目越做越大,功能模块越来越多,代码量越来越多,前后端代码都糅杂在一个项目里,前后端开发人员几十个,代码提交次数多而杂,项目变得很臃肿,代码维护人员的工作变得难做,此时亟待解决此问题,把前后端代码分离成两个项目,前后端开发人员各自维护自己的项目,使项目轻量化,便于维护。

前后端分离后带来的问题有哪些呢?

1、跨域。前后端分离后,势必各自部署,那么前后端就会存在跨域的问题。

2、前端项目部署方式。前后端各自部署,后端好说,继续用原来的方式部署就行了,前端怎么部署?

3、前后端怎么联调?

带着这3个问题,自然而然的就想到使用nginx做反向代理。

nginx [engine x]是一个HTTP和反向代理服务器,一个邮件代理服务器和一个通用的TCP / UDP代理服务器

我们线上用的是 Nginx ,分离后我们本地开发时有很多同事,还是使用原来的老方式, 把前端代码复制到项目里跑,这样太笨重。所以我就自己研究了一下 nginx ,配置好打好包分享给其他同事,在公司同事间推广。

nginx做前后端分离具体怎么使用的呢?下面来说一下。

首先我们在Windows上搞好,下载nginx,官网[http://nginx.org/](http://nginx.org/),

打开后可以看到目前最新版本是1.17.2

找一个版本下载后放到自己喜欢的目录解压就行了。

然后打开解压后的目录,找到conf目录进去找到nginx.conf文件,文本方式打开。

这个就是nginx的配置文件,我们需要修改这个文件,以适用于我们的需要。

这里只截取了配置文件的一部分,这部分是关键。

解释一下,在http模块里,有两个子模块,upstream  和 server 。

upstream 模块配置的是服务端的(集群)地址,eroly_server 是 upstream 的名称,server 是服务器地址,后跟服务的ip:port,可以写多个,也就是服务器集群地址。

server 模块相当于使用Nginx做静态服务器,配置静态资源的一些信息,使其能够被外部访问。listen 是监听的端口,server_name 是服务器ip,location 模块主要配置资源的地址 location 后面跟的是一个正则表达式表示符合此正则的请求被路由到该模块配置的资源地址。可以配置多个。其中,location 模块中的 root 这里我配置的静态资源的地址,当请求包含 /eroly/(我的项目根地址)时其实访问的是我本地 D盘下的 eroly_static 目录下的对应的文件。例如访问http://localhost/eroly/login/index.html时,其实 nginx 会根据配置信息 从上到下去匹配你配置的 location ,此时将会匹配到 location /eroly/ 这个,那么其实真正访问的是 D:/eroly_static/eroly/login/index.html。

root 下面一行被注释掉的是什么意思?rewrite 表示重定向,假如此时我的D盘eroly_static目录下没有 eroly 这一层,就直接是 D:/eroly_static/login/index.html 少一层目录(可能前端项目没有这个目录,所以从版本管理工具上下载下来就没有。但是后端服务根目录是这个,前端访问的时候需要加上,如果手动添加的话,很麻烦又不能提交,所以用这个指令就很好的解决了这个尴尬的问题),我们就可以用这个指令配合 root 使用。

至于下面这个location 配置的就是服务端的了,假如服务端接口都是 /eroly/api/开头的,那么前端访问后端接口时,就会走这个location ,关键的是 proxy_pass 这个属性,你看后面跟的是 http://eroly_server/ 就是 upstream 的名字。其他字段的含义这里不多说了,可以自行了解。

http {
upstream eroly_server{
server localhost:8080;
}
server {
listen 8091;
server_name localhost; #static
location /eroly/ {
root D:/eroly_static;
#rewrite ^/eroly/(.*?)$ /$1 break;
}
#server
location /eroly/api {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_set_header X-NginX-Proxy true;
proxy_pass http://eroly_server/;
proxy_redirect off;
}
}
}

这里只是简单的介绍下 Nginx 用于前后端分离,作为前端部署服务器的简单用法,实际 Nginx 的应用非常强大。

Nginx之前后端分离(入门)的更多相关文章

  1. 谈谈渲染,玩玩nginx——前后端分离,转发请求到Tomcat的尝试

    一.谈谈"渲染" 相信好多人都挺听过"渲染"这个词,但不清楚它是什么意思?前端开发以为这是后端的活儿,后端开发以为是前端的事儿,推着推着就不了了之.其实渲染很简 ...

  2. nginx 前后端分离 代理转发,解决跨域问题

    场景 适用于公司有前端,项目采用前后端分离.类似于我们 后端 springboot 提供接口,前端专门写html调用相应的接口,解决跨域问题 配置说明 worker_processes 1; even ...

  3. SpringBoot 和Vue前后端分离入门教程(附源码)

    作者:梁小生0101 juejin.im/post/5c622fb5e51d457f9f2c2381 推荐阅读(点击即可跳转阅读) 1. SpringBoot内容聚合 2. 面试题内容聚合 3. 设计 ...

  4. Nginx 前后端分离配置 分发

    前端项目VUE  端口8081 , 后端项目JAVA 端口8080 # For more information on configuration, see: # * Official English ...

  5. web 部署专题(九):Nginx 前后端分离中csrf_token 认证的实现

    1. 思路 参考:https://stackoverflow.com/questions/20826201/simple-csrf-protection-using-nginx-alone?r=Sea ...

  6. springboot+vue脚手架使用nginx前后端分离

    1.vue配置 /** * * 相对于该配置的nginx服务器请参考nginx配置文件 * */ module.exports = { // 基本路径 publicPath: '/', // 输出文件 ...

  7. nginx前后端分离路由配置

    参考链接: https://blog.csdn.net/qq_30021219/article/details/80901199

  8. 一个Java程序猿眼中的前后端分离以及Vue.js入门

    松哥的书里边,其实有涉及到 Vue,但是并没有详细说过,原因很简单,Vue 的资料都是中文的,把 Vue.js 官网的资料从头到尾浏览一遍该懂的基本就懂了,个人感觉这个是最好的 Vue.js 学习资料 ...

  9. 使用 Nginx 部署前后端分离项目,解决跨域问题

    前后端分离这个问题其实松哥和大家聊过很多了,上周松哥把自己的两个开源项目部署在服务器上以帮助大家可以快速在线预览(喜大普奔,两个开源的 Spring Boot + Vue 前后端分离项目可以在线体验了 ...

随机推荐

  1. [译]Vulkan教程(03)开发环境

    [译]Vulkan教程(03)开发环境 这是我翻译(https://vulkan-tutorial.com)上的Vulkan教程的第3篇. In this chapter we'll set up y ...

  2. Java,该学什么?

    本人大学学的是生物技术专业,毕业后入坑Java. 最近有人问我是如何转行的,需要学一些什么.我在网上看到一篇帖子,觉得写得很全.如果是我来写,可能还写不了这么全的.在此分享给网友. 2019秋招几个月 ...

  3. MySQL 在 Windows 下安装教程、避坑指南

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,2008 年被 SUN 公司收购,后 SUN 公司又被 Oracle 公司收购. 一.下载 MySQL 官网 https:/ ...

  4. C++入门到理解之文件操作(文本文件的读写+二进制文件的读写)

    原文地址http://www.javayihao.top/detail/168 一:概述 1.程序在运行中产生的数据都是临时数据,程序一旦运行结束会被释放,可以通过文件相关的操作将数据持久保存. 2. ...

  5. Python 从入门到进阶之路(三)

    在之前的文章我们介绍了一下 Python 中 if while for 的使用,本章我们来看一下 Python 中的变量类型. 在 Python 定义变量时的规则是 变量名 = 变量 ,Python ...

  6. TypeScript 装饰器的执行原理

    装饰器本质上提供了对被装饰对象 Property​ Descriptor 的操作,在运行时被调用. 因为对于同一对象来说,可同时运用多个装饰器,然后装饰器中又可对被装饰对象进行任意的修改甚至是替换掉实 ...

  7. Windows7中启动Mysql服务时提示:拒绝访问的一种解决方式

    场景 在Windows7中打开任务管理器--服务下 找到mysql的服务点击启动时提示: 拒绝访问 这是因为权限不够导致的不能启动sql服务. 点击 任务管理器右下角的服务 在这里就可以正常启动服务

  8. SAP depreciation key config

    正常折旧 Configure 1.分配总帐科目 spro进入后台配置 –> Financial Accounting(New) –> Asset Accounting –> Depr ...

  9. ABP入门教程15 - 小结

    点这里进入ABP入门教程目录 效果预览 至此,ABP入门教程的CURD(增删改查)示例已完成,效果如下 登录 首页 查询课程 新增课程 修改课程 删除课程 阶段总结 关键步骤: 领域层创建实体基础设施 ...

  10. Pyhton 连接数据库

    Python连接MySql 步骤 开始 创建connection 获取cursor 操作过程 SQL语句 执行查询 执行命令 获取数据 处理数据 关闭游标:cursor.close() 关闭连接:co ...