网站首页 > 技术教程 正文
很多场景下,不得不承认Nginx是个好东西,它给我们的跨系统间的访问、安全性方面等等,带来了极大的便利,况且它的性能也极高。
Nginx是一个异步框架的 Web服务器,可用作正向代理,也可以用作反向代理,负载平衡器 和 HTTP缓存。最近在项目中通过反向代理解决我们一些的问题,今天我们就来聊聊它的反向代理。(内容均整理来源于网络)
什么是反向代理?
反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。
我们换个方式理解,就是当外部网络对内部网络器是不能直接访问的,要通过一个代理服务器才能进行访问,而外部网络看到的只是代理服务器,反馈也是由代理服务器返回的,外部网络对于代理服务器与内部网络直接的具体情况是不可见的。
正向代理和反向代理什么区别?
正向代理是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。客户端才能使用正向代理。
这里有一个最显著的区别是:(可以看下面的图示来感受)
- 正向代理是客户端知道目的服务器在哪里,然后通过代理服务器去访问客户端不能直接访问的目标服务器,而目标服务器并不知道客户端通过什么来访问的, 即正向代理代理的是客户端 ,最典型的案例就是”翻墙“
- 反向代理中,外部网络对于内部网络具体的情况是不可见的,而代理服务器来代理内部网络来返回所要的数据(当然静态文件可以放在Nginx,这个静动分离再说),而服务端知道请求的来源以及数据,反向代理代理的是服务端 ,典型的例子就是负载均衡。
反向代理的好处:
- 保护了真实的web服务器,web服务器对外不可见,外网只能看到反向代理服务器,而反向代理服务器上并没有真实数据,因此,保证了web服务器的资源安全。
- 反向代理为基础产生了动静资源分离以及负载均衡的方式,减轻web服务器的负担,加速了对网站访问速度(动静资源分离和负载均衡会以后说)。
- 节约了有限的IP地址资源,企业内所有的网站共享一个在internet中注册的IP地址,这些服务器分配私有地址,采用虚拟主机的方式对外提供服务。
反向代理在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。
- proxy_set_header Host $host :把原http请求的Header中的Host字段也放到转发的请求里,$host值为主域名/IP
- proxy_set_header X-real-ip $remote_addr:这里的X-real-ip是一个自定义名,名字随意,效果是可以将 ip 就被放在 X-real-ip 这个变量里了,可以通过request.getHeader("X-real-ip ")获取当前的值,与X-Forwarded-For,下文会详细解释
- proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
首先我们要知道什么是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
我们来个图浅显的解释下:
X-real-ip与X-Forwarded-For的区别
- X-real-ip是覆盖,而X-Forwarded-For是后面添加
- 举个例子,请求由1.1.1.1发出,经过三层代理,第一层是2.2.2.2,第二层是3.3.3.3,而本次请求的来源IP4.4.4.4是第三层代理,
- 而X-Real-IP,没有相关标准,上面的例子,如果配置了X-Read-IP,可能会有两种情况:
最后一跳是正向代理,可能会保留真实客户端IP:X-Real-IP: 1.1.1.1
最后一跳是反向代理,比如Nginx,一般会是与之直接连接的客户端IP:X-Real-IP: 3.3.3.3
- 而X-Forwarded-For的结果则是
X-Forwarded-For:1.1.1.1, 2.2.2.2, 3.3.3.3
所以如果只有一层代理,则两个值是一样的。
猜你喜欢
- 2024-10-11 Nginx、HAProxy、LVS三种负载均衡的区别和特点(附学习资料)
- 2024-10-11 教你如何用 openresty 完美替换 nginx
- 2024-09-19 运维干货-tengine与nginx的区别(nginx vs)
- 2024-09-19 Nginx——正向代理和反向代理的区别
- 2024-09-19 nginx反向代理和负载均衡区别(nginx反向代理和负载均衡区别)
- 2024-09-19 Nginx 原理和架构 | 原力计划(nginx工作原理图)
- 2024-09-19 Gateway和Nginx的区别是什么?#程序员
- 2024-09-19 iis和nginx的区别?(nginx和http的区别)
- 2024-09-19 nginx 和 apache 对比区别(apache2 nginx 对比)
- 2024-09-19 Apache和nginx哪个性能高?(apache2 nginx 对比)
你 发表评论:
欢迎- 最近发表
-
- Linux新手必看:几种方法帮你查看CPU核心数量
- linux基础命令之lscpu命令(linux中ls命令的用法)
- Linux lscpu 命令使用详解(linux常用ls命令)
- 如何查询 Linux 中 CPU 的数量?这几个命令要知道!
- 在linux上怎么查看cpu信息(linux如何查看cpu信息)
- 查看 CPU 的命令和磁盘 IO 的命令
- 如何在CentOS7上改变网卡名(centos怎么改网卡名字)
- 网工必备Linux网络管理命令(网工必备linux网络管理命令是什么)
- Linux 网络命令知多少(linux 网络 命令)
- Linux通过命令行连接wifi的方式(linux命令行连接无线网)
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)
本文暂时没有评论,来添加一个吧(●'◡'●)