• keepalived的概述与安装


    keepalived是什么

    Keepalived软件起初是专门为LVS负载均衡软件设计的用来管理并监控LVS集群系统中各个服务节点的状态,后来又加入了可以实现高可用的VRRP功能。因此,Keepalived除了能够管理LVS软件外,还可以作为其他服务的高可用解决方案软件。

    Keepalived软件主要是通过VRRP协议实现高可用功能的,VRRP是Virtual Router Redundancy Protocol(虚拟路由器冗余协议)的缩写.VRRP出现的目的就是为了解决静态路由单点故障问题的

    Keepalived是一个免费开源的,用C编写的类似于layer3, 4 & 7交换机制软件,具备我们平时说的第3层、第4层和第7层交换机的功能。主要提供loadbalancing(负载均衡)和 high-availability(高可用)功能,负载均衡实现需要依赖Linux的虚拟服务内核模块(ipvs),而高可用是通过VRRP协议实现多台机器之间的故障转移服务。 

     

    VRRP原理

     

     

    1.master在工作状态会不断群发一个广播包(内涵优先参数)

     

    2.其他路由收到收到广播后会和自己的优先参数作对比,如果优先参数小于自己则什么都不执行,如果优先参数大于自己则开启争抢机制

     

    3.如果启动了争抢机制,他就会群发自己的优先参数,最终优先参数最小的称为master路由.

     

    keepalived工作原理

    keepalived是以VRRP协议为实现基础的,VRRP全称Virtual Router Redundancy Protocol,即虚拟路由冗余协议

    虚拟路由冗余协议,可以认为是实现路由器高可用的协议,即将N台提供相同功能的路由器组成一个路由器组,这个组里面有一个master和多个backup,master上面有一个对外提供服务的vip(该路由器所在局域网内其他机器的默认路由为该vip),master会发组播,当backup收不到vrrp包时就认为master宕掉了,这时就需要根据VRRP的优先级选举一个backup当master。这样的话就可以保证路由器的高可用了。

    keepalived主要有三个模块,分别是core、check和vrrp。core模块为keepalived的核心,负责主进程的启动、维护以及全局配置文件的加载和解析。check负责健康检查,包括常见的各种检查方式。vrrp模块是来实现VRRP协议的。

    keepalived只有一个配置文件keepalived.conf,里面主要包括以下几个配置区域,分别是global_defs、static_ipaddress、static_routes、vrrp_script、vrrp_instance和virtual_server。

     keepalived体系结构

    上图是Keepalived的功能体系结构,大致分两层:用户空间(user space)和内核空间(kernel space)。 
    内核空间:主要包括IPVS(IP虚拟服务器,用于实现网络服务的负载均衡)和NETLINK(提供高级路由及其他相关的网络功能)两个部份。 
    用户空间

    • WatchDog:负载监控checkers和VRRP进程的状况
    • VRRP Stack:负载负载均衡器之间的失败切换FailOver,如果只用一个负载均稀器,则VRRP不是必须的。
    • Checkers:负责真实服务器的健康检查healthchecking,是keepalived最主要的功能。换言之,可以没有VRRP Stack,但健康检查healthchecking是一定要有的。
    • IPVS wrapper:用户发送设定的规则到内核ipvs代码
    • Netlink Reflector:用来设定vrrp的vip地址等。

    Keepalived的所有功能是配置keepalived.conf文件来实现的。

    keepalived安装

    1、keepalived下载地址:http://www.keepalived.org/download.html

    #将keepalived-2.0.10.tar.gz上传到服务器/usr/local/下。
    cd /usr/local tar -zxvf keepalived-2.0.10.tar.gz
    cd keepalived-2.0.10 #执行配置命令
    ./configure --prefix=/usr/local/keepalived
    #编译 make
    #安装 make install

    2、加入开机启动

    #拷贝执行文件 
    cp /usr/local/keepalived/sbin/keepalived /usr/sbin/
    #将init.d文件拷贝到etc下,加入开机启动项 (错误:缺少rc.d 目录,1.2版本之后,这个目录编译后不再出现放在源码包里面)
    cp /usr/local/keepalived-2.0.10/keepalived/etc/init.d/keepalived /etc/init.d/keepalived
    #将keepalived文件拷贝到etc下,加入网卡配置 
    cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/ 
    #创建keepalived文件夹 
    mkdir -p /etc/keepalived
    #将keepalived配置文件拷贝到etc下 
    cp /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/keepalived.conf
    #添加可执行权限 
    chmod +x /etc/init.d/keepalived
    #加入开机启动:
    chkconfig --add keepalived    #添加时必须保证/etc/init.d/keepalived存在
    chkconfig keepalived on
    #添加完可查询系统服务是否存在:
    chkconfig --list

    3、keepalive的操作

    #启动
    service keepalived start
    #停止
    service keepalived stop
    #重启
    service keepalived restart
  • 相关阅读:
    Android布局优化
    Handler原理
    最少钱币数:
    ASCII码排序
    Fibonacci数
    奇偶数分离
    认识Dom
    js浏览器对象
    返回/设置时间方法与 Math对象
    window.open
  • 原文地址:https://www.cnblogs.com/zouhong/p/12294689.html
Copyright © 2020-2023  润新知