<返回更多

Nginx正向代理和反向代理什么区别?

2019-06-17    
加入收藏

很多场景下,不得不承认Nginx是个好东西,它给我们的跨系统间的访问、安全性方面等等,带来了极大的便利,况且它的性能也极高。

Nginx是一个异步框架的 Web服务器,可用作正向代理,也可以用作反向代理,负载平衡器 和 HTTP缓存。最近在项目中通过反向代理解决我们一些的问题,今天我们就来聊聊它的反向代理。(内容均整理来源于网络)

Nginx之反向代理,正向代理和反向代理什么区别?

 

什么是反向代理?

反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。

我们换个方式理解,就是当外部网络对内部网络器是不能直接访问的,要通过一个代理服务器才能进行访问,而外部网络看到的只是代理服务器,反馈也是由代理服务器返回的,外部网络对于代理服务器与内部网络直接的具体情况是不可见的。


正向代理和反向代理什么区别?

正向代理是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。客户端才能使用正向代理。

 

这里有一个最显著的区别是:(可以看下面的图示来感受)

 

Nginx之反向代理,正向代理和反向代理什么区别?

 

 

反向代理的好处:

反向代理在Nginx.conf的简单配置

server {
 listen 8182;
 server_name localhost;
 ...
 location / {
 proxy_pass http://localhost:8082; 
 ...
 }
 
 }

server块可以理解为一个虚拟主机,此时我们如果调用的是http://localhost:8182时,会将这个请求转发到http://localhost:8082,因此实际处理这个请求的是http://localhost:8082

使用Nginx后web服务器如何获得真实的用户IP

问题:

当使用Nginx后,web服务器中request.getRemoteAddr(),得到的是Nginx的ip,而不是真实用户的ip

解决方案:

在nginx.conf的的中的location中添加如下一些配置

server {
 ...
 location / {
 ...
 proxy_set_header Host $host;
 proxy_set_header X-real-ip $remote_addr;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 }
 
 }

然后web服务端就可以可以通过request.getHeader("X-Forwarded-For");来获得真实的用户ip。

首先我们要知道什么是X-Forwarded-For?

X-Forwarded-For:简称XFF头,它代表客户端,也就是HTTP的请求端真实的IP,只有在通过了HTTP 代理或者负载均衡服务器时才会添加该项。用于识别通过HTTP代理或负载平衡器原始IP一个连接到Web服务器的客户机地址的非rfc标准,

当Nginx有X-Forwarded-For设置的话,每次经过proxy转发都会有记录,格式就是client1, proxy1,proxy2,以逗号隔开各个地址,而且由于他是非rfc标准,所以默认是没有的,需要强制添加,通过Proxy转达的时候,后端服务器看到的远程ip是Proxy的ip,也就是说如果直接使用request.getHeader("X-Forwarded-For")是获取不到用户ip的,那我们要如何设置获得用户ip呢?

 

此时就需要在nginx配置的location块中添加

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for

注意这里的意思是增加到X-Forwarded-For中,不是覆盖,而增加后的格式就是之前说的“client1,proxy1....”,默认的时候X-Forwarded-For是空的,如果有两个nginx,并且都配置了上面这个命令,则会在web服务器的request.getHeader("X-Forwarded-For")获得的是“用户ip,第一个nginx的ip”,分别对应之前的格式。

proxy_add_forwarded_for包含着两个格式,前面一部分是请求头的X-Forwarded-For,而后面$remote_addr,也就是说是远程用户的ip

 

我们来个图浅显的解释下:

Nginx之反向代理,正向代理和反向代理什么区别?

 

X-real-ip与X-Forwarded-For的区别

最后一跳是正向代理,可能会保留真实客户端IP:X-Real-IP: 1.1.1.1
最后一跳是反向代理,比如Nginx,一般会是与之直接连接的客户端IP:X-Real-IP: 3.3.3.3
X-Forwarded-For:1.1.1.1, 2.2.2.2, 3.3.3.3

声明:本站部分内容来自互联网,如有版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
▍相关推荐
更多资讯 >>>