基于keepalived的VRRP协议实现DR模型下的高可用集群

基于keepalived的VRRP协议实现DR模型下的高可用集群

环境及配置前提说明

4台虚拟服务器都为centos6.8.

主机1,ip:192.168.25.140 做后端RS1,80端口向外部提供web服务

主机2,ip:192.168.25.141 做后端RS2,80端口向外部提供web服务

ip:192.168.25.142为lo:0接口的VIP地址,80端口定义为集群服务端口

注意:两台作为DR模型的RS主机需要先配置其内核参数

主机3,ip:192.168.25.138 做keepalived集群主机1,做主模型的,负责调度,192.168.25.142为VIP地址,80端口定义为集群服务端口

主机4,ip:192.168.25.139 做keepalived集群主机2,做备模型的,负责调度,192.168.25.142为VIP地址,80端口定义为集群服务端口

1、给两台后端RS主机安装webserver,这里以httpd为例,并且为其编辑测试主页,并且配置两台RS主机的内核参数,定义其arp级别,以及为其lo:0接口设置vip地址

]# yum install httpd -y
]# vim /var/www/html/index.html
<h1>RS 1</h1>
<h1>RS 2</h1>
]# vim set_arp.sh 使用脚本的方式来配置内核参数和lo接口的vip地址 
    #/!bin/bash
    #
    vip='192.168.25.142' #vip地址
    vport='80' #vip端口
    netmask='255.255.255.255' #vip掩码
    iface='lo:0' #vip接口

    case $1 in
    start)
            echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
            echo 1 > /proc/sys/net/ipv4/conf/lo/arp_ignore
            echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce
            echo 2 > /proc/sys/net/ipv4/conf/lo/arp_announce

            ifconfig $iface $vip netmask $netmask broadcast $vip up #添加vip地址到lo:0接口
            route add -host $vip dev $iface #添加路由
            ;;
    stop)
            ifconfig $iface down

            echo 0 > /proc/sys/net/ipv4/conf/all/arp_ignore
            echo 0 > /proc/sys/net/ipv4/conf/lo/arp_ignore
            echo 0 > /proc/sys/net/ipv4/conf/all/arp_announce
            echo 0 > /proc/sys/net/ipv4/conf/lo/arp_announce
            ;;
    esac
]# ./set_arp.sh start

2、为两台keepalived主机编辑配置文件

]# yum install keepalived -y 安装keepalived
]# cp -a keepalived.conf{,.bak} 先备份
]# vim keepalived.conf 编辑配置文件
]# openssl rand -hex 4 生成8位密码
2.1节点1配置如下
! Configuration File for keepalived

global_defs {
   notification_email {
     root@localhost
   }
   notification_email_from keepalived@localhost
   smtp_server 172.0.0.1
   smtp_connect_timeout 30
   router_id node1
   vrrp_mcast_group4 224.0.100.19
}

vrrp_instance VI_1 {
    state MASTER
    interface eth0
    virtual_router_id 1
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass cb77b8da
    }
    virtual_ipaddress {
        192.168.25.142/32 dev eth0 #此处写DR模型中的VIP地址
    }
    notify_master "/etc/keepalived/notify.sh master"
    notify_backup "/etc/keepalived/notify.sh backup"
    notify_fault "/etc/keepalived/notify.sh fault"
}

vrrp_instance VI_2 {
    state BACKUP
    interface eth0
    virtual_router_id 2
    priority 99
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 020c3694
    }
    virtual_ipaddress {
        192.168.25.142/32 dev eth0 #此处写DR模型中的VIP地址
    }
}

virtual_server 192.168.25.142 80 { #此处写DR模型中的VIP地址
    delay_loop 3
    lb_algo rr
    lb_kind DR
    protocol TCP

    real_server 192.168.25.140 80 { #此处写DR模型中的RS1地址
        weight 1
        HTTP_GET {
            url {
              path /
              status_code 200
            }
            connect_timeout 1
            nb_get_retry 3
            delay_before_retry 1
        }
    }
    real_server 192.168.25.141 80 { #此处写DR模型中的RS2地址
        weight 1
        HTTP_GET {
            url {
              path /
              status_code 200
            }
            connect_timeout 1
            nb_get_retry 3
            delay_before_retry 1
        }
    }
}
2.2节点2配置如下;
! Configuration File for keepalived

global_defs {
   notification_email {
     root@localhost
   }
   notification_email_from root@localhost
   smtp_server 172.0.0.1
   smtp_connect_timeout 30
   router_id node2
   vrrp_mcast_group4 224.0.100.19
}

vrrp_instance VI_1 {
    state BACKUP
    interface eth0
    virtual_router_id 1
    priority 99
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass cb77b8da
    }
    virtual_ipaddress {
        192.168.25.142/32 dev eth0 #此处写DR模型中的VIP地址
    }
    notify_master "/etc/keepalived/notify.sh master"
    notify_backup "/etc/keepalived/notify.sh backup"
    notify_fault "/etc/keepalived/notify.sh fault"
}

vrrp_instance VI_2 {
    state MASTER
    interface eth0
    virtual_router_id 2
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 020c3694
    }
    virtual_ipaddress {
        192.168.25.142/32 dev eth0 #此处写DR模型中的VIP地址
    }
}

virtual_server 192.168.25.142 80 { #此处写DR模型中的VIP地址
    delay_loop 3
    lb_algo rr
    lb_kind DR
    protocol TCP

    real_server 192.168.25.140 80 { #此处写DR模型中的RS1地址
        weight 1
        HTTP_GET {
            url {
              path /
              status_code 200
            }
            connect_timeout 1
            nb_get_retry 3
            delay_before_retry 1
        }
    }
    real_server 192.168.25.141 80 { #此处写DR模型中的RS2地址
        weight 1
        HTTP_GET {
            url {
              path /
              status_code 200
            }
            connect_timeout 1
            nb_get_retry 3
            delay_before_retry 1
        }
    }
}
3进行访问测试
curl http://192.168.25.142

基于keepalived的VRRP协议实现DR模型下的高可用集群

如上环境进行单主配置如下;

节点1配置
! Configuration File for keepalived

global_defs {
   notification_email {
     root@localhost
   }
   notification_email_from keepalived@localhost
   smtp_server 172.0.0.1
   smtp_connect_timeout 30
   router_id node1
   vrrp_mcast_group4 224.0.100.19
}

vrrp_instance VI_1 {
    state MASTER
    interface eth0
    virtual_router_id 1
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass cb77b8da
    }
    virtual_ipaddress {
        192.168.25.142/32 dev eth0 #此处写DR模型中的VIP地址
    }
    notify_master "/etc/keepalived/notify.sh master"
    notify_backup "/etc/keepalived/notify.sh backup"
    notify_fault "/etc/keepalived/notify.sh fault"
}

virtual_server 192.168.25.142 80 { #此处写DR模型中的VIP地址
    delay_loop 3
    lb_algo rr
    lb_kind DR
    protocol TCP

    real_server 192.168.25.140 80 {
        weight 1
        HTTP_GET {
            url {
              path /
              status_code 200
            }
            connect_timeout 1
            nb_get_retry 3
            delay_before_retry 1
        }
    }
    real_server 192.168.25.141 80 {
        weight 1
        HTTP_GET {
            url {
              path /
              status_code 200
            }
            connect_timeout 1
            nb_get_retry 3
            delay_before_retry 1
        }
    }
}
节点2配置
! Configuration File for keepalived

global_defs {
   notification_email {
     root@localhost
   }
   notification_email_from root@localhost
   smtp_server 172.0.0.1
   smtp_connect_timeout 30
   router_id node2
   vrrp_mcast_group4 224.0.100.19
}

vrrp_instance VI_1 {
    state BACKUP
    interface eth0
    virtual_router_id 1
    priority 99
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass cb77b8da
    }
    virtual_ipaddress {
        192.168.25.142/32 dev eth0
    }
    notify_master "/etc/keepalived/notify.sh master"
    notify_backup "/etc/keepalived/notify.sh backup"
    notify_fault "/etc/keepalived/notify.sh fault"
}

virtual_server 192.168.25.142 80 {
    delay_loop 3
    lb_algo rr
    lb_kind DR
    protocol TCP

    real_server 192.168.25.140 80 {
        weight 1
        HTTP_GET {
            url {
              path /
              status_code 200
            }
            connect_timeout 1
            nb_get_retry 3
            delay_before_retry 1
        }
    }
    real_server 192.168.25.141 80 {
        weight 1
        HTTP_GET {
            url {
              path /
              status_code 200
            }
            connect_timeout 1
            nb_get_retry 3
            delay_before_retry 1
        }
    }
}
测试

基于keepalived的VRRP协议实现DR模型下的高可用集群

为两种模型添加sorry_server

前提条件,keepalived主机需要安装web服务,使得sorry_server运行在keepalived主机上
]# yum install httpd -y 下载web服务
]# vim /var/www/html/index.html 编辑sorry_server主页
    <h1>这是sorry_server1</h1>
    <h1>这是sorry_server2</h1>
]# service keepalived stop 停止keepalived服务
]# vim keepalived.conf 编辑keepalived主机配置文件,定义sorry_server,在virtual_server的各real_server之外添加
    sorry_server 127.0.0.1 80
]# service keepalived start 启动服务
]# service httpd start 启动sorry_server服务
]# curl http://192.168.25.142 在两个RS都处于停机状态下进行访问测试,此时哪一个keepalived节点处于master地位则哪个节点响应

基于keepalived的VRRP协议实现DR模型下的高可用集群

基于keepalived的VRRP协议实现DR模型下的高可用集群

注意:此时如果一个keepalived主机挂了 只有另外一台在线的话 可是可以正常进行调度工作的

keepalived调用外部的辅助脚本进行资源监控,并根据监控的结果状态能实现优先动态调整示例;

基于keepalived的VRRP协议实现DR模型下的高可用集群

]# service keepalived start 启动服务
]# touch down | rm -f down 在当前的主节点上的/etc/keepalived目录下创建名为down的文件就可实现动态切换
注意:节点1和节点2都需要配置

原创文章,作者:M20-1马星,如若转载,请注明出处:http://www.178linux.com/58161

(0)
M20-1马星M20-1马星
上一篇 2016-11-07 10:36
下一篇 2016-11-07 10:40

相关推荐

  • DHCP及自动化安装Linux

    主机IP配置: 静态指定 静态IP 动态获取: bootp:bootprotocol MAC与IP一一静态对应 DHCP: Dynamic Host Configuration Protocol 动态主机配置协议基于UTP协议 主要用途:自动化分配IP地址,实现集中管理,解决IP地址不足的问题。 DHCP的4种报文 DHCP DISCOVER OFFER R…

    2017-09-18
  • N25-第五周作业

    1、显示当前系统上root、fedora或user1用户的默认shell;   grep -E “^\(root|fedora|user1\)” /etc/passwd | cut -d: f7 2、找出/etc/rc.d/init.d/functions文件中某单词后面跟一组小括号的行,形如hello();  &nb…

    Linux干货 2017-02-15
  • 软连接与硬连接

    硬链接定义 新建的文件是已经存在的文件的一个别名,当原文件删除时,新建的文件仍然可以使用. 硬链接(hard link) ln   UNIX文件系统提供了一种将不同文件链接至同一个文件的机制,称这种机制为链接。它可以使得单个程序对同一文件使用不同的名字。这样的好处是文件系统只存在一个文件的副本。系统简单地通过在目录中建立一个新的登记项来实现这种连接。该登记项…

    Linux干货 2017-07-22
  • Linux文档的压缩与打包

    Linux文档的压缩与打包 概述 compress和uncompress gzip压缩工具 bzip2压缩工具 zip压缩工具 tar压缩工具 cpio压缩工具(主要用来备份还原) Linux文档的压缩与打包 概述 本章将介绍Linux系统中的压缩和解压缩的工具,以及归档工具(tar,cpio) compress/uncompress:   &nb…

    Linux干货 2016-09-06
  • 第三周-作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。     ~]# who | cut -d" " -f1 | uniq 2、取出最后登录到当前系统的用户的相关信息。     ~]# who |  t…

    Linux干货 2016-12-14
  • N25第二周视频作业:用户、组与权限管理详解

    此篇博客是根据视频要求写的,因为马哥在视频中说了,用户组、权限在linux运维过程中比较重要,所以一定要深入学习 首先,先介绍一下用户、组与权限是什么:     用户:用户时指你在服务器上的标识,通过不同类型的用户,你享受到不同的待遇,而待遇就是权限的大小。每个用户在服务器上都有唯一的id标识,即使你将此用户删除,再建…

    Linux干货 2016-11-26