集群:将很多个机器组织到一起,作为一个整体对外提供服务。集群在扩展性、性能方面都可以做到很灵活。集群的分类:负载均衡集群:Load Balance。高可用集群:High Available。高性能集群:High Performance Computing。
LVS(Linux Virtual Server):Linux虚拟服务器。实现负载均衡集群。
data:image/s3,"s3://crabby-images/c3089/c3089f7765e20ca72ab347fd464ef379812dcae8" alt="79df78b1d3ea4fe8a6b1f8d1333f331c.png"
LVS的工作模式:NAT:网络地址转换。DR:路由模式。TUN:隧道模式。
术语:调度器:LVS服务器。真实服务器Real Server:提供服务的服务器。VIP:虚拟地址,提供给用户访问的地址。DIP:指定地址,LVS服务器上与真实服务器通信的地址。RIP:真实地址,真实服务器的地址。
调度算法共10个,常见的有:轮询rr:Real Server轮流提供服务。加权轮询wrr:根据服务器性能设置权重,权重越大得到的请求越多。最少连接lc:根据Real Server的连接数分配请求。加权最少连接wlc:类似于wrr,根据权重分配请求。
配置LVS的NAT模式:配置4台虚拟机,
data:image/s3,"s3://crabby-images/ca1dd/ca1dd269ca54fa0b4014d38f3de6c3db2d43f78c" alt="01bfc6b0a07b42c782b959f5cffde3ee.png"
data:image/s3,"s3://crabby-images/c3191/c3191fdff01ee58550f3b16e169b2f73be656295" alt="12d48a2e901d406683220a4463938506.png"
第一台为client1,eth0->192.168.88.10,网关为192.168.88.5
第二台为lvs1,eth0->192.168.88.5,eth1->192.168.99.5
第三台为web1,eth0->192.168.99.100,网关为192.168.99.5
第四台为web2,eth0->192.168.99.200,网关为192.168.99.5
关闭所有主机的防火墙
data:image/s3,"s3://crabby-images/6bed3/6bed3b645c6605015cc8f7930ed79048b5b1e502" alt="0b5cdee3667b460a8714d70acab1fafe.png"
查看双网卡机器lvs的内核参数ip_forward双网卡转发是否打开0表示不允许转发数据。sysctl -a:查看全部的内核参数
data:image/s3,"s3://crabby-images/8d1d5/8d1d5bd3beab8aeecff2db1682f0fe1e15277526" alt="1a75073d36294ab9b7a8c2dfe310629d.png"
打开允许转发数据
data:image/s3,"s3://crabby-images/1edc1/1edc1b7d5cb18adb9818f089e9eabb61199380eb" alt="4403d69150cf4b6a893b3c3f7d28f014.png"
data:image/s3,"s3://crabby-images/ae8a1/ae8a1464d6cd3b2b38648c9c95eec62639bcc201" alt="4b7e150c64854f4a991bd2c20f74877c.png"
此时client1主机就能ping通192.168.99.100/200
data:image/s3,"s3://crabby-images/258d3/258d3f9a0bb0d9430a74fe2eebebf4050de11f58" alt="cf037c0499214b968884bf48f7a25f3b.png"
在web1和web2主机上安装http服务并开启该服务。systemctl enable httpd --now:开启服务并设置开机自启动。
data:image/s3,"s3://crabby-images/0a3bf/0a3bf6377e42879c382472646715dd6926fe699e" alt="2188e963b99f4dcbaadb2041ce793420.png"
data:image/s3,"s3://crabby-images/b03ad/b03adb497315a0f9945f545c81959703fe4415fc" alt="6fd593a47cc643949ba4f4458dd89e07.png"
访问^100^200表示把上面命令的100换成200
data:image/s3,"s3://crabby-images/533a8/533a8dfe655b38c021ee7a7796edb20b79451870" alt="378bc2a8522f46bd8bd11550e18daa00.png"
data:image/s3,"s3://crabby-images/d0823/d0823bda647d2c440bb6bf0ea2670e54ba7b7ae7" alt="a554336ff9894e90b4d7ef94e4b86d96.png"
安装LVS的软件包ipvsadm
data:image/s3,"s3://crabby-images/4739e/4739efaf49c3337c59c63b157f8b8ed21ecb5669" alt="f0bf94009af24eafbdc3ba2ccf74471c.png"
ipvsadm命令:-A:添加虚拟服务器。-E:编辑虚拟服务器。-D:删除虚拟服务器。-t:添加tcp服务器。-u:添加udp服务器。-s:指定调度算法,如轮询rr/加权轮询wrr/最少连接lc/加权最少连接wlc。-a:添加虚拟服务器后向虚拟服务器中加入真实服务器。-r:指定真实服务器。-w:设置权重。-m:指定工作模式为NAT。-g:指定工作模式为DR。
添加一个tcp的192.168.88.5:80服务器指定rr调度算法。
data:image/s3,"s3://crabby-images/e8c5d/e8c5da40806d194572b9c326c49908f5fa248bc3" alt="1a2afcbe713d4517a09021fe8f377029.png"
ipvsadm -Ln:查看添加的虚拟服务器
data:image/s3,"s3://crabby-images/dd17d/dd17d5835410904b31b67c969b386311421099d0" alt="85bcd9ad5d1042339c2272813b4eb52c.png"
向虚拟服务器中添加真实服务器,设置权重为1,200为2,工作模式为NAT
data:image/s3,"s3://crabby-images/10cfe/10cfef6fa221c59b3ea65c5bfe021da91c48b80c" alt="87eda6abb19a4e919cd93200554505f8.png"
查看服务器
data:image/s3,"s3://crabby-images/a1e2e/a1e2e3b7cb6af6e6e5b526fbeebcc5641709e9b5" alt="be9259f98fad4da6a87659363ef4c542.png"
在客户端测试,因为设置虚拟服务的调度算法为轮询,所以权重没有起作用。
data:image/s3,"s3://crabby-images/be1fc/be1fcfb2920a9c17fbc6b50d54175f141874e6f4" alt="f8bc373065994b6f9d384698821f052d.png"
修改虚拟服务器的算法为加权轮询。
data:image/s3,"s3://crabby-images/56695/56695ac8f3e7e17487a83db1f73ddfea6bef4393" alt="8017e6aec5aa46f9861829957469b54a.png"
此时使用客户端访问就会出现1:2的比例。
data:image/s3,"s3://crabby-images/149d6/149d667f64e5c37ba4222f29137d4bfaefdc886a" alt="68fd909ac2ce42d59bc5169d33be2be9.png"
配置LVS的DR模式:当用户访问192.168.88.15时被调度器lvs的子接口接收到该访问,然后通过算法由本机网卡地址192.168.88.5向真实服务器的192.168.88.100/200发送命令,然后该服务器通过lo:0子接口192.168.88.15回答客户端的访问。
data:image/s3,"s3://crabby-images/6e29d/6e29d793f4e117581af373934ef439fd7357bc1d" alt="e2af6aac9c024dfcb26984d0ef8bfb2d.png"
data:image/s3,"s3://crabby-images/dd22f/dd22f6be631e683f7cbcabdac3aaedc98921f410" alt="b1a7db6873604cbe8f37085309558e25.png"
LVS主机和web服务器都是单网卡:
client1:eth0->192.168.88.10
lvs1:eth0->192.168.88.5,删除eth1的IP
data:image/s3,"s3://crabby-images/a1536/a1536bfae5c828ae3fe4fe80249fc4a1cdb5f91b" alt="b33e430bab9c4b7895f70b252e83a6e4.png"
web1:eth0->192.168.88.100
web2:eth0->192.168.88.200
删除lvs虚拟服务器的配置
data:image/s3,"s3://crabby-images/7e4ed/7e4ed9e40f51affcc68d1c69f1117271e8a97715" alt="cecf9e100b1640d5b5336fb6a7eba7a8.png"
在lvs主机添加192.168.88.15的VIP地址
vim /etc/sysconfg/network-scripts/ifcfg-eth0:0
data:image/s3,"s3://crabby-images/2ae56/2ae56295d55765c88b4ae041e9ea30f72744383b" alt="2d18f7dc8075482baf6088a0ef45c9ce.png"
修改web1的配置,配置eth0的地址为192.168.88.100
data:image/s3,"s3://crabby-images/6d446/6d4466f6e79e051460b4925745874c02d96bc6ab" alt="2bd9c4bf01e34c8687f73786cd8e45e4.png"
data:image/s3,"s3://crabby-images/eb975/eb97560a21ab395d490f7c0c175fb854d8eea1a7" alt="63a3a62feadd432fbdaea0e61d60868f.png"
修改web2的网卡
data:image/s3,"s3://crabby-images/19497/19497c7d2e67aa33a535e9fa67dd1ac19dfa2e8d" alt="64dffed70fb24057b20e35ec51625ba9.png"
配置web1的loopback网卡的子接口lo:0,虚拟网卡只有它自己所有掩码为32位。
192.168.88.15表示为自己的地址不和其他主机冲突。
data:image/s3,"s3://crabby-images/f7017/f7017806b3c878b7a90586033a33594c857ad840" alt="95f9fc0bc17e42bea933c6ddce05cf65.png"
data:image/s3,"s3://crabby-images/b33bb/b33bb2ef5053887e2ddfcaa9e8899059441094fa" alt="800bd871c4484daab810ad087f7c27a2.png"
然后配置web2
data:image/s3,"s3://crabby-images/879f0/879f02a2ba183c698fdfc44ca471c186b815081c" alt="7f0c758221414803a1646fc05f73528f.png"
在2台web服务器上配置内核参数,使他们不响应对客户端的请求192.168.88.15(由LVS调度)。
sysctl -a
data:image/s3,"s3://crabby-images/c6667/c6667d5964be5802b03fad21377c682aec76e3b9" alt="319c5705551845de87b98dac766e08b3.png"
net.ipv4.conf.all.arp_ignore = 1
net.ipv4.conf.lo.arp_ignore = 1
net.ipv4.conf.all.arp_announce = 2
net.ipv4.conf.lo.arp_announce = 2
data:image/s3,"s3://crabby-images/8006d/8006db531ae16b0a72d386394d3bee471fd984cc" alt="ca8a71fe986b42789bf1508098832a4e.png"
data:image/s3,"s3://crabby-images/abd95/abd95cf066fdccec47ee7b46db568c827a1c14ef" alt="094a8446870a4d94967e23b25bf041a9.png"
data:image/s3,"s3://crabby-images/45fd3/45fd326e6d4c1eebe8cb0843813a1b15b18a9f84" alt="e6c357bbfc3f493da2ab17cc53a6fe40.png"
在lvs主机添加虚拟服务器
data:image/s3,"s3://crabby-images/5b613/5b6134a7614579566ac6706a504d5167b5dad767" alt="abadf86b5c914d4b9fe283fbf3f7ed6c.png"
按ctrl+r进入搜索命令模式,输入for,按左右键
data:image/s3,"s3://crabby-images/62f54/62f54104161cfacf686d1bfdeeadc14905f6d8dc" alt="989e8e53c18542b6aed8d03eeb733b46.png"
此时client主机访问192.168.88.15
data:image/s3,"s3://crabby-images/6b882/6b882f09075396c9fa434a8a67de820cb766e655" alt="01f4f44e83954ae6bead0d9c4d1b06b7.png"
当web1主机出现错误
data:image/s3,"s3://crabby-images/d6070/d6070deedf4c2f159b718531b8914ebfd9348e7e" alt="22bf13f5d3cb468ea6845ad3ea51de85.png"
data:image/s3,"s3://crabby-images/fdbc1/fdbc1285e682ea0391110d8d9a17ffa2487438dc" alt="8696d80f72f3466b94c87c41067d7717.png"
删除该服务器
data:image/s3,"s3://crabby-images/c5be7/c5be739249d514174560840bfabc844e0cf0a71b" alt="2d1e537dfb09410b891896cee106053d.png"
此时只有web2在服务
data:image/s3,"s3://crabby-images/8b3b5/8b3b58ceac8deeae79ee91e6b204bfdec112d8a8" alt="30b019e20b224b05a07b853998b0227c.png"
使用ansible命令来配置LVS服务
在192.168.88.240主机上安装ansible软件包
data:image/s3,"s3://crabby-images/a79da/a79da71f815e1cd73fe1446a8ee919bc7a8b942f" alt="aeaca8f7865f4e9bb947ffcbed39a800.png"
创建工作目录,创建ansible.cfg和inventory主机清单
data:image/s3,"s3://crabby-images/1a68a/1a68acc6a028a47bb7a91660f46c8791028eb443" alt="399b11a54b394043b482efb312472b27.png"
data:image/s3,"s3://crabby-images/30ffa/30ffa5a45903410a93e023e69be406c5016a22b0" alt="57c69814e119440f8d4ba2329867e1ee.png"
配置主机清单
data:image/s3,"s3://crabby-images/66254/662548b09700ed9dbedb68756583f8d59c89a8b0" alt="6fe94e008f4f49178d29483d712b1c5a.png"
因为有主机密钥检查所以连接失败
data:image/s3,"s3://crabby-images/583d8/583d880b333ecb14d5e31c65294b09b7304d5427" alt="5117fc7ec7404dd99d81709916e32d96.png"
不检查主机密钥
data:image/s3,"s3://crabby-images/ddc5f/ddc5f8677e0490516b8ccc17ae81d399f4c98a4d" alt="39642b3ac3c94e9c866bb7241dcbefb3.png"
此时就能ping通了
data:image/s3,"s3://crabby-images/e3973/e39735445522efbf2756f9661f6f7811ad7d98a7" alt="d42c3ccc9c594675bc372bab4a447ded.png"
配置vim。~/.vimrc
data:image/s3,"s3://crabby-images/393c4/393c46ed369fe8dfa177cb37d8c9539c5571d19f" alt="342cf7d990b14d5eba2accefca8faebc.png"
配置web主机上的服务
创建index.html文件
data:image/s3,"s3://crabby-images/e0fbf/e0fbf29c1923257282e8f46970231136fd697894" alt="c6e27df938da4ee0b07fd5cb11fef6d9.png"
data:image/s3,"s3://crabby-images/15b92/15b92db44bdd208c5c8decc27122c20104f07533" alt="8a76d0d1c4fd40e2a5b7ab8e0ac28674.png"
data:image/s3,"s3://crabby-images/b8acc/b8acc7af5156cd78589052f9b04f1fb2b32995b8" alt="f60b82bdc7ff42a1a33bb80bc8fe0855.png"
data:image/s3,"s3://crabby-images/85f1a/85f1acb255f14e569585e214123e78f62236cd63" alt="ac4672ca48a1442fabced57d9310635a.png"
此时修改index.html文件成功
data:image/s3,"s3://crabby-images/5fbb1/5fbb1f73cb25edcb110e577dfbd8547dc62351f2" alt="d5e5962991db4580b312ea51677370bb.png"
网卡eth0:0可以拷贝到一个文件中需要时直接拷贝过去
使用sysctl模块修改内核参数
data:image/s3,"s3://crabby-images/86b99/86b99a131768720e325f449c5780d56bb6b89c09" alt="51fa2b6613d045fb9a22079b959cd9b1.png"
data:image/s3,"s3://crabby-images/8c5e8/8c5e89046c5366e4a2b056809a3979ea8111af88" alt="a58c884ed9dc4285864d0000dedd5d6b.png"
KeepAlived高可用集群:工作原理就是VRRP(虚拟冗余路由协议)。
data:image/s3,"s3://crabby-images/abfc9/abfc9543d3fd42628541ef7c392534248018c2fa" alt="a9dbffc8413144bc94d7aa5408eeaacc.png"
有两个真实服务器一个虚拟服务器,用户服务器访问 虚拟服务器,虚拟服务器把数据转发给其中一个真实服务器,当该服务器出现故障时,虚拟服务器就会把数据转发给另一台完好的服务器。
配置web:web1:eth0->192.168.88.100;web2:eth0->192.168.88.200
配置keepalived在两台web服务器安装keepalived: yum -y install keepalived httpd
data:image/s3,"s3://crabby-images/94238/94238440fd028cf254856a1eaebc11db8e265404" alt="1e260a2d88474c2a8d2b24f71872b8f9.png"
修改配置文件:/etc/keepalived/keepalived.conf
data:image/s3,"s3://crabby-images/672f6/672f6ec9362752cde0d5306ed25cb8b7fc941540" alt="6de813dbe83545d39d1ab907336da7c8.png"
router_id:设置本机在集群中的唯一标识符。
vrrp_iptables:自动配置iptables放行规则
data:image/s3,"s3://crabby-images/97429/97429668f8bfd75f96d70a00c1b0f65167130db1" alt="6572be154b884902a978c1b03f231e10.png"
state:状态主为MASTER备用BACKUP
interface:网卡
virtual_router_id:虚拟路由器地址
priority:优先级
advert_int:发送心跳消息的间隔
auth_type:认证类型为共享密码
auth_pss:集群中的机器密码相同才能成为集群
192.168.88.80/24:VIP地址。
data:image/s3,"s3://crabby-images/2087a/2087a678c8a8ce40924a6dffb33a11392c134f54" alt="8e8f305ec96e4e32b826f6fc0339ffef.png"
启动服务
data:image/s3,"s3://crabby-images/1c4a6/1c4a67ea6f72061f552d4810a61f7bdd9b4957f4" alt="b4c6228ea01b4b7296689d530c75c69f.png"
data:image/s3,"s3://crabby-images/c245c/c245c0cf214cc1d6d5fd56929b87552e149004d5" alt="b8edfdea1af745e8a5a20d0b2c080b8f.png"
当访问192.168.88.80其实就是访问的web1主机
data:image/s3,"s3://crabby-images/1f69b/1f69b07f129cef428740e5760ff04bb585d6702c" alt="99f760fe3039443ab07898e3d22c948b.png"
配置web2
data:image/s3,"s3://crabby-images/27221/272210788006e6f1764ba77b726f380c05df471f" alt="1ea0e37762e84c20a81421b80efb8185.png"
修改标识符web2、状态为BACKUP、优先级为80
data:image/s3,"s3://crabby-images/c70f5/c70f5efffc6e68ce6e90be00029a9f89934553ed" alt="d44b9ff76d8d46189ed5bfae142a937c.png"
data:image/s3,"s3://crabby-images/ad9a4/ad9a4f667de0789b0458f8168732387481904b36" alt="4c2c5610a74f4db498ec3e15320dcb4a.png"
重启
data:image/s3,"s3://crabby-images/ab5d5/ab5d52baa768dd20f2e95d49702d2991537ac97f" alt="524d897ee9a442048181f5656f429f31.png"
因为该设备为备用设备,虚拟IP活跃在主设备中,所以没有192.168.88.80的VIP。
data:image/s3,"s3://crabby-images/b3457/b3457407e857f3d7fe132b80d9de3815e70179b4" alt="c6b14a5a640e4802b97f707065fd7924.png"
搭建高可用、负载均衡的web集群:
client1:eth0->192.168.88.10
lvs1:eth0->192.168.88.5
lvs2:eth0->192.168.88.6
web1:eth0->192.168.88.100
web2:eth0->192.168.88.200
关闭web服务器的keepalived
data:image/s3,"s3://crabby-images/bec75/bec75a5c21222d7c6297456067e36eae7fa7afb5" alt="4127d095ba7d4f959b4449e7732a31d3.png"
data:image/s3,"s3://crabby-images/72430/724300bcfa44f22653c0ba2e5cdb4508267a25f0" alt="c395774005d040f69a4d50982a58f027.png"
在两台web服务器的lo上配置VIP
data:image/s3,"s3://crabby-images/b2832/b28321122bb3a39a09179a699bb6df802edfaf76" alt="63a39ce64091497fa4106394570cd69b.png"
data:image/s3,"s3://crabby-images/dba57/dba57b196448a8752adfbae3fd0f6786e389249e" alt="7835260f3dd9431fac58a94a76c8d9de.png"
在两台web服务器上配置内核参数
data:image/s3,"s3://crabby-images/a80fb/a80fb10447af21b5fcabce73d3196d4bb22c27ad" alt="97ca80c34b2948c885fb41d043630ff6.png"
data:image/s3,"s3://crabby-images/f5650/f565039654d5d560cc7896904966a4dee77038af" alt="4a10dde800fb493783b1e73cf34533c2.png"
删除lvs1的eth0:0,VIP由keepalived接管。
data:image/s3,"s3://crabby-images/d9231/d92316e147d090506f79e27a858d9205552448fe" alt="a605d8acc04c4f538fbff8dd55f32063.png"
删除lvs1的LVS规则。LVS规则由keepalived创建
data:image/s3,"s3://crabby-images/41f30/41f307842e84d47f2b1add3efc98d7556dc664d7" alt="b29612de77884803b2ab130f5cff267d.png"
在两台lvs服务器上安装keepalived和ipvsadm
data:image/s3,"s3://crabby-images/92225/9222537eea923ae27a99242b9e0b92af20bff187" alt="43ecfada77de49cd88f3f5f2e006a701.png"
data:image/s3,"s3://crabby-images/8d02a/8d02ab4353175093806540e30b29df6b005115b1" alt="3ac70fcc18d14f39aacaa3c2da9c98ca.png"
配置lvs服务器的keepalived
data:image/s3,"s3://crabby-images/d9c37/d9c37c8fc0a0c4d3a8d72ae9177c51bcba4b7a37" alt="ef77f95b53bb4fc3912391a082c262e9.png"
data:image/s3,"s3://crabby-images/8c8ea/8c8eabbb7164376bb000c48ee3040477e3bff4c5" alt="d99e71f0ea7b49b7ab2a0b73c6534133.png"
配置LVS规则
virtual_server 192.168.88.16 80:声明虚拟服务器地址和端口号
delay_loop 6:健康检查延迟6秒开始
lb_algo wrr:调度算法为wrr
lb_kind DR:工作模式为DR
persistence_timeout 50:50秒内相同客户端调度到相同服务器
protocol TCP:协议为TCP
real_server 192.168.88.100 80:声明真实服务器
weight 1:权重
TCP_CHECK:通过TCP协议对真实服务器做健康检查
connect_timeout 3:连续超时时间为3秒
nb_get_retry 3:3次访问失败则认为真实服务器故障
delay_before_retry 3:两次检查时间间隔为3秒
data:image/s3,"s3://crabby-images/fac2a/fac2ad3634c296385c41645778a88f0dac1777f2" alt="32c27ccdc7964799af7cd09b53bba488.png"
此时还没有LVS规则
data:image/s3,"s3://crabby-images/4e4c0/4e4c0ea178f4cc26770bf9872559860c08066bf5" alt="71dd737d196847e2ab71984561cb30d9.png"
开启服务
data:image/s3,"s3://crabby-images/3413d/3413dfef32dc39deaa2856bab6eb34c94bc0f02e" alt="683e5c42c9864072bc5a1a9115ec266c.png"
此时就显示LVS规则
data:image/s3,"s3://crabby-images/778c1/778c1aeac3c9306fea3bd6c8157c63f7f0150738" alt="f68c1274fa0b4fcc99b59897d4ff49fe.png"
此时client访问192.168.88.16就能轮询web服务器
data:image/s3,"s3://crabby-images/3b115/3b1151b4bf4b4375a157ce973d7a1a84087717c6" alt="0c12075ab1cf4c26a2348a7b613b12aa.png"
因为设置了persistence_timeout 50:在50秒内访问同一服务器,所以会一直访问web2
data:image/s3,"s3://crabby-images/4e8a3/4e8a3a3a518457c6711ee6088e2967ba6890c521" alt="43deed49689e4105808aa80bff0602c6.png"
data:image/s3,"s3://crabby-images/8cb05/8cb05e9b5ca574bbf5d2cdcd254da6e42c76e2d9" alt="df81e26a10554dec892f25e8eab1b7db.png"
注释该行重启服务,此时就能以权重响应web服务器
data:image/s3,"s3://crabby-images/523f9/523f9a62527bf6df257c418e81052609319bb207" alt="11f51fffa5c34e31b7d5bdd397ae4588.png"
data:image/s3,"s3://crabby-images/01e7f/01e7fc8c0d94493be731bf1309f39ad723a2f1a6" alt="e408cd6a1b0043e5afb1e02b71414836.png"
data:image/s3,"s3://crabby-images/ac6df/ac6df428b4d47f3afd3fd1c0b2d6777a8a2e6c69" alt="7c00ad49b40942c196fdccf74fe4ca22.png"
当关闭web1的http服务
data:image/s3,"s3://crabby-images/a0be7/a0be742fc39fe0a4e8c7a461199a508852ff4f24" alt="69ff2d5e5403437c8455ee10959d3954.png"
此时客户端访问就只有web2在响应了
data:image/s3,"s3://crabby-images/6bcdf/6bcdf6911c994faa7abf96d2db6025a9bd6c01a8" alt="d2c5b0aee9c647dcac64bfbf37fe8176.png"
LVS规则自动更新,把出故障的服务器暂时从LVS规则中去掉。
data:image/s3,"s3://crabby-images/865dc/865dc89eadb34c35f3c0319b2a1fe97e49e3ca4a" alt="3011cedcd07e42f4bd8840298649b9c8.png"
当开启web1服务
data:image/s3,"s3://crabby-images/37d74/37d74890b5eace002a1492aa6d039893913285a1" alt="9f6524463e814c85b49d4291d552d8ab.png"
客户端访问会重新加入web1服务
data:image/s3,"s3://crabby-images/83472/83472053d27da8d789acc2e8d2b4b8c653c70c12" alt="82a65042cd254c67a62c4b2a2869cfeb.png"
LVS规则也会自动更新
data:image/s3,"s3://crabby-images/f442a/f442a21ca98c19c1792007ccaf8d76b838fe6976" alt="de3149508f05418c8c8cd98dbd5e612a.png"
修改lvs2主机的keepalived配置
data:image/s3,"s3://crabby-images/94973/949733a00872b39ed0038450d55c4cf7516ed22a" alt="97e6168075694bd29b26f77a757b966d.png"
data:image/s3,"s3://crabby-images/9fff2/9fff28597308d0abbd341060f8d157dce87131b7" alt="26eb589edff947fbb75649876b8e0684.png"
data:image/s3,"s3://crabby-images/060ed/060ed6f815a4af7dd134e06301e835909e63b0a0" alt="ae64e23d9a0747e2a8ce1ee837dc6d3a.png"
重启服务,
data:image/s3,"s3://crabby-images/dd061/dd061b021dc8bfa45784987e6dd890f77e82953c" alt="70bcf0c7107043e18bbb41795bc92f98.png"
当关闭lvs1的keepalived服务
data:image/s3,"s3://crabby-images/30317/30317cd07f3af98aa9c830df8ff7f6d38ad54c9a" alt="021b8743548f4a51b76f95b2b02cb86c.png"
此时lvs2的VIP就会自动开启
data:image/s3,"s3://crabby-images/0a016/0a0162f92bda5e879d6ffcf843ba275d00c65ef8" alt="a0f803ccc70142769f0226c35f2c5d0d.png"
此时客户端也能正常访问
data:image/s3,"s3://crabby-images/4c6c6/4c6c656bffc67ec2de731496aa66c5146e5464c2" alt="afc80a517e6e49d5baf2f4851dad652a.png"
开启lvs1的keepalived时lvs2的VIP会自动隐藏不启用。
data:image/s3,"s3://crabby-images/0b7a4/0b7a44958155b1d530d2995321eacf068d9f686d" alt="3d412c6bbd7f455096724206f966d0e1.png"
HAProxy:也是一款实现负载均衡的调度器。适用与负载特别大的web站点。(所有web服务器都需要经过haproxy调度服务器)
HAProxy工作模式:
mode http:只适用于web服务
mode tcp:适用与各种服务
mode health:仅做健康检查,很少使用
data:image/s3,"s3://crabby-images/5fb30/5fb30977beadb66224062a18ee64bc31cc103d71" alt="a325faa85ed147ecbcec4ef25331bc90.png"
环境准备:不需要VIP
client1:eth0->192.168.88.10
HAProxy:eth0->192.168.88.5
web1:eth0->192.168.88.100
web2:eth0->192.168.88.200
把lvs1的keepalived和ipvsadm卸载,修改主机名为HAProxy
data:image/s3,"s3://crabby-images/6da6a/6da6a5350f46e11ea33b3f0636757ef3492e402d" alt="dbad58d4ced0450f8a921e4e920f5eba.png"
data:image/s3,"s3://crabby-images/1f1b1/1f1b102a3c2c8eec8ad287944beafee28439f77d" alt="a1461b7542224a8aba37b7fa6740f682.png"
安装haproxy软件包
data:image/s3,"s3://crabby-images/79b3d/79b3d29b6b9d996bfe54237e194c328befb7c7d3" alt="72d86f8502694ab3bcdab2a651d66f9f.png"
修改haproxy配置文件
data:image/s3,"s3://crabby-images/ae262/ae2626834b767329657d6faabce5785f8b9e2271" alt="da86eebfc25d4efdbc457e1ab98c01e3.png"
配置文件中global是全局配置,default是缺省配置,如果后续有和default相同的配置,default配置会被覆盖。
data:image/s3,"s3://crabby-images/0ffe8/0ffe852375b25841690053e5de87093b00536676" alt="27506a8c59ce497491de7631c757bc13.png"
data:image/s3,"s3://crabby-images/758f3/758f371e18c2a41fee882c3d69a53716f1523f4f" alt="5a436ae5c2d8497081380259c5ba928c.png"
配置文件中,frontend描述haproxy怎么和用户交互,backend描述haproxy怎么和后台应用服务器交互,这两个选项一般不单独使用,而是合并到一起,名为listen。
data:image/s3,"s3://crabby-images/9783d/9783df9a73e2f599989499b84335588ffe1000d0" alt="eb6426c7be3c4557995d8c75ab7bfcff.png"
将63以下全部删除,添加listen
listen myweb 0.0.0.0:80:定义虚拟服务器,监听在所有可用地址的80端口
balance roundrobin:定义轮询调度算法
server web1 192.168.88.100 check inter 2000 rise 2 fall 5:对web服务器做健康检查,2秒检查一次,如果连续两次检查成功,认为服务器是健康的,如果连续5次检查失败则认为服务器坏了。
data:image/s3,"s3://crabby-images/0e7c8/0e7c890be32ed98141089ec04700229fd223ea7c" alt="9fcf932402c44034a43a7072c1305cb5.png"
开启haproxy服务
data:image/s3,"s3://crabby-images/2022a/2022a223d8cc0bf1a1dd379f5788115b7e13f179" alt="c6569546dcd445ea95e812eb62a1d06b.png"
查看haproxy的状态
data:image/s3,"s3://crabby-images/5c0e8/5c0e85fdc925e46bd22c9b5fca88e9fa296e9ba9" alt="dd9b576d7cf643c7b2ab028605722133.png"
data:image/s3,"s3://crabby-images/88fc9/88fc9bf16b6acfcde7ae237d6cb1536939b15bff" alt="40ecc7ab5bcc4ab1949229130caf98e6.png"
重新启动服务,此时就能轮询访问web服务器了
data:image/s3,"s3://crabby-images/70e6b/70e6b5bf01fb2312c02b269476527bfb6eb3e9e9" alt="6b5bb59fd5334a59a3dce4cc650b03fc.png"
配置虚拟服务器监听1080端口用来监控haproxy
stats refresh 30s:设置监控页面自动刷新时间为30秒
stats uri /stats:定义监控地址为/stats
stats auth admin:admin:监控页面的用户名和密码都是admin
data:image/s3,"s3://crabby-images/3c474/3c47438a9804ea590a7820a66bef9569ebebd304" alt="103ead0256d949d8905504023e87728f.png"
重启服务
data:image/s3,"s3://crabby-images/d234b/d234bb9337fb89438f51cbf58712f75e3f5edc5c" alt="fe9b4f60b80a4ea5a875b578438a8a99.png"
此时就能访问监控页面,需要登录用户
data:image/s3,"s3://crabby-images/78326/78326a226c07cf2aa06d103edc065606db8557a5" alt="d2c89cdae1c94ebb819c03ca7af2416b.png"
data:image/s3,"s3://crabby-images/c45f0/c45f0fd71d88471da76b6f4952ab60480e3d7cd1" alt="9b34858f5a774ecbb9288e01ff5f9389.png"
web服务器的背景代表着不同的状态
data:image/s3,"s3://crabby-images/a10e4/a10e4c247180b87610d65e1303cd5374e97d6831" alt="16b989d9b9034c0d8da35e110449ec67.png"
Queue:队列长度。Cur当前队列长度;Max最大队列长度;Limit限制长度
Session rate:会话率,每秒钟的会话数
Session:会话数
Bytes:字节数。ln收到的字节数,Out发出的字节数
Denied:拒绝。Req请求,Resp响应
Errors:错误
Warring:警告
Status:状态
LastChk:上一次检查。L4Ok第四层tcp检查通过
Wght:权重
在客户端下载httpd-tools软件包,使用ab命令访问调度器查看其负载状况
data:image/s3,"s3://crabby-images/760eb/760eb4363a3ba24c22f1b2003e907009cf7342d8" alt="268d7abebcb04e079aa3dda825673a49.png"
data:image/s3,"s3://crabby-images/d0bbe/d0bbec9cc515501c1892e66a11f8f9e30465b972" alt="0d656ebeba444a4d98710584b38c96fc.png"
data:image/s3,"s3://crabby-images/2298f/2298f3c61a6e41b3233b75768b1ac715cc58a489" alt="3313a6d143bd4fbd87afd132b45223eb.png"
使用ansible自动化来搭建HAproxy+keepalived集群
修改主机清单
data:image/s3,"s3://crabby-images/ee651/ee6515a8376ea1c20581b2eb54b08fecbc102703" alt="ccc693add4764f4b97d428ebb6e54687.png"
data:image/s3,"s3://crabby-images/d18bf/d18bf7b0f148101fb9a0e89730e078fd66794251" alt="d54aa31d63e045ac9c712a7c6ee0f11a.png"
卸载keepalived和ipvsadm软件包
data:image/s3,"s3://crabby-images/2a2fe/2a2fe8fe0f766630927d62f5778408d0628fe9e6" alt="2cfd562648074c34b02559de4d0aaaff.png"
编辑config-haproxy.yml,安装HAProxy软件包
data:image/s3,"s3://crabby-images/c5261/c526116fabf640e2d0714b077c47c4a2ff2fc978" alt="c747f487763d4f19a83c9c79607e0ce1.png"
将haproxy1的haproxy配置文件拷贝到file目录中
data:image/s3,"s3://crabby-images/bd1cb/bd1cb5632fee43b732c4a9418c155b6890a84ae5" alt="070b4930553e48a89963cf69602e7c79.png"
data:image/s3,"s3://crabby-images/f8c6e/f8c6e858883446d69dc390a038b5ec8a31d609c6" alt="5923d80ab57a496e923725d50e7dcd8c.png"
拷贝haproxy配置文件开启服务
data:image/s3,"s3://crabby-images/ba93b/ba93b6943c147614395ad294b61cf257698a245b" alt="6921a574be2248cda512818710a63f3f.png"
data:image/s3,"s3://crabby-images/c863b/c863b0fcd6ed685342258364930181b8e9f00852" alt="7b08cb346c40499bb9cd10011e6eeb35.png"
查看lvs2
data:image/s3,"s3://crabby-images/492d7/492d718bf86425e3e1dc3ba521f2f954f2e85b56" alt="1cd67f5db0714cf3a319b3d2388cfbf5.png"
此时lvs2调度服务器了
data:image/s3,"s3://crabby-images/99db9/99db9f23c7d9bde43937c527fe1146e364143f04" alt="56b0cdb2cd784f2294ce14a11c21f578.png"
使用ansible配置keepalived的服务
把/etc/keepalived/keepalived.cfg文件拷贝到file目录下面
data:image/s3,"s3://crabby-images/c35af/c35af4aa453153805f30118db5b423228f362f6c" alt="cd64327a7a1a4afaa66a530c058f1044.png"
编辑keepalived.cfg,其余的删除
data:image/s3,"s3://crabby-images/00b76/00b76c023edcbe452fd25b424c8d1a134c153506" alt="9bb374fcad27425abc49c4dbd1c05909.png"
在主机清单中定义变量
data:image/s3,"s3://crabby-images/371b5/371b50f8b9e710d39c0fccebcbfe1bff3d74cf15" alt="ae4123c3ef834aa8905d85acfc88f22f.png"
data:image/s3,"s3://crabby-images/468b0/468b0570d0f7c7a9e832e70b456eb2a014673141" alt="6c9ef40eb9f34767a40b24d3cff297dd.png"
运行该剧本
data:image/s3,"s3://crabby-images/64335/64335c05cd17083ccd6e510b4a1ebb9f43e2d654" alt="69743c42605d4978baf9edaee02161b8.png"
此时haproxy1就成为了mater主设备,lvs2成为了从设备
data:image/s3,"s3://crabby-images/c6039/c60395ad14d7630172e295cc154624a8a0c144e2" alt="09553501520f4eeaa8f8051e62abc889.png"
data:image/s3,"s3://crabby-images/d7ebb/d7ebb23b3438ccd193dbcd8ccb6e86770fccfeba" alt="86024445c8704a8585b0e519da8e2137.png"
data:image/s3,"s3://crabby-images/5a3bd/5a3bdd908bf3ddaae5fbecd6544690de53afdf47" alt="57cfc21833f8458e9984f6601081c54d.png"
负载均衡调度器比较:LVS适用于需要高并发和稳定性的场景;Nginx适用于静态文件服务和反向代理、应用层负载均衡等场景;HAProxy则具备较为丰富的功能和灵活性,适用于多种负载场景。
LVS:
优点:
高性能:LVS使用Linux内核中的IP负载均衡技术,能够实现非常高的并发处理能力。
稳定性:LVS经过长时间的实践应用,成熟稳定被广泛使用。
可用性:支持高可用的配置,可以实现故障自动切换,提供无中断服务。
灵活性:可根据需要采用多种负载均衡算法,如轮询、加强轮询、哈希等。
缺点:
配置复杂:相对于其他两个技术,LVS的配置相对较为复杂,需要更深入的了解和配置
功能相对局限:LVS主要是一种传输层负载均衡技术,无法像Nginx和HAProxy那样对应用层协议进行处理。
Nginx:
优点:
高性能:Nginx采用了基于事件驱动和异步非阻塞架构,能够处理大量并发连接。
负载均衡:Nginx具备内置的负载均衡功能,可以根据配置进行请求的转发。
丰富的功能:Nginx支持反向代理、静态文件服务、缓存、SSL等,在web服务器领域有很广泛的应用。
缺点:
功能相对较少:相对LVS和HAProxy,Nginx在负载均衡算法和健康检查等方面的功能相对较少。
限制于应用层协议:Nginx只能对HTTP和HTTPS等应用层协议进行处理,无法处理其他协议。
HAProxy:
优点:
灵活性:HAProxy支持丰富的负载均衡算法和会话保存方式,可以根据需求进行灵活配置。
完整的功能:HAProxy支持高可用性配置、健康检查、故障恢复、SSL等功能,在负载均衡领域应用广泛。
高性能:HAProxy性能优良,能够处理大量并发连接,并且支持异步IO模型。
缺点:
内存占用:相对于Nginx和LVS,HAProxy在处理大量连接时消耗的内存稍高一些
高可用性:HAProxy需要借助额外的工具来实现高可用性,例如keepalived