HA Cluster-主备模型(项目实战)

主机环境:主机A和主机B使用的是CentOS7.2的系统:
    主机A IP地址为:192.168.1.103
    主机B IP地址为:192.168.1.106
    向外界提供的服务的地址为:192.168.1.100

配置过程:
    (1)基础配置过程:
        a.在主机B上同步主机A的时间:
            vim /etc/chrony.conf
            注释掉以server开头的行,添加下面的行;
            server 192.168.1.103 iburst
            systemctl restart chronyd.service
            chronyc sources
        b.关闭主机A和主机B的防火墙和SELinux
            iptables -F
            setenforce 0
        c.各节点之间的root用户可以基于密钥认证的ssh服务完成互相通信(非必须)      
            主机A:ssh-keygen -t rsa -P ''
            主机B:ssh-copy-id -i .ssh/id_rsa.pub root@192.168.1.106
            用主机A测试连接主机B:ssh 'root@192.168.1.106'
    (2)主机A配置为主主机:

        yum -y install keepalived
        mv /etc/keepalived/keepalived.conf{,.bak}
        vim /etc/keepalived/keepalived.conf
            ! Configuration File for keepalived
            global_defs {
                notification_email {
                    root@localhost :设置主机的email的收件人为root,真实生产中用的是公司的管理员的邮箱账号;
                }
                notification_email_from keepalived@localhost:设置报警服务的发件人为keepalived;
                smtp_server 127.0.0.1
                smtp_connect_timeout 30
                router_id node1
                vrrp_mcast_group4 224.0.100.19
            }
            vrrp_instance VI_1 {
                state MASTER :设置主机A模式为MASTER
                interface eno16777736
                virtual_router_id 14 :给出一个指定的ID,应该和周围所有的人的不一样
                priority 100:设置主机的优先级为100
                advert_int 1
                authentication {
                    auth_type PASS :设置认证机制为PASS
                    auth_pass 571f97b2 :设置密钥,应该是一串随机的密码
                }
                virtual_ipaddress {
                    192.168.1.100/24 dev eno16777736        
                }  网络响应的IP为192.168.1.100/24

            }

        systemctl start keepalived.service
    (3)主机B配置为备用主机:(可以直接远程复制主机A的配置文件,修改即可)
        yum -y install keepalived
        mv /etc/keepalived/keepalived.conf{,.bak}
        vim /etc/keepalived/keepalived.conf
            ! Configuration File for keepalived
            global_defs {
                notification_email {
                    root@localhost
                }
                notification_email_from keepalived@localhost
                smtp_server 127.0.0.1
                smtp_connect_timeout 30
                router_id node1
                vrrp_mcast_group4 224.0.100.19
            }
            vrrp_instance VI_1 {
                state BACKUP :设置主机B模式为BACKUP,备用主机
                interface eno16777736
                virtual_router_id 14 :给出一个指定的ID,应该和周围所有的人的不一样,但应该和MASTER主机的相同;
                priority 98 :设置主机B的优先级应该小于主机A的优先级,以98为例;
                advert_int 1
                authentication {
                    auth_type PASS :设置认证机制为PASS
                    auth_pass 571f97b2 :设置密钥,应该是一串随机的密码,应该和MASTER主机的PASS相同        
                }
                virtual_ipaddress {
                    192.168.1.100/24 dev eno16777736                
                }  网络响应的IP为192.168.1.100/24        
            }  
        systemctl start keepalived.service  
测试过程:
    (1)同时启用主机A和主机B,然后观察日志的输出:
        systemctl start keepalived.service
        主机A的日志:(主机A已经监听在192.168.1.100)

        blob.png

        blob.png

         主机B的日志:(主机B由于是备用主机,所以显示BACKUP模式)

        blob.png

        blob.png   

    (2)将主机A的keepalived的服务down掉,然后观察主机A和主机B的日志信息
        在主机A上面执行的命令:systemctl stop keepalived.service
        主机A的日志信息:(发现主机A已经将192.168.1.100 IP地址已经移除)

        blob.png

        blob.png

        主机B的日志信息:(主机B发现主机A已经down掉,自己接手192.168.1.100 IP地址)

        blob.png

        blob.png

    (3)将主机A的keepalived服务启动起来,观察日志的输出:
        主机A执行的操作:systemctl start keepalived.service
        主机A的日志信息:(由于主机A的优先级比主机B的优先级高,所以主机A应该取回192.168.1.100的IP)

        blob.png

        blob.png

        主机B的日志信息:(主机B发现比自己级别高的主机A已经运行,所以将自己的IP交出,自己回到BACKUP模式)

        blob.png

        blob.png

    (4)扩展,要是主机A和主机B的优先级同样高,在主机Adown掉,主机B接手IP,之后,启动主机A的keepalived的服务,主机B还会将自己的IP交出,将自己的恢复成BACKUP模式么?
        实验步骤:
            修改主机B的/etc/keepalved/keepalived.conf配置文件中的:priority的值修改为100                    
        实验的现象:
        a.将主机Adown掉之后的两台主机的日志:
            主机A的日志信息:

            blob.png

            blob.png

            主机B的日志信息:

            blob.png

            blob.png            

        b.将down掉的主机A重新启动服务,观察现象:
            主机A的日志信息:

            blob.png

            blob.png

            主机B的日志信息:    

            blob.png

            blob.png

        结果总结:虽然将主机A和主机B的优先级调到同样高的级别,但是主机A因为是MASTER身份,所以还是在重新启动的时候,请求主机B交出自己的IP,让主机B恢复为BACKUP的模式;即使在同样的级别下,MASTER的主机就是比BACKUP的主机的响应程度高。

原创文章,作者:sjsir,如若转载,请注明出处:http://www.178linux.com/56639

(0)
sjsirsjsir
上一篇 2016-11-01 14:02
下一篇 2016-11-01 14:35

相关推荐

  • rpm管理包

    rpm命令是RPM软件包的管理工具。rpm原本是Red Hat Linux发行版专门用来管理Linux各项套件的程序,由于它遵循GPL规则且功能强大方便,因而广受欢迎。逐渐受到其他发行版的采用。RPM套件管理方式的出现,让Linux易于安装,升级,间接提升了Linux的适用度。接下来聊一聊如何安装、卸载、查询、检验rpm类的软件。 安装:…

    2017-08-19
  • 马哥教育网络班21期+第3周课程练习

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@centos ~]# who | awk '{print $1 $NF}'| uniq -d root(192.168.40.1) derulo(19…

    Linux干货 2016-07-22
  • 使用httpd反向代理模块实现tomcat负载均衡集群(上)

    前言  tomcat介绍:   tomcat是一个免费开放源代码的web应用服务器,不是一个完整意义上的Java EE服务器;它甚至都没有提供哪怕对一个主Java EE API的实现,但由于遵守apache开源协议,tomcat却有为众多的java应用程序服务器嵌入自己的产品中构建商业的java应用程序服务器,如JBoss和JOnAS等。…

    Linux干货 2015-07-21
  • 第一章 linux的安装及简单的命令合集

    linux安装;简答命令:注释;常见用法

    Linux干货 2018-03-17
  • 网络班26期-第1周课程作业

    1、描述计算机的组成及其功能? (1)CPU:计算机的大脑,计算机的运算,命令的控制功能,寄存器及缓存都由CPU功能承担; (2)内存:RAM,随机访问存储器,计算机的另一个核心功能,系统指令存放及运行的基础。 (3)输入设备:人工给计算机下指令的设备,例如鼠标,键盘等; (4)输出设备:计算机输出人工输入的执行命令的结果;例如,音响,显示屏等; …

    Linux干货 2017-01-10
  • 网络接口配置bonding

    Bonding 就是将多块网卡绑定同一IP地址对外提供服务,可以实现高可用或者负载均衡。当然,直接给两块网卡设置同一IP地址是不可能的。通过bonding,虚拟一块网卡对外提供连接,物理网卡的被修改为相同的MAC地址。 Bonding的工作模式 Mode 0 (balance-rr)     轮转(…

    Linux干货 2016-09-09