1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > 使用keepalived搭建双机热备高可用一览

使用keepalived搭建双机热备高可用一览

时间:2021-10-20 17:33:49

相关推荐

使用keepalived搭建双机热备高可用一览

很多时候大家为了部署高可用方案都是前端配一个 nginx,如果nginx挂掉怎么办,比如下面这张图:

你可以清楚的看到,如果 192.168.2.100 这台机器挂掉了,那么整个集群就下线了,这个问题该怎么解决呢???简单的想想确实不大好处理,因为你的前端请求总得要访问一个ip地址,对吧。。这个问题怎么破呢?

一:问题分析

如果你有一些网络底子的话,就会明白,你给一个不在本网段的机器发送请求的话,这个请求会先经过你的网关IP,然后通过网关IP传给对方的网关IP,然后网关IP会将请求转给它所在局域网的主机,当然我的网关IP和对方的网关IP之间可能有很多跳的路由地址,大概的流程就是下面这样:

如果你不信的话,可以用tracert看看你到的路由总过程。

从上图中可以看到,从我当前主机到 一共有20跳,第一条是192.168.2.1,这个就是我的路由器IP,也就是我的网关IP。

二:虚拟路由冗余协议

好了,说了这么多有什么用呢?其实大家仔细观察这张图,你会想我能不能在网关IP上做一些手脚呢?可喜的是如今的路由器基本上都支持一个叫做VRRP(虚拟路由冗余协议),这一协议的作用你可以理解成把网关IP虚拟化成一个网关IP集群,就好像兽族剑圣的镜像技能,这里面有master,也有slave,然后局域网内的主机设置的都是虚拟的masterIP(VIP),刚好 keepealived 就是一个实现 VRRP 的一款应用程序,你需要,我专业,大家就这样走到一块了。

三:keepalived搭建一览

1. 下载

从官网上找到当前最新的版本1.4.2 /software/keepalived-1.4.2.tar.gz。

配置机器:192.168.23.156 【centos】192.168.23.157 【centos】

[root@localhost app]# wget /software/keepalived-1.4.2.tar.gz---03-10 04:04:06-- /software/keepalived-1.4.2.tar.gzResolving ()... 37.59.63.157, 2001:41d0:8:7a9d::1Connecting to ()|37.59.63.157|:80... connected.HTTP request sent, awaiting response... 200 OKLength: 738096 (721K) [application/x-gzip]Saving to: ‘keepalived-1.4.2.tar.gz’100%[==================================================================>] 738,0965.24KB/s in 4m 44s

2. 然后把相关依赖装起来:yum install -y openssl openssl-devel。

[root@localhost app]# yum install -y openssl openssl-develLoaded plugins: fastestmirror, langpacksCould not retrieve mirrorlist /?release=7&arch=x86_64&repo=os&infra=stock error was14: curl#52 - "Empty reply from server"base | 3.6 kB 00:00:00epel/x86_64/metalink| 7.8 kB 00:00:00Could not retrieve mirrorlist /?release=7&arch=x86_64&repo=extras&infra=stock error was14: curl#52 - "Empty reply from server"extras | 3.4 kB 00:00:00updates | 3.4 kB 00:00:00updates/7/x86_64/primary_db | 6.9 MB 00:01:10

3. 接下来继续解压,最后安装三板斧:./configure --prefix=/usr/app/keepalived && make && make install。

[root@localhost app]# tar -zxvf keepalived-1.4.2.tar.gz[root@localhost app]# lskeepalived-1.4.2 keepalived-1.4.2.tar.gz[root@localhost app]# cd keepalived-1.4.2[root@localhost keepalived-1.4.2]# lsaclocal.m4 bin_install configureCOPYING genhashkeepalivedMakefile.am README.mdar-libChangeLog configure.ac depcomp INSTALLkeepalived.spec.in Makefile.in snapAUTHORcompileCONTRIBUTORS docinstall-sh lib missingTODO[root@localhost keepalived-1.4.2]#[root@localhost keepalived-1.4.2]# ./configure --prefix=/usr/app/keepalived && make && make install

安装好了之后,你就会看到如下的内容,那就恭喜你,安装成功了。

Keepalived configuration------------------------Keepalived version : 1.4.2Compiler : gccPreprocessor flags : Compiler flags : -Wall -Wunused -Wstrict-prototypes -Wextra -g -O2 -fPIE -D_GNU_SOURCELinker flags : -pieExtra Lib: -lcrypto -lssl Use IPVS Framework : YesIPVS use libnl : NoIPVS syncd attributes : NoIPVS 64 bit stats : Nofwmark socket support : YesUse VRRP Framework : YesUse VRRP VMAC : YesUse VRRP authentication : YesWith ip rules/routes: YesSNMP vrrp support : NoBuild genhash : YesBuild documentation: No

4. 接下来我们改一下配置文件

安装好了之后,在/usr/app/keepalived/etc/keepalived 目录下有一个 keepalived.conf文件,现在你要做的事情就是将它copy到/etc/keepalived文件夹下,然后在192.168.23.156机器中的配置文件,修改如下:

global_defs {notification_email {acassen@firewall.locfailover@firewall.locsysadmin@firewall.loc}notification_email_from Alexandre.Cassen@firewall.locsmtp_server 192.168.200.1smtp_connect_timeout 30router_id NodeAvrrp_skip_check_adv_addrvrrp_strictvrrp_garp_interval 0vrrp_gna_interval 0}vrrp_instance VI_1 {state MASTERinterface ens33virtual_router_id 51priority 150advert_int 1authentication {auth_type PASSauth_pass 1111}virtual_ipaddress {192.168.2.200}}

其中要注意的就是:

<1> priority 150

节点的优先级,master要比slave高。

<2> interface ens33

ens33大家可以通过ipconfig查看一下自己的网卡。

[root@localhost ~]# ifconfigens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500inet 192.168.23.157 netmask 255.255.255.0 broadcast 192.168.23.255inet6 fe80::20c:29ff:fe54:4f5a prefixlen 64 scopeid 0x20<link>ether 00:0c:29:54:4f:5a txqueuelen 1000 (Ethernet)RX packets 10899 bytes 11349012 (10.8 MiB)RX errors 0 dropped 0 overruns 0 frame 0TX packets 5575 bytes 599717 (585.6 KiB)TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536inet 127.0.0.1 netmask 255.0.0.0inet6 ::1 prefixlen 128 scopeid 0x10<host>loop txqueuelen 0 (Local Loopback)RX packets 4 bytes 340 (340.0 B)RX errors 0 dropped 0 overruns 0 frame 0TX packets 4 bytes 340 (340.0 B)TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

<3> virtual_ipaddress 192.168.23.200

设置好虚拟IP(VIP)为:192.168.23.200, 同样的道理,在 192.168.23.157 设置如下:

global_defs {notification_email {acassen@firewall.locfailover@firewall.locsysadmin@firewall.loc} notification_email_from Alexandre.Cassen@firewall.locsmtp_server 192.168.200.1smtp_connect_timeout 30router_id NodeBvrrp_skip_check_adv_addrvrrp_strictvrrp_garp_interval 0vrrp_gna_interval 0} vrrp_instance VI_1 {state BACKUPinterface ens33virtual_router_id 51priority 100advert_int 1authentication {auth_type PASSauth_pass 1111} virtual_ipaddress {192.168.23.200}}

6. 接下来就可以启动keepalived了。

[root@localhost sbin]# ./keepalived -D[root@localhost sbin]# ps -ef | grep keepalivedroot 46611 0 05:41 ? 00:00:00 ./keepalived -Droot 4662 4661 0 05:41 ? 00:00:00 ./keepalived -Droot 4663 4661 0 05:41 ? 00:00:00 ./keepalived -Droot 4673 4300 0 05:41 pts/0 00:00:00 grep --color=auto keepalived

五:检测

通过ip a 看看当前 ens33 网卡上是否绑定了 192.168.23.200 虚拟IP。

然后通过 arp -a 查看当前的vip映射到的物理(mac)地址,可以看到当前的vip映射到的是 192.168.23.156 上面。

C:\Users\hxc>arp -a接口: 192.168.23.1 --- 0x6Internet 地址 物理地址 类型192.168.23.156 00-0c-29-75-7e-20动态192.168.23.157 00-0c-29-54-4f-5a动态192.168.23.200 00-0c-29-75-7e-20动态192.168.23.255 ff-ff-ff-ff-ff-ff静态224.0.0.22 01-00-5e-00-00-16静态224.0.0.251 01-00-5e-00-00-fb静态224.0.0.252 01-00-5e-00-00-fc静态239.11.20.1 01-00-5e-0b-14-01静态239.255.255.250 01-00-5e-7f-ff-fa静态255.255.255.255 ff-ff-ff-ff-ff-ff静态

然后我们把156这台机器关闭了,可以看到当前的vip已经漂移到了157这台机器上了。

C:\Users\hxc>arp -a接口: 192.168.23.1 --- 0x6Internet 地址 物理地址 类型192.168.23.156 00-0c-29-75-7e-20动态192.168.23.157 00-0c-29-54-4f-5a动态192.168.23.200 00-0c-29-54-4f-5a动态192.168.23.255 ff-ff-ff-ff-ff-ff静态224.0.0.22 01-00-5e-00-00-16静态224.0.0.251 01-00-5e-00-00-fb静态224.0.0.252 01-00-5e-00-00-fc静态239.11.20.1 01-00-5e-0b-14-01静态239.255.255.250 01-00-5e-7f-ff-fa静态255.255.255.255 ff-ff-ff-ff-ff-ff静态

好了,这个就是本篇所说的所有内容,希望对您有帮助。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。