keepalived主备高可用配置
来源:互联网 发布:ftp yum源 编辑:程序博客网 时间:2024/05/04 10:48
一、工作原理
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、vrrp_script、vrrp_instance和virtual_server、static_ipaddress、static_routes。
global_defs区域
global_defs { notification_email { a@abc.com b@abc.com ... } notification_email_from alert@abc.com smtp_server smtp.abc.com smtp_connect_timeout 30 enable_traps router_id host163}
- notification_email 故障发生时给谁发邮件通知。
- notification_email_from 通知邮件从哪个地址发出。
- smpt_server 通知邮件的smtp地址。
- smtp_connect_timeout 连接smtp服务器的超时时间。
- enable_traps 开启SNMP陷阱
- router_id 标识本节点的字条串,通常为hostname,但不一定非得是hostname。故障发生时,邮件通知会用到。
vrrp_script区域
vrrp_script chk_tomcat_8080 { #定义一个名为chk_tomcat_8080的检查脚本 script "netstat -tpln | grep -w 8080" interval 5 #执行间隔 weight -2}
执行script里面的命令。当weigt为正数时,script指令的执行结果从非0变为0时,优先级加上对应的值;反之,当weigt为负数时,script指令的执行结果从0变为非0时,优先级减去相应的值。
上面示例的意思是,当关闭8080端口时,优先级减2。
vrrp_instance区域
vrrp_instance用来定义对外提供服务的VIP区域及其相关属性。
vrrp_instance CLM_1 { state MASTER interface bond0 virtual_router_id 19 priority 100 advert_int 1 track_interface { bond0 bond1 } track_script { chk_tomcat_8080 } authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.181.19/26 dev bond0 } notify_master "/apps/sh/notify.sh master" notify_backup "/apps/sh/notify.sh backup"}
- state 可以是MASTER或BACKUP。当节点keepalived启动时会将priority比较大的节点选举为MASTER,因此该项其实没有实质用途。
- interface 节点固有IP(非VIP)的网卡,用来发VRRP包。
- virtual_router_id 取值在0-255之间,用来区分多个instance的VRRP组播。
- priority 优先级,通过该值选举MASTER,项取值范围是1-255(在此范围之外会被识别成默认值100)。
- advert_int 发VRRP包的时间间隔,即多久进行一次master选举。
- track_interface 监控以下网卡,如果任何一个不通就会切换到FALT状态。(可选项)
- track_script 执行的检查脚本。
- authentication 认证区域,认证类型有PASS和HA(IPSEC),推荐使用PASS(密码只识别前8位)。
- virtual_ipaddress 绑定的vip
- notify_master 、notify_backup 当切换为master或backup状态时,执行的脚本。
- keepalived主备高可用配置
- Nginx+Keepalived 主备高可用 安装与配置
- keepalived+nginx实现主备高可用
- keepalived 及 keepalived配置LVS高可用集群
- nginx+keepalived配置高可用HTTP群集
- Nginx + keepalived 高可用配置文档
- MariaDB+Keepalived双主高可用配置MySQL
- nginx+keepalived配置双主高可用负载均衡
- mysql+keepalived 主主高可用集群配置
- HaProxy+keepalived+mycat集群高可用配置
- MariaDB+Keepalived双主高可用配置MySQL-HA
- HaProxy+Keepalived+Mycat高可用群集配置
- nignx+keepalived高可用配置开发步骤
- keepalived+LVS+MySql Cluster 高可用配置
- keepalived+LVS+MySqlCluster 高可用配置
- Mycat+keepalived+haporxy 高可用群集配置
- RabbitMQ高可用配置(Haproxy + Keepalived)
- Mysql+Keepalived双主互备高可用详细配置
- Android Volley使用介绍(三),量身定做自己的Request
- Clion注册码
- 二分查找
- CSS预处理语言:Sass
- Python学习笔记(break语句)
- keepalived主备高可用配置
- lag与latency的区别
- thymeleaf学习
- OC - 使用AFNetworking进行图片上传
- unity3d 平滑看向的脚本
- lua 堆栈
- DNS的解析杂谈,以及gethostbyname的弊端
- boost 1.56.0 编译及使用
- 大数据相关内容资料收集