高可用工具keepalived学习笔记
keepalived完全遵守VRRP协议包括竞选机制,至于VRRP是什么这里不说了参考http://wenku.baidu.com/link?
url=1UbkmHuQlGECgC90P7zF6u2xYyifLK0F-G_7pehNVUitZZExISjZ-
B22TJKKGyYIZXh9X7uULA8lA1nKw0NsyNGelrt_yQ317knkVyjwCqW,不同的是VRRP里的路由器在keepalive中变成服务器
vrrp的术语:虚拟路由器、VRID、Master、Backup、VIP、VMAC、优先级、抢占式、非抢占式;
HA Cluster的配置前提: 1、各节点时间要同步 (查看两台主机时间是否同步的命令date; ssh root@x.x.x.x 'date' 2、确保
iptables及selinux不会成为障碍
yum -y install keepalived

/etc/keepalived/keepalived.conf 就是keepalived的主配置文件 配置文件的说明可以使用命令 man keepalived.conf
vim /etc/keepalived/keepalived.conf

global_defs 定义的是全局配置段, notification_email表示keepalived在发生诸如主从切换操作时需要发送email通知,以及email
发送给哪些邮件地址,邮件地址可以多个每行一个
notification_email_from 发件人邮箱地址 , smtp_server 表示发送email时使用的smtp服务器地址 ,
smtp_connect_timeout:与邮件服务器建立连接的超时时长
router_id LVS_DEVEL:物理节点的标识符;建议使用主机名

vrrp_instance 配置虚拟服务器实例, state MASTER|BACKUP:在当前VRRP实例中此节点的初始状态, interface vrrp用于绑定vip
的接口 , virtual_router_id 当前VRRP实例的VRID,可用范围为0-255,默认为51, priority 100 设置本节点的优先级优先级高的为
master可用范围0-255, advert int 检查间隔默认为1秒, authentication 这里设置认证, auth type 认证方式 auth pass 认证密码
virtual_ipaddress 配置虚拟ip地址

上图指的是lvs配置段
配置一台backup:


在两台主机上都启动keepalived service keepalived start
ip addr list, 可以看到master上已经配置了vip了

如果把master停掉 vip就会漂移到backup, 根据上面的配置使用mail命令去查看本地邮件 f|from num 指针移动到指定邮件 查看
backup是否转变为master,或者在backup主机上使用ip addr list 查看绑定的接口上是否有vip地址来决定状态是否转换,前提是还
得写一个脚本来说明邮件的内容是什么
接下来就写这个脚本

脚本定义好了还得在配置文件中定义脚本怎么引用

notify_master 如果该主机转换成master则执行哪个脚本 notify_backup 转换成backup执行哪个脚本 notify_fault 发生错误执
行哪个脚本,notify这三条指令在master和backup都得给配置上
一台master需要维护可以直接是用service keepalived stop 下面介绍另外一种方法当一台master主机需要维护时,通过脚本的方式
使master降级为backup,不过默认情况下当原来的master恢复时会主动把master重新夺回

vrrp_script 定义哪一个脚本名 script 执行什么脚本, interval 定义执行脚本的时间间隔, weight 如果script的执行状态结果为失
败,则使priority减2
接下来还得在vrrp实例中调用该脚本

在track_script中调用前面定义过的脚本,脚本的目的是如果/etc/keepalived/目录下有down文件则使该keepalived主机的priority
减2,现在在另外一台keepalived主机上也配置上
接下来在两台keepalived主机上配置nginx并使nginx高可用,yum -y install nginx
rpm -ql nginx 查看一下网页根目录在哪 vim /usr/share/nginx/html/index.html

在后面添加了HAA

在后面添加了HA1,这样两nginx就配置上了

master在172.16.238.176上,接下来把master down掉,在/etc/keepalived/下 touch down创建一个down文件

master转移到了192.168.238.177上了,现在的需要是创建一个脚本,能自动识别nginx作为反代服务器是否在线,如果master上的
nginx不在线立即降为backup,并使backup立即转为master,实现nginx的高可用

killall -0 nginx 探测nginx是否在线,它不会杀死nginx进程,如果nginx在线则执行状态返回值为0,反之为1,如果为1 就会使该
keepalived主机的priority减5,降级为backup,如果从前的master nginx服务又启动了,则会夺回master
在vrrp实例中调用该脚本


track_interface是监控网卡是否正常,它不需要定义脚本,有内置的脚本
高可用工具keepalived学习笔记的更多相关文章
- Rancher Server HA的高可用部署实验-学习笔记
转载于https://blog.csdn.net/csdn_duomaomao/article/details/78771731 Rancher Server HA的高可用部署实验-学习笔记 一.机器 ...
- Nginx之keepalived高可用工具
1.创建两台虚拟机,分别为主机和从机,区别两台虚拟机的IP地址 2. 将keepalived上传到linux系统当中 3. cd /usr/local目录 4. tar -zxvf keepalive ...
- centos7.4安装高可用(haproxy+keepalived实现)kubernetes1.6.0集群(开启TLS认证)
目录 目录 前言 集群详情 环境说明 安装前准备 提醒 一.创建TLS证书和秘钥 安装CFSSL 创建 CA (Certificate Authority) 创建 CA 配置文件 创建 CA 证书签名 ...
- GNU工具链学习笔记
GNU工具链学习笔记 1..so为动态链接库,.a为静态连接库.他们在Linux下按照ELF格式存储.ELF有四种文件类型.可重定位文件(Relocatable file,*.o,*.a),包含代码和 ...
- 17.Linux高可用之Keepalived
1.什么是高可用,为什么要设计高可用? 两台机器启动着相同的业务系统,当有一台机器宕机,另外一台服务器能快速的接管,对于访问的用户是无感知的. 减少系统不能提供服务的时间. 2.高可用使用什么工具来实 ...
- 高可用软件Keepalived
关于高可用软件Keepalived的使用及配置请参见:http://www.voidcn.com/blog/9124573/article/p-5990263.html
- 高可用之KeepAlived(2):keepalived+lvs
*/ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...
- MySQL高可用工具--orchestrator
orchestrator是一款MySQL高可用工具,其支持: 集群拓扑探测 集群拓扑重塑 故障恢复 提供3种使用方式: 命令行 HTTP API web页面 orchestator github地址
- keepalived高可用工具
1.准备俩台虚拟机,一台主机,一台备机 我这里模拟的是 主机ip: 192.168.42.66 masternginx 备机ip: 192.168.42.77 slavenginx 虚拟ip: 192 ...
随机推荐
- Java中的Property类
Property是JAVA中的属性操作类,该类在java.util包中,它是HashTable的子类. 常用函数列表: l Properties() n 构造函数 l setProperty(S ...
- 京东校招笔试(C++方向)编程题
这次笔试是今年校招我参加的第一次笔试..出了很多状况,基础知识不扎实,导致选择题耽误了太多时间,导致后面的题目没做完,编程题也没有在 时间内写出来,基本没有面试机会了.不过我继续研究第二个编程题,在1 ...
- SQL执行的原理以及一些常见的关键字
sql语句在面试里面问道的问题: sql的解析的顺序 1.where里面的条件是从右向左扫描解析 2.from里面的大表在前,小表在后,解析的顺序是从右向左解析. 3.left/right/inner ...
- MySQL数据库优化技术之数据库表的设计
三范式介绍表的范式:只有符合的第一范式,才能满足第二范式,进一步才能满足第三范式. 1. 第一范式:表的列具有原子性,不可再分解.只要是关系型数据库都自动满足第一范式.数据库的分类:关系型数据库:My ...
- 剑指Offer:面试题11——数值的整数次方(java实现)
题目描述: 实现函数double Power(double base, int exponent),求base的exponent次方,不得使用库函数,同时不需要考虑大数问题 思路:本题的重点考察内容是 ...
- C# ToolStripProgressBar
ToolStripProgressBar 将所有 ToolStrip控件的移动和渲染功能和其典型的进程跟踪功能结合在一起.ToolStripProgressBar通常放在StatusStrip中,偶尔 ...
- Xml语言
一.XML是什么?作用是什么? l XML ( eXtensible Markup Language )语言是一种可扩展的标记语言.其中的可扩展是相对HTML来说的.因为XML标签没有被预定义,需要 ...
- 为网站加入Drupal星球制作RSS订阅源
目前中文 Drupal 星球的版块还未成立,但大家的积极性挺高,不少站长都已经调整好自己的网站,生成了可供Drupal Planet 使用的RSS订阅源. 如果你也想让网站做好准备,可以不必再花上不少 ...
- 国内外CDN服务商CNAME特征串调研
总结 此篇博文给特定需求的人群使用,通过CNAME的某些特征串,确定其使用的是哪家CDN,大多是国外的CDN,国内的CDN厂商只有几个,格式为:[来源地址]+[截图]+[猜测的特征串],整体博文较长, ...
- 慕课网-安卓工程师初养成-3-4 Java中的比较运算符
来源:http://www.imooc.com/code/1299 比较运算符用于判断两个数据的大小,例如:大于.等于.不等于.比较的结果是一个布尔值( true 或 false ). Java 中常 ...