贴几个反向代理的好文链接?
https://juejin.im/post/5ce6b9c9f265da1b7b31637c
https://juejin.im/post/5bacbd395188255c8d0fd4b2
https://www.cnblogs.com/zengjielin/p/9134623.html
正向代理与反向代理的区别是什么?最简单的理解方式就是看 局域网LAN
客户端client
与代理服务器proxy
处于同一个局域网,就是正向代理
服务器server
与代理服务器proxy
处于同一局域网,就是反向代理
ps: 我们将代理服务器统一称呼为proxy服务器
什么是反向代理?以nginx反向代理服务器为例
反向代理简单理解就是,在客户端client
与服务器server
之间有一台nginx服务器
,并且nginx服务器
与服务器server
处于同一个局域网LAN内
, 客户端client
发送请求到nginx服务器
(此时nginx服务器是所有服务器的任务分配总管,外部客户端client只被允许访问nginx服务器,服务器server对客户端是透明不可见的,也就是说,客户端请求无法直接发送到服务器server上),然后nginx服务器
根据用户配置,以遍历的方式分配nginx服务器
所收集到的请求(均衡的分配)给一台或者多台(负载均衡)服务器
(真正干活的),不让某台或某部分服务器server
因为请求链接量过大导致压力过大崩溃。
什么是正向代理?
比如,我们想要科学上网(fan qiang)
,那就需要在客户端client
与服务器server
之间有一台代理服务器
(这台代理服务器有办法访问到国外的网站资源),客户端client
与代理服务器
(代理服务器就是客户端client的经纪人,事情都由他出面,因此客户端client对服务器server是透明不可见的,服务器不知道是哪台客户端client访问他)处于同一局域网
内,并且客户端client
将请求内容发送给代理服务器
(请注意,这里并不是真正获取服务器server的数据,只是传递请求内容给代理服务器而已),交代代理服务器
帮忙发送一个http请求获取服务器server
资源,获取到资源后,再由代理服务器
转交给客户端client
什么是请求转发?
对于前端开发者来说,肯定会碰到跨域访问限制
,那么请求转发就能实现解决跨域,其原理是绕过客户端浏览器
,不在客户端浏览器
直接对服务器server
发起请求,而是利用其他请求转发服务将请求发送给(真实的)服务器server
。以node.js为例,我们在前端应用中自己用node.js语法
写了一个server.js
,不启动webpack内置的服务器,而是用node server.js命令启动自己定义的node.js服务器
,这时,再写一个proxy配置
,匹配客户端浏览器
发给他的请求url,匹配到了再让node.js服务器
根据预设好的路径发送请求给服务器server
,拿到数据后,再让node.js服务器
返回给客户端浏览器