data:image/s3,"s3://crabby-images/00652/006522762dfd0d4fa7bc0b0d189bd4cbbe3a5ac6" alt=""
正常情况下,客户端去访问代理服务器,然后代理服务器再取访问真实服务器,在真实服务器上,只能显示代理服务器的ip地址,而不显示客户端的ip地址,如果想让客户端的ip地址也能在真实服务端看见,这一技术叫做IP透传
$http_x_forwarded_for:这个变量我们要赋值给它,并且会一直保留,每次都会追加
可以在主配置文件里面的日志文件里面看见这一选项
data:image/s3,"s3://crabby-images/2d992/2d992b284c094606da58491f03d787d541131534" alt=""
data:image/s3,"s3://crabby-images/533cf/533cf1b128ef5a845dede961fae6d26ef838f7a2" alt=""
#proxy_set_header X-Real-IP $remote_addr; #只添加客户端IP到请求报文头部,转发至后端服务器
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; #添加客户端IP和反向代理服务器IP到请求报文头部
如果有一个代理服务器,可以写第一个
如果有多个代理服务器,则下面的
如果既想看见客户端ip又想看见代理服务器 就添加第二行
在真实服务端的日制中查看,是看不见客户端或者代理服务器端的ip的
data:image/s3,"s3://crabby-images/095f6/095f66f112897ab102ae8647e41d851777614176" alt=""
如果想看见真实访问的ip地址,就是客户端跟代理服务端的ip时 看以下操作
单机IP透传
在代理服务端(7-1) (nginx系统)
在子配置文件里面配置内容 X-Forwarded-For 这是一个变量
7-2真实服务器上(httpd系统)
用set list 可以查看时在196行(set nu可以看到多少行),然后进行添加 (只需要将次变量加入即可)
X-Forwarded-For
data:image/s3,"s3://crabby-images/193e9/193e938324b9139ccd400f1eb1e567fd81f4f55c" alt=""
data:image/s3,"s3://crabby-images/b4ab4/b4ab42f914d93e4f7ac7dfc65aad8e544425200a" alt=""
然后重启
data:image/s3,"s3://crabby-images/1d837/1d837f798c94ec41f30f03da9641677e3a46a32d" alt=""
然后再用另外一台客户端(7-3)去curl192.168.68.3的代理服务器
data:image/s3,"s3://crabby-images/e9705/e9705bd646213d5fe0849fcef52e5ba3435842de" alt=""
此时 再去7-2查看日志
data:image/s3,"s3://crabby-images/f4031/f4031e0be22d33b151b983fd08b34fd5074b6fd4" alt=""
data:image/s3,"s3://crabby-images/f6fc5/f6fc5c919c9fc0b29b4c2963cbfcb6584b50ab9c" alt=""
多机IP透传 (把所有机器换成nginx,都是nginx系统)
在每个代理服务器上面都要设置:proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; #添加客户端IP和反向代理服务器IP到请求报文头部
data:image/s3,"s3://crabby-images/25136/251366c75a99eafa331543196129d7f1afb463c1" alt=""
在nginx中,变量 X-Forwarded-For已经写好了,都写在日志文件中了 只需要在每个代理服务端的配置文件中写入proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for即可
data:image/s3,"s3://crabby-images/a6ffa/a6ffac7071e1a1ea98a5a93cdd77120e9306eac0" alt=""
代理服务器1:192.168.68.3
代理服务器2:192.168.68.4
真实服务器:192.168.68.5
(访问代理服务器1 就跳转到代理服务器2 访问代理服务2 就跳转到真是服务器)
代理服务器1配置:
data:image/s3,"s3://crabby-images/33d18/33d1890df38a422c5c8127e96ab89858814d04c3" alt=""
代理服务器二配置:
data:image/s3,"s3://crabby-images/485c2/485c26749ac25e4ef654690b4a06a36ec5728d39" alt=""
随后,重载
data:image/s3,"s3://crabby-images/a92cb/a92cbe7541c1b2aade8b5389e1d7185754f32383" alt=""
真实服务器 (7-3)
首先关闭防火墙
其次yum 安装nginx
yum install -y epel-release
yum install nginx -y
然后开启服务器nginx
data:image/s3,"s3://crabby-images/02c97/02c97bdbc0d3708d76b21e865111858c16d99ee0" alt=""
yum安装的nginx的主页面 在/usr/share/nginx/html中
data:image/s3,"s3://crabby-images/32fc5/32fc5212dcc858468e167a23e95e946bcb469be4" alt=""
然后在代理服务器curl 192.168.68.3自己
data:image/s3,"s3://crabby-images/35708/35708619486a97936dd770a59e6d5a5e8f98ac7f" alt=""
最后,在真是服务器上面查看日志,会出现代理ip 跟客户端ip
data:image/s3,"s3://crabby-images/124a2/124a277d6ec9899f7a06c48e40fd86e9017c79a2" alt=""
http反向代理负载均衡 upstream
data:image/s3,"s3://crabby-images/9a07b/9a07b51b4a6db40a7898a245e06dd345e16468a7" alt=""
data:image/s3,"s3://crabby-images/e52f0/e52f09ae68d29bcca765520fef704b0fa5dd4ff3" alt=""
upstream 在http模块里面
调度算法:
data:image/s3,"s3://crabby-images/1fe83/1fe83a7470a7a04c7f39358394b247109be7d8da" alt=""
代理服务器:192.168.68.3
真实服务器1:192.168.68.4
真是服务器2::192.168.68.5
代理服务器 :
修改主配置文件
加入服务器组
data:image/s3,"s3://crabby-images/9bc24/9bc2437823c6f20932081580b720523b1ae91c17" alt=""
然后将子配置文件注释掉,如果不注释,不能进行下面的location操作
data:image/s3,"s3://crabby-images/bd42c/bd42c4923b488361cdf114b88aadc351ee5a5a4d" alt=""
随后,在location里面修改
data:image/s3,"s3://crabby-images/dba12/dba120d590f50c4223e1e8a1b1f3cffacb8b3712" alt=""
随后保存并退出
data:image/s3,"s3://crabby-images/9ffca/9ffca6d4272d977b2e0e358cf73b8aa1b0c42a95" alt=""
真实服务器1:
data:image/s3,"s3://crabby-images/3f230/3f2300f7b524c2ff1d9275fe56aefd0979dde6fc" alt=""
真实服务器2
data:image/s3,"s3://crabby-images/85237/85237bb0f567c82720a878ba44b160130b0c9639" alt=""
随后,在代理服务器服务器上curl
一会7-2 一会7-3
data:image/s3,"s3://crabby-images/7ff2d/7ff2da67cc4b62f8e4181d50e1efe04bdc86d1ed" alt=""
以上为轮询算法(nginx默认),一人一次的意思
nginx有检测机制,如果有一台服务器挂掉,nginx只会去访问正常的那一台 (健康性检查)
举例说明:
当7-3 服务器挂了,nginx只能去访问7-2
data:image/s3,"s3://crabby-images/6eba7/6eba7589c14af5582e57371161cf2c9070ebe8c3" alt=""
data:image/s3,"s3://crabby-images/1d4c1/1d4c1b79a2c124eac1c2b0c67836ee3c86429434" alt=""
然后再去代理服务器上面curl
data:image/s3,"s3://crabby-images/174ab/174abd7edeac64d9614448ae5b849f1e1eb4e542" alt=""
验证成功 ,只能去健康的服务器访问
data:image/s3,"s3://crabby-images/f5de4/f5de454445da6aefa98cb8ad512d13a687f6b4b1" alt=""
去关闭的那台真实服务器上查看
此时只有I个包,正常情况下,tcp三次握手最少应该有6个包 所以这边失败
data:image/s3,"s3://crabby-images/e530e/e530e91a87d7ec8e04c872cabc6ad2d4fe75fd15" alt=""
加权轮询 weight
data:image/s3,"s3://crabby-images/ca692/ca6922dae0a8f4b82ab7218bb4c07d29d2b4ba10" alt=""
weight:5 意思为上面分5次 下面没写,默认一次
实例:
在代理服务器(192.168.68.3)上的主配置文件里面修改
data:image/s3,"s3://crabby-images/2ea12/2ea12c1c8c55a373fd131907aede7f69966ab5b0" alt=""
随后,保存重载 然后在curl
可以看出192.168.68.4 出现3次 192.168.68.5出现一次
data:image/s3,"s3://crabby-images/f8791/f879130eaa36dd2ce37afbc3e1e42e2f61de5138" alt=""
data:image/s3,"s3://crabby-images/a54d9/a54d90ee25742f022cc9b89043cd64e460785233" alt=""
#server支持的parameters如下:
weight=number #设置权重,默认为1,实现类似于LVS中的WRR,WLC等
max_conns=number #给当前后端server设置最大活动链接数,默认为0表示没有限制
max_fails=number #后端服务器的下线条件,当客户端访问时,对本次调度选中的后端服务器连续进行检测多少次,如果都失败就标记为不可用,默认为1次,当客户端访问时,才会利用TCP触发对探测后端服务器健康性检查,而非周期性的探测
fail_timeout=time #后端服务器的上线条件,对已经检测到处于不可用的后端服务器,每隔此时间间隔再次进行检测是否恢复可用,如果发现可用,则将后端服务器参与调度,默认为10秒
backup #设置为备份服务器,当所有后端服务器不可用时,才会启用此备用服务器 sorry server 自己不能转自己
down #标记为down状态
resolve #当server定义的是主机名的时候,当A记录发生变化会自动应用新IP而不用重启Nginx
max_fails 表示链接次数,当检验计算机是否挂掉,max_fails=3 就表示尝试tcp连接次计算机三次 ,如果不行就认为挂掉
fail_timeout :如果检测到计算机还活着,等个多少秒再上线
backup:备份服务器,当前面几台服务器都挂掉的时候,可以使用备份服务器
演示备份服务器流程:
在第一台服务器7-1 主配置文件里面修改
data:image/s3,"s3://crabby-images/70e16/70e16773c39194ccbedbed01ce96c486245b5a99" alt=""
第二步在备份服务器上面下载nginx
data:image/s3,"s3://crabby-images/57ee3/57ee3cf34bb9e98f871c3286a250767a16da91f0" alt=""
data:image/s3,"s3://crabby-images/d3391/d3391ee0e4216df41d55e92fd727b0b43a375856" alt=""
data:image/s3,"s3://crabby-images/b59bd/b59bdc3fd259bfd478b7c69f00ebf04c390ced06" alt=""
模拟192.168.68.4 跟192.168.68.5 损坏 就是将其nginx关掉
data:image/s3,"s3://crabby-images/bede2/bede2345d7399792bd479b0f356ab50b95c178b0" alt=""
随后,再次进入到7-1 curl自己 会出现备份服务器上的网页
data:image/s3,"s3://crabby-images/7f224/7f224303bff0456116038dad76b0a58ddcab641e" alt=""
hash算法
hash的作用:保持会话一致
什么是会话?
data:image/s3,"s3://crabby-images/08687/0868724b5056dd00240d08bc2644f65486fd3992" alt=""
ip hash 根据ip地址,然后得出一个值 这样就会永久保持会话。第一次访问1服务器 就永久访问1服务器
url hash 根据url 然后得出一个值 这样就会永久保持会话
ip hash实例:在7-1 代理服务上操作
data:image/s3,"s3://crabby-images/e23ab/e23ab244beb46a60f0ab442cff6e2263e68b6fdc" alt=""
因为第一次被curl到7-2上,所以一辈子都在7-2上
data:image/s3,"s3://crabby-images/372cd/372cdafd96386f6e435da674d9695206628e362a" alt=""
hash有个致命缺点,就是跟权重相关 例如权重是2,则hash/2 hash/(除以)总权重,所以会使用路径hash (url hash)
url hash
hash $requst_uri
在7-1 代理服务器主配置文件里面修改
data:image/s3,"s3://crabby-images/b31df/b31df85162057b88033d659337d3316775e40150" alt=""
然后再通过服务器7-1 去curl
data:image/s3,"s3://crabby-images/53d0b/53d0b2f39a53622c9716c052ab8344d7b1dddd15" alt=""
cookie hash 缓存hash
data:image/s3,"s3://crabby-images/f2ecb/f2ecbde81aa0fc8a5436883178a9cc41e56f7716" alt=""
案例根据cookic里面的关键字去查找
在7-1 代理服务器上主配置文件里面修改
然后重启
data:image/s3,"s3://crabby-images/c7b93/c7b9341779ba17354e9f24236bb8744b9e932152" alt=""
随后去curl
data:image/s3,"s3://crabby-images/b7b7d/b7b7db26818ad5caab5d119b0a915e4d93eae47c" alt=""
fair
根据响应时间来分配,响应时间短的优先分配