keepalived-1.4.2实践:安装与测试

一、下载安装

http://www.keepalived.org/software/keepalived-1.4.2.tar.gz

1、操作系统:CentOS 7.4,先确保安装了openssl,安装方法:

 yum -y install openssl-devel

没有OpenSSL的话,configure会报错:

 !!! OpenSSL is not properly installed on your system. !!!

  !!! Can not include OpenSSL headers files. 

2、解压编译

tar -zxf keepalived-1.4.2.tar.gz

chmod -R 777 keepalived-1.4.2

cd keepalived-1.4.2
./configure #默认安装
make
make install

会在以下路径生成:

/usr/local/etc/keepalived/keepalived.conf
/usr/local/etc/sysconfig/keepalived

/usr/local/sbin/keepalived

然后我们需要手动做以下事情:

1、mkdir /etc/keepalived #新建文件夹

再把/usr/local/etc/keepalived/keepalived.conf拷贝到/etc/keepalived/keepalived.conf,

cp /usr/local/etc/keepalived/keepalived.conf /etc/keepalived/

内容修改为:

[html] view plain copy
  1. ! Configuration File for keepalived  
  2.   
  3. global_defs {  
  4.    notification_email { #指定Keepalived在发生事情的时候,发送邮件通知,每行一个地址  
  5.      acassen@firewall.loc  
  6.      failover@firewall.loc  
  7.      sysadmin@firewall.loc  
  8.    }  
  9.    notification_email_from Alexandre.Cassen@firewall.loc #指定发件人  
  10.    smtp_server 192.168.200.1 #发送email的smtp地址  
  11.    smtp_connect_timeout 30 #超时时间  
  12.    router_id lb01 #运行Keepalived的机器标识号,主从机必须不同  
  13.    ##vrrp_skip_check_adv_addr #注释掉vrrp_strict相关是为了解决虚拟ip,ping不通的问题  
  14.    ##vrrp_strict  
  15.    ##vrrp_garp_interval 0  
  16.    ##vrrp_gna_interval 0  
  17. }  
  18.   
  19. vrrp_instance VI_1 {  
  20.     state MASTER  
  21.     interface ens33 #物理网卡名称,主节点和备节点需要相同  
  22.     virtual_router_id 100 #唯一的id,主从机必须相同  
  23.     priority 150 #优先级,主节点大于备节点,建议至少相差50  
  24.     advert_int 1 #通信检查间隔时间1s  
  25.     authentication {  
  26.         auth_type PASS  
  27.         auth_pass 1111  
  28.     }  
  29.     virtual_ipaddress {  
  30.         172.16.6.200 #虚拟ip,会绑定在ens33网卡  
  31.     }  
  32. }  


注意:配置keepalived后发现虚拟ip ping不通的解决办法,vim /etc/keepalived/keepalived.conf。把vrrp_strict相关的语句注释就可以了。


2、在路径/etc/init.d/下新建keepalived.sh脚本,内容如下,重点关注exec和sysconfig的路径要对的上:

[html] view plain copy
  1. #!/bin/sh   
  2. #   
  3. # keepalived   High Availability monitor built upon LVS and VRRP   
  4. #   
  5. # chkconfig:   - 86 14   
  6. # description: Robust keepalive facility to the Linux Virtual Server project \   
  7. #              with multilayer TCP/IP stack checks.   
  8.      
  9. ### BEGIN INIT INFO   
  10. # Provides: keepalived   
  11. # Required-Start: $local_fs $network $named $syslog   
  12. # Required-Stop: $local_fs $network $named $syslog   
  13. # Should-Start: smtpdaemon httpd   
  14. # Should-Stop: smtpdaemon httpd   
  15. # Default-Start:    
  16. # Default-Stop: 0 1 2 3 4 5 6   
  17. # Short-Description: High Availability monitor built upon LVS and VRRP   
  18. # Description:       Robust keepalive facility to the Linux Virtual Server   
  19. #                    project with multilayer TCP/IP stack checks.   
  20. ### END INIT INFO   
  21.      
  22. # Source function library.   
  23. . /etc/rc.d/init.d/functions   
  24.   
  25. exec="/usr/local/sbin/keepalived"  
  26. prog="keepalived"  
  27. config="/etc/keepalived/keepalived.conf"  
  28.      
  29. [ -e /usr/local/etc/sysconfig/$prog ] &&  /usr/local/etc/sysconfig/$prog   
  30.   
  31. lockfile=/var/lock/subsys/keepalived   
  32.   
  33. start() {   
  34.     [ -x $exec ] || exit 5   
  35.     [ -e $config ] || exit 6   
  36.     echo -n $"Starting $prog: "   
  37.     daemon $exec $KEEPALIVED_OPTIONS  
  38.     retval=$?   
  39.     echo   
  40.     [ $retval -eq 0 ] && touch $lockfile   
  41.     return $retval   
  42. }   
  43.      
  44. stop() {   
  45.     echo -n $"Stopping $prog: "   
  46.     killproc $prog   
  47.     retval=$?   
  48.     echo   
  49.     [ $retval -eq 0 ] && rm -f $lockfile   
  50.     return $retval   
  51. }   
  52.      
  53. restart() {   
  54.     stop   
  55.     start   
  56. }   
  57.      
  58. reload() {   
  59.     echo -n $"Reloading $prog: "   
  60.     killproc $prog -1   
  61.     retval=$?   
  62.     echo   
  63.     return $retval   
  64. }   
  65.      
  66. force_reload() {   
  67.     restart   
  68. }   
  69.      
  70. rh_status() {   
  71.     status $prog   
  72. }   
  73.      
  74. rh_status_q() {   
  75.     rh_status &>/dev/null   
  76. }   
  77.      
  78.      
  79. case "$1" in   
  80.     start)   
  81.         rh_status_q && exit 0   
  82.         $1   
  83.         ;;   
  84.     stop)   
  85.         rh_status_q || exit 0   
  86.         $1   
  87.         ;;   
  88.     restart)   
  89.         $1   
  90.         ;;   
  91.     reload)   
  92.         rh_status_q || exit 7   
  93.         $1   
  94.         ;;   
  95.     force-reload)   
  96.         force_reload   
  97.         ;;   
  98.     status)   
  99.         rh_status   
  100.         ;;   
  101.     condrestart|try-restart)   
  102.         rh_status_q || exit 0   
  103.         restart   
  104.         ;;   
  105.     *)   
  106.         echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload}"   
  107.         exit 2   
  108. esac   
  109. exit $?  

二、运行测试

1、获得权限

chmod a+x /etc/init.d/keepalived

chmod a+x /usr/local/etc/sysconfig/keepalived

chmod a+x /usr/local/sbin/keepalived

2、启动

/etc/init.d/keepalived start

或者 service keepalived start

启动后,可以通过以下命令来查看是否安装正确,启动后有3个keepalive进程表示正确:

[html] view plain copy
  1. [root@localhost init.d]# ps -ef|grep keep|grep -v grep  
  2. root      20163      1  0 10:03 ?        00:00:00 /usr/local/sbin/keepalived -D  
  3. root      20164  20163  0 10:03 ?        00:00:00 /usr/local/sbin/keepalived -D  
  4. root      20165  20163  0 10:03 ?        00:00:00 /usr/local/sbin/keepalived -D  
  5.   
  6. [root@localhost ~]# ip add|grep 172.16  
  7.     inet 172.16.6.161/24 brd 172.16.6.255 scope global ens33  
  8.     inet 172.16.6.200/32 scope global ens33  


ifconfig只能查看物理网卡,ip addr或者ip a才能看见虚拟ip,172.16.6.161是真实ip,172.16.6.200是虚拟ip

[html] view plain copy
  1. [root@localhost init.d]# ip addr  
  2. 1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN qlen 1  
  3.     link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00  
  4.     inet 127.0.0.1/8 scope host lo  
  5.        valid_lft forever preferred_lft forever  
  6.     inet6 ::1/128 scope host   
  7.        valid_lft forever preferred_lft forever  
  8. 2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000  
  9.     link/ether 00:0c:29:b9:7b:31 brd ff:ff:ff:ff:ff:ff  
  10.     inet 172.16.6.161/24 brd 172.16.6.255 scope global ens33  
  11.        valid_lft forever preferred_lft forever  
  12.     inet 172.16.6.200/32 scope global ens33  
  13.        valid_lft forever preferred_lft forever  
  14.     inet6 fe80::2176:1363:975e:6c17/64 scope link   
  15.        valid_lft forever preferred_lft forever  

3、停止

/etc/init.d/keepalived stop
或者 service keepalived stop


4、通过终端命令来查看虚拟ip是否生效存在:

正确状态下,主机会生效,命令有返回查询结果;备机不生效,命令无查询结果。

主机异常时,备机才生效。

也就是说,正常两个主机启动keepalived的时候,应该是master 绑定了虚拟ip。通过命令 ip a 和ip add|grep 172.16.6.200,只有在master机器上能看到绑定的虚拟ip,而backup上是看不到的。

[html]
  1. [root@localhost ~]# ip add|grep 172.16.6.200  
  2.     inet 172.16.6.200/32 scope global ens33  


5、本人的实测环境是:在一台电脑开了2个CentOS 7虚拟机,ip分别是

主服务器A:172.16.6.161

备服务器B:172.16.6.135

防火墙处于关闭状态,我通过service keepalived stop命令来测试主备的变化。

按照以上的配置信息,我现在遇到的问题:两个keepalived启动的时候,通过命令ip a和ip add|grep 172.16.6.200, 都能看到绑定了虚拟ip,相当于两台都是master,那怎么办呢?

出现这问题的场景是在服务器网络环境中,因为路由交换层禁用了ARP的广播限制,造成KEEPALIVE主备协议无法通过广播的方式进行通信,造成主备两台服务器都强占HAVIP地址,出现同时两台服务器都有VIP地址的情况出现,必须通过配置来指定IP的两台服务器间进行通讯。也就是说主备vvrp直接无法通信的原因,改成单播就ok了:

主机配置keepalived.conf如下,重点关注unicast_src_ip和unicast_peer字段。

[html]
  1. ! Configuration File for keepalived  
  2.   
  3. global_defs {  
  4.    notification_email { #指定Keepalived在发生事情的时候,发送邮件通知,每行一个地址  
  5.      acassen@firewall.loc  
  6.      failover@firewall.loc  
  7.      sysadmin@firewall.loc  
  8.    }  
  9.    notification_email_from Alexandre.Cassen@firewall.loc #指定发件人  
  10.    smtp_server 192.168.200.1 #发送email的smtp地址  
  11.    smtp_connect_timeout 30 #超时时间  
  12.    router_id lb01 #运行Keepalived的机器标识号,主从机必须不同  
  13.    ##vrrp_skip_check_adv_addr #注释掉vrrp_strict相关是为了解决虚拟ip,ping不通的问题  
  14.    ##vrrp_strict  
  15.    ##vrrp_garp_interval 0  
  16.    ##vrrp_gna_interval 0  
  17. }  
  18.   
  19. vrrp_instance VI_1 {  
  20.     state MASTER  
  21.     interface ens33 #物理网卡名称,主节点和备节点需要相同  
  22.     virtual_router_id 100 #唯一的id,主从机必须相同  
  23.     priority 150 #优先级,主节点大于备节点,建议至少相差50  
  24.     unicast_src_ip  172.16.6.161 #本地IP地址  
  25.     unicast_peer {  
  26.                   172.16.6.135 #对端IP地址,此地址一定不能忘记  
  27.                        }  
  28.     advert_int 1 #通信检查间隔时间1s  
  29.     authentication {  
  30.         auth_type PASS  
  31.         auth_pass 1111  
  32.     }  
  33.     virtual_ipaddress {  
  34.         172.16.6.200 #虚拟ip,会绑定在ens33网卡  
  35.     }  
  36. }  

备机配置keepalived.conf如下,重点关注unicast_src_ip和unicast_peer字段。

[html] view plain copy
  1. ! Configuration File for keepalived  
  2.   
  3. global_defs {  
  4.    notification_email { #指定Keepalived在发生事情的时候,发送邮件通知,每行一个地址  
  5.      acassen@firewall.loc  
  6.      failover@firewall.loc  
  7.      sysadmin@firewall.loc  
  8.    }  
  9.    notification_email_from Alexandre.Cassen@firewall.loc #指定发件人  
  10.    smtp_server 192.168.200.1 #发送email的smtp地址  
  11.    smtp_connect_timeout 30 #超时时间  
  12.    router_id lb02 #运行Keepalived的机器标识号,主从机必须不同  
  13.    ##vrrp_skip_check_adv_addr #注释掉vrrp_strict相关是为了解决虚拟ip,ping不通的问题  
  14.    ##vrrp_strict  
  15.    ##vrrp_garp_interval 0  
  16.    ##vrrp_gna_interval 0  
  17. }  
  18.   
  19. vrrp_instance VI_1 {  
  20.     state BACKUP  
  21.     interface ens33 #物理网卡名称,主节点和备节点需要相同  
  22.     virtual_router_id 100 #唯一的id,主从机必须相同  
  23.     priority 100 #优先级,主节点大于备节点,建议至少相差50  
  24.     unicast_src_ip  172.16.6.135 #本地IP地址  
  25.     unicast_peer {  
  26.                   172.16.6.161 #对端IP地址,此地址一定不能忘记  
  27.                        }  
  28.     advert_int 1 #通信检查间隔时间1s  
  29.     authentication {  
  30.         auth_type PASS  
  31.         auth_pass 1111  
  32.     }  
  33.     virtual_ipaddress {  
  34.         172.16.6.200 #虚拟ip,会绑定在ens33网卡  
  35.     }  
  36. }  


6、如果开启firewall防火墙,则记得要放行VRRP默认的多播地址224.0.0.18,centos7下面改firewall防火墙命令如下:

firewall-cmd --direct --permanent --add-rule ipv4 filter INPUT 0 --in-interface ens33 --destination 224.0.0.18 --protocol vrrp -j ACCEPT 

firewall-cmd --reload
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值