19.1、heartbeat的作用:

heartbeat的官方网站地址是:http://linux-ha.org/wiki/Main_Page

19.2、heartbeat工作原理:

19.3、heartbeat切换的条件:

1、和keepalived服务一样,heartbeat高可用是服务器级别的,不是服务级别的;

2、切换的条件是:

(1)服务器宕机;

(2)heartbeat服务本身故障;

(3)心跳连接故障(网络连接故障);

(4)可以通过停掉heartbeat服务实现切换;

19.4、heartbeat心跳连接:

要部署heartbeat服务,至少需要两台主机来完成;

1、两台主机如何做到相互监测:

(1)串行电缆(串口)(首选);

(2)一根以太网电缆两网卡直连;(推荐)

(3)以太网电缆,通过交换机等网络设备连接(次要);

1)缺点:增加了交换机故障点;

2)线路不是专用心跳线,容易受其他数据传输的影响,

导致心跳报文发送问题;

19.5、heartbeat裂脑:

1、什么是裂脑:

2、发生裂脑的原因:

(1)高可用服务器之间心跳链路故障,导致无法通信;

1)心跳线坏了(包括断了,老化);

2)网卡及相关的驱动故障,ip配置冲突,心跳间设备故障;

(2)高可用服务器对上开启了防火墙阻挡了心跳消息传输;

(3)高可用服务器对上心跳网卡地址等信息配置不正确,导致心跳发送失败;

(4)其它服务配置不当的原因,如心跳的方式不同,心跳广播冲突,软件bug等;

3、预防脑裂的方法:

19.6、heartbeat消息类型:

1、消息类型:

(1)心跳消息;

(2)集群转换消息;

(3)重传消息;

2、心跳消息:

3、集群转换消息:

4、重传消息:

19.7、heartbeat的ip接管和故障转移原理:

19.8、vip(ip别名,辅助ip)介绍:

ifconfig eth1:0 192.168.0.111/24 up

#创建网卡别名,heartbeat 2版本用;

ip addr add 10.0.0.3/24 dev eth0 label eth0:0

#创建辅助ip,heartbeat 3版本起使用;

ifconfig eth0:0 down #删除网卡别名或辅助ip;

19.9、heartbeat脚本默认目录:

1、启动目录:

/etc/init.d/

2、资源目录:

/etc/ha.d/resource.d/

3、heartbeat控制脚本的要求:

(1)把脚本放到上面两个路径其中任意一个下面,然后在/etc/ha.d/haresource配置

文件中配置脚本名称就能够调用到该脚本,进而控制资源和服务的启动和关闭;

(2)脚本要有执行的权限;

(3)脚本执行需要以/etc/init.d/httpd stop|start 的方式;

(4)/etc/init.d/httpd名字要和/etc/ha.d/haresource中配置的启动服务名相同;

(5)/etc/ha.d/resource.d/目录为heartbeat的默认脚本存放目录;

(6)master-db IPaddr::172.16.1.26/24/eth1 httpd #使用heartbeat管理http服务;

19.10、heartbeat的配置文件:

19.11、高可用软件使用的场景:

1、使用的条件:

高可用服务器对之间数据要时时同步,否则高可用切换时数据会不一致;

2、web代理的高可用:

keeplived+lvs/nginx/haproxy

heartbeat+nginx/haproxy

控制vip资源的漂移,不负责服务资源的启动及停止;

3、存储和数据库的高可用方案:

(1)数据库:

heartbeat+drbd+mysql

(2)存储:

heartbeate+drbd+nfs

也可以使用keepalived/heartbeat+(inotify+rsync)+nfs

(3)注意事项:

heartbeat既控制vip资源的漂移同时又控制服务资源启动及停止,heartbeat控制服务资源

启动及停止时,服务资源不要设置为开机自启动;

19.12、heartbeat修改配置文件要点:

heartbeat常见的情况就是修改配置文件,主要有三个配置文件,分别是ha.cf、authkey、haresource;

在修改配置文件之前需要执行/etc/init.d/heartbeat stop或者是/usr/lib64/heartbeat/hb_standby,把

本机业务推到备节点工作,当确认被节点工作正常后才开始修改本地的配置,修改好后执行/etc/init.d/heartbeat start

命令把资源服务接管回来;

确定资源接管的命令:

ifconfig | grep "vip地址"

wget url

[root@master-db ~]#/etc/init.d/heartbeat

Usage: /etc/init.d/heartbeat {start|stop|status|restart|reload|force-reload}

19.13、一个局域网中多组heartbeat服务同时开启的问题:

mcast eth0 255.0.0.1 694 1 0

即使在一个局域网中是多组heartbeat服务同时使用,多播方式也是没有问题的,前提是

多播地址不能够相同(多播地址段是224.0.0.0 - 239.255.255.255),不用多播用单播也是可以的;

19、高可用工具heartbeat介绍的更多相关文章

  1. mysql高可用方案MHA介绍

    mysql高可用方案MHA介绍 概述 MHA是一位日本MySQL大牛用Perl写的一套MySQL故障切换方案,来保证数据库系统的高可用.在宕机的时间内(通常10-30秒内),完成故障切换,部署MHA, ...

  2. Nginx之keepalived高可用工具

    1.创建两台虚拟机,分别为主机和从机,区别两台虚拟机的IP地址 2. 将keepalived上传到linux系统当中 3. cd /usr/local目录 4. tar -zxvf keepalive ...

  3. MySQL高可用工具--orchestrator

    orchestrator是一款MySQL高可用工具,其支持: 集群拓扑探测 集群拓扑重塑 故障恢复 提供3种使用方式: 命令行 HTTP API web页面 orchestator github地址

  4. 高可用-软件heartbeat的入门介绍

    注:参考互联网整理. 一.简介Linux-HA的全称是High-Availability Linux,它是一个开源项目,这个开源项目的目标是:通过社区开发者的共同努力,提供一个增强linux可靠性(r ...

  5. 高可用群集HA介绍与LVS+keepalived高可用群集

    一.Keepalived介绍 通常使用keepalived技术配合LVS对director和存储进行双机热备,防止单点故障,keepalived专为LVS和HA设计的一款健康检查工具,但演变为后来不仅 ...

  6. Keepalived高可用集群介绍

    1.Keepalived服务介绍 Keepalived起初是专为LVS设计的,专门用来监控LVS集群系统中各个服务节点的状态,后来又加入了VRRP的功能,因此除了配合LVS服务外,也可以为其他服务(n ...

  7. 高可用工具keepalived学习笔记

    keepalived完全遵守VRRP协议包括竞选机制,至于VRRP是什么这里不说了参考http://wenku.baidu.com/link? url=1UbkmHuQlGECgC90P7zF6u2x ...

  8. mysql 高可用方案MHA介绍

    概述 MHA是一位日本MySQL大牛用Perl写的一套MySQL故障切换方案,来保证数据库系统的高可用.在宕机的时间内(通常10—30秒内),完成故障切换,部署MHA,可避免主从一致性问题,节约购买新 ...

  9. keepalived高可用工具

    1.准备俩台虚拟机,一台主机,一台备机 我这里模拟的是 主机ip: 192.168.42.66 masternginx 备机ip: 192.168.42.77 slavenginx 虚拟ip: 192 ...

随机推荐

  1. [Java] javaEE

    定义 面向企业级应用中一些通用模块制定的标准 避免重复开发,解决代码可靠性问题 13种规范 JDBC(JavaDatabase Connectivity):数据库连接 以统一方式访问数据库的API J ...

  2. [刷题] 347 Top K Frequent Elements

    要求 给定一个非空数组,返回前k个出现频率最高的元素 示例 [1,1,1,2,2,3], k=2 输出:[1,2] 思路 出队逻辑,普通队列是先进先出,优先队列是按最大/最小值出队 通过堆实现优先队列 ...

  3. wps中新罗马字体如何设置Times New Roman

    word wps中新罗马字体如何设置Times New Roman  ###   WPS字体自带 Times New Roman  ###

  4. 061.Python前端Django组件用户认证组件

    一 auth认证组件 在使用pymysql,数据库迁移的时候.,默认生成有十张表如下 查看author_user表结构 mysql> desc auth_user; +------------- ...

  5. Prometheus存储原理及数据备份还原

    prometheus将采集到的样本以时间序列的方式保存在内存(TSDB 时序数据库)中,并定时保存到硬盘中.与zabbix不同,zabbix会保存所有的数据,而prometheus本地存储会保存15天 ...

  6. strcpy和memcpy的区别-(转自stone Jin)

    strcpy和memcpy都是标准C库函数,它们有下面的特点.strcpy提供了字符串的复制.即strcpy只用于字符串复制,并且它不仅复制字符串内容之外,还会复制字符串的结束符. 已知strcpy函 ...

  7. Redis SWAPDB 命令背后做了什么

    Redis SWAPDB 命令背后做了什么 目录 Redis SWAPDB 命令背后做了什么 0x00 摘要 0x01 SWAPDB 基础 1.1 命令说明 1.2 演示 0x02 预先校验 0x03 ...

  8. Go语言安装配置

    一.Go语言下载 官方下载地址:https://golang.google.cn/dl/ 选择自己需要的版本下载即可. 二.Go语言安装 下载完成之后,双击go1.16.4.windows-amd64 ...

  9. Pandas之:Pandas简洁教程

    Pandas之:Pandas简洁教程 目录 简介 对象创建 查看数据 选择数据 loc和iloc 布尔索引 处理缺失数据 合并 分组 简介 pandas是建立在Python编程语言之上的一种快速,强大 ...

  10. 物联网设备OTA软件升级之:升级包下载过程之旅

    OTA概述 大家好,我是一个软件升级包.这几天呢,我将会进行一次神奇的网络之旅,从开发者的电脑中,一直跑到终端嵌入式设备中. 大家都把我的这个旅游过程叫做 OTA,也就是在线升级. 那么啥叫 OTA ...