Nginx+Keepalived主备架构总是会有一台服务器处于空闲状态,这样会造成资源的浪费,所以为了能够将两台服务器都利用起来,我们需要借助Nginx+Keepalived双主架构来实现。即是对外两个VIP地址,同时接收请求。
一:Nginx+keepalived主从,双主架构
1:keepalived原理
Keepalived:是Linux下面实现VRRP备份路由的高可靠性运行件。基于Keepalived设计的服务模式能够真正做到主服务器和备份服务器故障时IP瞬间无缝交接。
VRRP协议:全称 Virtual Router Redundancy Protocol。即虚拟路由冗余协议。可以认为它是实现路由器高可用的容错协议,即将N台提供相同功能的路由器组成一个路由器组(RouterGroup),这个组里面有一个master和多个backup,但在外界看来就像一台一样,构成虚拟路由器,拥有一个虚拟IP(vip,也就是路由器所在局域网内其他机器的默认路由),占有这个IP的master实际负责ARP相应和转发IP数据包,组中的其它路由器作为备份的角色处于待命状态。master会发组播消息,当backup在超时时间内收不到vrrp包时就认为master宕掉了,这时就需要根据VRRP的优先级来选举一个backup当master,保证路由器的高可用。
总结:两台主备机器通过keepalived,虚拟一个IP,也就是VIP(Virtual IP)。VIP开始为主机器所有,备份机为空闲状态,同时在两台keepalived之间通信相当于有一条心跳线,通过心跳线互相通信,只要主机器监控(通过脚本)到ngin服务停止,则主机器自己停止keepalived,将VIP交给备份机器处理web请求,直至主机器再次恢复正常,将VIP返还给主机器。
data:image/s3,"s3://crabby-images/110c3/110c3833af6afbb15ed5f3d9f64ddda39a84740b" alt=""
data:image/s3,"s3://crabby-images/16f49/16f49574393f3c046f14ddc571005a6eaab6d1d7" alt=""
先搭建两个web服务器;
开启同步会话;
data:image/s3,"s3://crabby-images/b75d9/b75d98172c3338db65412a63f99bb3baa9d128b1" alt=""
data:image/s3,"s3://crabby-images/e69d3/e69d330799e4be4ec1b627a667f5b9a296fc339c" alt=""
生成测试文件;
data:image/s3,"s3://crabby-images/3aee3/3aee3a1d829706bda74f59fe54c3de2c2f90eb9a" alt=""
data:image/s3,"s3://crabby-images/977e3/977e3793a5282ecb59c2ee53e86e61f4908ed216" alt=""
然后为了区分,把两台web服务器的端口号进行一个修改;
103:
data:image/s3,"s3://crabby-images/9f02a/9f02a0d7c7216b67b170eb5b29c1df2733f6d9fc" alt=""
104:
data:image/s3,"s3://crabby-images/33827/3382713123c7769e9d0b6056eb0c7aae06b331aa" alt=""
然后保存退出,启动httpd服务;
然后搭建nginx代理服务器;
data:image/s3,"s3://crabby-images/7d946/7d9466faebc594b87a5a3fba6397a1a4e514e7c8" alt=""
这里采用源码包的方式进行安装;
安装nginx所需要的依赖环境;
data:image/s3,"s3://crabby-images/aa1c0/aa1c002a72ccc20f9fd3bbd0737045a194866c99" alt=""
创建程序用户并开始解压;
data:image/s3,"s3://crabby-images/5a402/5a402cb787e5103c989891a60d38b38c68e82603" alt=""
随后cd到解压目录开始安装;
data:image/s3,"s3://crabby-images/b8075/b8075771b5ea254bd9fa1271e81b6df5ffecc2c9" alt=""
编译;
data:image/s3,"s3://crabby-images/54623/54623086d1b9bf710cbe3555bd6ce31f0b8603c8" alt=""
命令优化;
data:image/s3,"s3://crabby-images/efb31/efb31d8d65ba8ca7a047ed3d627a4b63acdf2604" alt=""
data:image/s3,"s3://crabby-images/5ee32/5ee32a1dec2055d9ed1997e288060d0924e85007" alt=""
然后开始设置nginx的代理功能;
data:image/s3,"s3://crabby-images/fb659/fb6596a5931b67c2977020cba2f0566e664e5267" alt=""
先在http单元中指定各个服务器节点;
data:image/s3,"s3://crabby-images/78238/78238e1d2cce6e59cfce7aef2266384ae4ff05e2" alt=""
然后往下翻;再server单元中指定location;
data:image/s3,"s3://crabby-images/05a14/05a1412e21a65b9ccab13b52422fa65f30117eb7" alt=""
保存退出;启动nginx;
data:image/s3,"s3://crabby-images/d2654/d26547e287465f0729cc17d1cb675625a4837c04" alt=""
找一个客户端进行测试;
nginx反向代理的时候会默认采用轮询的方式;
data:image/s3,"s3://crabby-images/1e6a1/1e6a1a8d35f383d23b7eb9ccd05cd953822cdf66" alt=""
且nginx还会检测后端真实服务器的状态;如果此时关闭了一台web服务器,那么就不会把请求发送给后端服务器了;
但是为了高可用环境的需求,要在两个nginx上安装keepalived;如果生产环境中,有一个代理服务器坏掉了,那么还要手动的设置域名和ip的对应关系,且为了服务器的安全隐私问题着想,要把vip给暴露出去,供用户访问;
再开启会话同步功能;安装keepalived搭建高可用;
data:image/s3,"s3://crabby-images/0a990/0a990a235af77cded8d2733a705144f1fec9e8ea" alt=""
data:image/s3,"s3://crabby-images/e9cfe/e9cfe3a87574e20c9c611953430a6344f2593b7c" alt=""
打开配置文件,修改一些参数;
data:image/s3,"s3://crabby-images/8d4e2/8d4e20c2866253eca37a9fab7a751128f5a62b78" alt=""
101:将图片以下的内容全部删除;
data:image/s3,"s3://crabby-images/b4986/b4986683cb49fe93ba52f635ebaa88830794bf17" alt=""
102:将图片以下的内容全部删除;
data:image/s3,"s3://crabby-images/156a1/156a15eccd34dbba5078d487a386aeb2b76d427d" alt=""
然后开启keepalived;并检查vip;
data:image/s3,"s3://crabby-images/5e3d0/5e3d022445c74068798f5e6f63a6388417359d6e" alt=""
客户端使用VIP访问测试;
data:image/s3,"s3://crabby-images/02d64/02d6447af3f819460e3e8e03ada9d89920fbd18a" alt=""
但是重点来了!!!
如果此时关闭nginx服务而不是关闭主机;那么这个架构就崩溃了,用户就访问不到后端服务器了;可以联想vrrp协议的特性;只是检查IP地址的状态;而不是检测服务的状态;
模拟故障;关闭master的nginx服务;
data:image/s3,"s3://crabby-images/635ca/635ca81abca2e4d54b952c0ecb30f5e93189d589" alt=""
再用客户端进行访问;
data:image/s3,"s3://crabby-images/c99fb/c99fbdc9afc3f72a46907e7896a247ac8c06f6c1" alt=""
此时也发现VIP不会进行漂移到另外一台nginx服务器上;
data:image/s3,"s3://crabby-images/ed8c4/ed8c420bf099de2af06cdd38ead0a9e3ee7acca1" alt=""
那么就可以在keepalived的安装目录下写一个脚本,如果检测不到keepalived的工作状态,那么就会关掉master节点的keepalived服务;backup就会上位;
data:image/s3,"s3://crabby-images/26a5e/26a5e8607383b1e2895cdea27f3154015e40bde5" alt=""
大概意思就是检查nginx的pid,如果有,那么返回值就会为0;但是如果不为0就可以判断nginx服务出现了故障;那么就停掉keepalived服务,backup节点就会上位,成为master;
data:image/s3,"s3://crabby-images/95e99/95e99dfeaefb47617e151ed5a75eed23a2a48730" alt=""
并且给这个脚本一个执行权;
data:image/s3,"s3://crabby-images/5135e/5135e5dab4434e4ffe7ca64b0998bd7284e58837" alt=""
然后模拟故障,关掉master的nginx服务,VIP就会漂移到102节点;
data:image/s3,"s3://crabby-images/cfc60/cfc60e5d3b4030a6c541483d88cdf4ec01685e35" alt=""
如果修好了,那么就可以启动nginx服务,并启动keepalived,就会抢占master的角色,随机VIP就会再漂移回来;
data:image/s3,"s3://crabby-images/da7f3/da7f301e87bd975c211f9edd3319cdf14bc88089" alt=""
data:image/s3,"s3://crabby-images/81d5a/81d5a95d1cb3605b01c795046a0c96def2fe4b62" alt=""
data:image/s3,"s3://crabby-images/e394a/e394a64909dfdc4bd45e9cebf9f81aefb65d50c0" alt=""
但是如果把该脚本写到计划任务中,不太恰当,因为计划任务的时间最小单位为1分钟,1分钟后才会检测出nginx节点失效,所以把该脚本放到keepalived的安装目录下,让keepalived进行调用;
首先打开其配置文件;
data:image/s3,"s3://crabby-images/62ec8/62ec87e301ef94f4033bf76f53d9f2fe0a1a5435" alt=""
先指定脚本的位置;及执行间隔时间;
data:image/s3,"s3://crabby-images/a21bf/a21bfdd7b571b75a056e1cb4205ecc9fe2693d34" alt=""
再最后一个括号的上方再写;注意书写位置;
data:image/s3,"s3://crabby-images/a5b11/a5b114c5c6b2b6e41eeb7be6275990e2b774fd82" alt=""
然后在另一个节点上也用同样的方式书写以脚本的方式进行健康检查的策略;
用SSH连接加密传输的方式到另一个节点的目录下;
data:image/s3,"s3://crabby-images/b1d37/b1d3787aa2d20b6dea1eb6924717e669ae55cce2" alt=""
然后再修改第二个节点的主配置文件;102
data:image/s3,"s3://crabby-images/009ed/009edf504de7ae3bdb698d71ff7cfdb1f590d836" alt=""
data:image/s3,"s3://crabby-images/a22d6/a22d66eecd7e940126443a53ee8af815e563a365" alt=""
data:image/s3,"s3://crabby-images/59cc1/59cc1df34882262b44e7c60ef0cecf48c949b0ca" alt=""
然后重启两个keepalived服务;
然后再模拟故障,只关闭nginx 服务,而不是关闭服务器本身;
此时就发现,引用了脚本的方式进行健康检查,就会关闭掉出问题的keepalived;
data:image/s3,"s3://crabby-images/cd7f3/cd7f369e3cdf88064f84efa004a9bc1b86cb1a45" alt=""
data:image/s3,"s3://crabby-images/8e6a7/8e6a723a3bb00095057518eb8678dc4e42a0050e" alt=""
data:image/s3,"s3://crabby-images/03551/03551b98823b0414e7929639d1ece42247d6af62" alt=""
然后修好了,就可以把nginx和keepalived服务启动起来;
还是会继续抢占master的身份;
data:image/s3,"s3://crabby-images/26f9f/26f9f654ba4450749a4dca5fa7b0bd4e3ece2fe9" alt=""
VRRP协议中的Master和Backup设备来回抢占的情况,这种情况会对网络稳定性和性能产生以下影响:
1. 网络振荡
频繁切换:当Master和Backup设备因为优先级变化、网络状态不稳定或其他原因频繁进行主备切换时,会导致网络中出现短暂的振荡。这种振荡可能表现为网络延迟增加、丢包率上升等现象。
路由协议收敛延迟:Master设备在恢复后如果立即抢占,可能会因为其上行链路的路由协议还未完全收敛,导致流量中断或路由错误。
2. 用户体验下降
服务中断:主备设备的频繁切换可能导致用户设备在短时间内无法正确获取到网关地址,从而引发服务中断。
性能下降:网络振荡会直接影响网络的整体性能,导致用户在使用网络时感受到明显的卡顿或延迟。
3. 设备和资源消耗
设备负载增加:频繁的主备切换会增加设备的处理负担,可能导致设备过热、能耗增加等问题。
资源浪费:不必要的抢占和切换会浪费网络资源,包括带宽、CPU和内存等。
缓解措施
为了缓解VRRP协议中来回抢占带来的影响,可以采取以下措施:
配置抢占延时:在Master设备恢复后,配置一定的抢占延时,以便等待其上行链路的路由协议完成收敛,减少流量中断的风险。
优化网络环境:提高网络的稳定性和可靠性,减少因网络堵塞等原因导致的Backup设备无法及时收到Master设备报文的情况。
合理设置优先级:根据设备的性能和稳定性合理设置VRRP优先级,避免因为优先级设置不当导致的频繁切换。
使用BFD等检测技术:通过BFD(Bidirectional Forwarding Detection,双向转发检测)等技术实时监测Master设备的状态,以便在Master设备故障时能够更快地切换到Backup设备。
综上所述,频繁的抢占不见得是一件好事,如何关闭它呢?
如何参考是否开启抢占功能呢?如果两个服务器性能相当,谁当主,谁当从,都可以,但是如果有一台服务器的性能比另外一台性能好,那么就可以设置成master的身份,并且把优先级设置的大一点,且不关闭抢占模式;
打开配置文件;
data:image/s3,"s3://crabby-images/21526/21526d1050e3288752e3d902df9e689dd7b166ac" alt=""
设置两个参数,因为关闭抢占模式仅在backup节点设置的,把两个节点的身份都设置成backup,因为选举master是依靠优先级的;所以不影响;
data:image/s3,"s3://crabby-images/b4611/b4611985d2503a87a3e29c63199999a069f610c2" alt=""
保存退出,然后重启keepalived服务;再去验证就可以了;
nginx双主结构
这种方案,使用两个vip地址,前端使用2台机器,互为主备,同时有两台机器工作,当其中一台机器出现故障,两台机器的请求转移到一台机器负担,非常适合于当前架构环境。
data:image/s3,"s3://crabby-images/5e42c/5e42cdf3a79bfcfe2d46e64646bad6c21a1af78c" alt=""
Nginx双主模式通常指的是两台Nginx服务器相互协作,提供高可用性的负载均衡服务。在这种配置中,两台Nginx服务器都处于活跃状态,并且各自绑定一个公共IP地址(VIP),以便在其中一台服务器出现故障时,另一台服务器能够接管流量,确保服务的连续性和可用性。
性能特点
Nginx本身是一个高性能的Web服务器和反向代理服务器,它以异步事件驱动的方式运行,能够处理大量并发连接,具有低内存消耗和高吞吐量的特点。在双主模式下,Nginx的这些性能优势得以保持,而且通过负载均衡,可以更有效地利用硬件资源,提高整体的服务能力。
高可用性
双主模式通过Keepalived等高可用性软件实现心跳检测和虚拟IP地址的动态管理,确保在任何一台Nginx服务器出现故障时,另一台服务器能够迅速接管服务,实现无缝切换。这种配置可以显著提高系统的可靠性和稳定性,减少单点故障的风险。
经济性
相比于传统的主从模式,双主模式不存在备用服务器资源的浪费问题。在主从模式中,备用服务器在正常情况下不承担流量,而在双主模式中,两台服务器都积极参与服务,提高了资源的利用率。
那么就需要再添加一个实例;
data:image/s3,"s3://crabby-images/27ce8/27ce8805e89f7f52a77463cca20406399a890827" alt=""
将描黑的部分再粘贴一份;
data:image/s3,"s3://crabby-images/a3d2a/a3d2a90a6f00cb7f768fae63686b72f469a5df09" alt=""
data:image/s3,"s3://crabby-images/12c8a/12c8ada0f67c433d74beef9333fc8c7f07020a21" alt=""
进入102修改;
由于上面那个实例是backup,那么这个就要设置成master;且优先级调高一点;
data:image/s3,"s3://crabby-images/33435/334354f8d866e5c1fc2f0912e7dd6fef37939ac6" alt=""
重启两个服务进行测试;
此时101就承载了第一个VIP;192.168.10.100
data:image/s3,"s3://crabby-images/4383c/4383c6635c33bb4f8a2104cea32df8286a7a4ee8" alt=""
102就承载了第二个VIP;192.168.10.200
data:image/s3,"s3://crabby-images/fb7be/fb7be47ec4c9d8cad8a2748ace85e95989e76b04" alt=""
再用客户端使用两个VIP进行测试;
data:image/s3,"s3://crabby-images/cf5b1/cf5b13e8cc6634592a167667b85f560d0668cb1a" alt=""
此时这个架构中任意一个节点出问题,都有对应的backup等待接管;
模拟故障,关闭101的nginx;此时101承载的VIP就漂移到了102上;
data:image/s3,"s3://crabby-images/fa8aa/fa8aa7f8e9bc1939c1b3d989805c804948fb661e" alt=""
data:image/s3,"s3://crabby-images/ad8e5/ad8e54874706ecd02217716501da3d570e003a02" alt=""
一旦修好了,开启两个服务,还是会抢占回来,因为在做双主架构的时候,把原先的配置还原了;
data:image/s3,"s3://crabby-images/31960/31960b6ea6eacc0f2cd4ab13d8c536a7b765b962" alt=""