Linux双机热备解决方案之Heartbeat
拓扑图:
环境描述:
操作系统:CentOS6.3_x64
主:eth0 192.168.10.10 心跳:eth1 192.168.1.10
备:eth0 192.168.10.20 心跳:eth1 192.168.1.20
VTP:192.168.128.5
heartbeat(Linux-HA)的工作原理:heartbeat最核心的包括两个部分,心跳监测部分和资源接管部分,心跳监测可以通过网络链路和串口进行,而且支持冗余链路,它们之间相互发送报文来告诉对方自己当前的状态,如果在指定的时间内未受到对方发送的报文,那么就认为对方失效,这时需启动资源接管模块来接管运 行在对方主机上的资源或者服务。
Heartbeat:(心跳检测)本身是整个集群的基础(cluster messaging layer),负责维护集群各节点的信息以及它们之前通信;只提供主从备份功能,并不能对各个节点进行监控,需要安装ldirectord。
Resource-agent:(资源代理)就是各种的资源的ocf脚本,这些脚本将被LRM调用从而实现各种资源启动、停止、监控等等。
Cluster-glue:相当于一个中间层,可以将heartbeat和crm(pacemaker)联系起来,主要包含2个部分,LRM和STONITH;
Ldirectord:负责realserver的健康检查,可以自动将realserver中宕机的机器移除,不再分配请求。
安装依赖包:
1
|
yum install -y gcc gcc-c++ autoconf libtool pkgconfig glib2-devel libxslt-devel libxml2-devel bzip2 -devel libtool-ltdl-devel libuuid-devel docbook-style-xsl
|
安装资源接管服务依赖包:
1
|
yum install -y *Socket6* *libwww-perl* *URI* *MailTools* *HTML-Parser* perl-IO-Socket-*
|
配置host解析
vi /etc/hosts
192.168.10.10 master
192.168.10.20 slave
软件下载:http://www.linux-ha.org/wiki/Downloads
一、配置主从heartbeat服务器(配置相同)
创建需要的组和用户
1
2
|
groupadd haclient
useradd -g haclient -s /sbin/nologin -M hacluster
|
1.安装资源接管服务(要先安装资源接管服务,否则安装心跳服务会报错)
1
2
3
4
5
|
tar zxvf Reusable-Cluster-Components-glue--glue-1.0.9. tar .bz2
cd Reusable-Cluster-Components-glue--glue-1.0.9
. /autogen .sh
. /configure
make && make install
|
2.安装心跳服务
1
2
3
4
|
tar jxvf Heartbeat-3-0-7e3a82377fa8. tar .bz2
cd Heartbeat-3-0-7e3a82377fa8
. /ConfigureMe configure
make && make install
|
报错:./configure: error: Core development headers were not found
解决:./ConfigureMe configure ,如果还解决不了,就是你没有安装Heartbeat服务
报错:gmake[1]: --xinclude: Command not found ,gmake[1]: *** [heartbeat.8] Error 127
解决:yum install libxslt-devel
3.安装中间件服务
1
2
3
4
5
|
tar jxvf ClusterLabs-resource-agents-v3.9.2-0-ge261943. tar .gz
cd ClusterLabs-resource-agents-b735277
. /autogen .sh
. /configure
make && make install
|
报错:syntax error near unexpected token `DBUS,
解决:vi configure,注释这行PKG_CHECK_MODULES(DBUS, dbus-1, dbus-glib-1)
二、配置heartbeat
1
2
3
4
5
6
7
8
9
10
|
/etc/ha .d /ha .cf #定义心跳信息层,用于实现心跳信息传输。
/etc/ha .d /haresources #本地最重要的CRM,这个文件我们使用v1版本的配置文件,很简单。
/etc/ha .d /authkeys #实现两个节点之间传递,对心跳信息进行签名,或者加密,避免篡改;authkeys的权限非常重要,通常是400或者600的,如果设置不对无法启动heartbeat服务。
rm -rf /usr/etc/ha .d
ln -s /etc/ha .d /usr/etc
cp /usr/share/doc/heartbeat/haresources /etc/ha .d
cp /usr/share/doc/heartbeat/authkeys /etc/ha .d
cp /usr/share/doc/heartbeat/ha .cf /etc/ha .d
chmod 600 /etc/ha .d /authkeys
chkconfig heartbeat on
|
1.修改配置文件
1
2
3
4
5
|
vi authkeys
auth 2
#1 crc
2 sha1 HI!
#3 md5 Hello!
|
1
2
3
4
5
6
7
8
9
10
11
12
13
|
vi ha.cf
logfile /var/log/ha-log
logfacility local0 #如果未定义上述日志,默认写入/var/log/message
keepalive 2 #心跳间隔
deadtime 30 #死亡阀值
warntime 10 #警告时间
initdead 120 #首次启动heartbeat,等待多久才启动主服务资源
udpport 694 #连接端口
ucast eth1 192.168.1.20 #采用网卡的eth1组织心跳,后跟接口IP
auto_failback on #当主节点故障恢复后,自动获取资源并取代从节点
node master #主节点主机名
node slave #备份节点主机名
ping 192.168.1.1 #选择ping节点,ping的越好对HA集群越稳定,建议使用网关
|
1
2
3
4
|
vi haresources
master IPaddr::192.168.128.5 ldirectord::ldirectord.cf httpd
#格式:[主机名] [资源名与虚拟ip] [资源名与脚本] [高可用服务]
#每个资源都是一个shell脚本,后面还可以写虚拟IP和资源,heartbeat会使用init脚本来管理系统服务,在范围内搜索脚本并启用
|
1
2
3
|
scp -r /etc/ha .d root@slave: /etc/ha .d #配置好的复制到备份服务器上
rm -rf /usr/etc/ha .d
ln -s /etc/ha .d /usr/etc
|
2.配置ldirectord
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
cp ClusterLabs-resource-agents-b735277 /ldirectord/ldirectord .cf /etc/ha .d/
vi /etc/ha .d /ldirectord .cf
checktimeout=3
checkinterval=1
autoreload= yes
quiescent= yes
virtual=192.168.128.5:80
real=192.168.1.10:80 gate
real=192.168.1.20:80 gate
fallback=127.0.0.1:80 gate
service=http
scheduler=rr
protocol=tcp
checkport=80
|
三、测试
1
2
3
4
5
6
|
service iptables stop #关闭防火墙
setenforce 0 #临时关闭selinux
service heartbeat start
ifconfig #会显示192.168.0.100绑定在主服务器eth0:0
echo “192.168.10.10″ > /var/www/html/index .html
echo “192.168.10.20″ > /var/www/html/index .html
|
hearbeat启动报错:
/etc/init.d/heartbeat: line 53: /etc/ha.d/shellfuncs: No such file or directory
解决:这是因为没有装ClusterLabs-resource-agents导致的,装了这个中间件会把shellfuncs自动复制过去,我们可以手动复制过去即可。
cp ClusterLabs-resource-agents-b735277/heartbeat/shellfuncs /etc/ha.d/
http://192.168.128.5 #正常访问到192.168.10.10
模拟down掉192.168.10.10的httpd服务,再刷新页面显示192.168.10.20,说明配置成功!
生产环境中,网站程序数据必须是一致的,可以采用rsync进行同步或使用共享存储(NFS、ISCSI),后台MySQL数据库可以采用双主热备,实现高可用性。
Linux双机热备解决方案之Heartbeat相关推荐
- 双机热备+负载均衡(Heartbeat+DRBD+NFS+Keepalived+Lnmp)线上方案
双机热备+负载均衡 线上方案 (Heartbeat+DRBD+NFS+Keepalived+Lnmp) gotop 对于网站服务器来说,可靠性之重要不用我多说,但要想做到可靠性一般需要昂贵的设备,这里 ...
- 网闸是单独部署还是双机部署_鼎信通达UC8000系列IPPBX双机热备解决方案
概述 随着通信全IP化的进程,现代企业中基于IP的语音.视频.会议.融合通信已广泛应用,企业部署的IPPBX作为通信系统最核心的部分,如何保证高可靠性与安全性尤为重要,也成了考验系统能力的一种标准. ...
- 网闸是单独部署还是双机部署_鼎信通达-UC8000系列IPPBX双机热备解决方案
概述 随着通信全IP化的进程,现代企业中基于IP的语音.视频.会议.融合通信已广泛应用,企业部署的IPPBX作为通信系统最核心的部分,如何保证高可靠性与安全性尤为重要,也成了考验系统能力的一种标准. ...
- linux双机热备方案,Hadoop HDFS系统双机热备方案 PDF
1. 前言 HDFS包含两种角色:数据节点(datanode)和名字节点(namenode),名字节点只有一个,数据节点最多支持2000个.HDFS可以确保在硬件失效情况下数据存储的可靠性.常见的三种 ...
- linux双机热备软件 mysql_linux mysql双机热备
linux mysql双机热备与win mysql双机热备略有不同,至少在win下面很快就OK. 本例使用的是mysql5.1.45编译安装 一.linux下热备修改/etc/my.cnf 具体修改如 ...
- windows文件服务器双机热备_服务器双机热备解决方案
两台主机各安装一套数据库软件(Oracle/SQL/Sysbase/)和应用程序,建立主机系统结构的镜像模式.将数据库的系统库.数据库及日 志建立在磁盘阵列提供的硬盘裸设备上,保证了其中任一台主机出现 ...
- linux查看双机热备运行,linux双机热备,故障切换!!!
1.部署一组mirror ha至少需要3个IP地址,其中2个ip地址作为物理IP使用,另外的ip作为浮动ip使用,也就是当浮动ip飘在哪台机器上面,那么就启动该机器上面的服务. 2.Linux系统的内 ...
- drbd实现mysql地热备_Mysql+DRBD+Heartbeat 实现mysql高可用的双机热备(mysql+heartbeat篇)...
*************************************部署MYSQL******************************************* yum -y insta ...
- linux双机热备 oracle,oracle for linux双机热备实战
10.0.0.11是我主服务器的ip,10.0.0.111是我从服务器的ip, testdbase是数据库的sid号, 操作系统的版本是RedHat Linux 8.0 数据库版本是Oracle 9. ...
最新文章
- 不连续子网掩码的魅力
- Sql Server中Select @Value和Select Value的区别
- Linux虚拟文件系统解析
- linux pprof工具安装,google perftools工具介绍
- C#编程总结(七)数据加密——附源码
- bgss::spherical_side_formula用法的测试程序
- c++ string分割字符串split_python 字符串和文本处理
- 深度学习数据集制作工作_创建我的第一个深度学习+数据科学工作站
- java scala_经过几天的Scala回归Java的10个最烦人的事情
- oracle 数据执行计划,Oracle 常见的执行计划步骤(explain结果的Description数据参考)...
- node.js web框架_使用Node.js进行Web爬取的终极指南
- win7系统怎么打开屏幕键盘
- smokeping安装方法及不出图解决办法
- linux模块builtin是什么意思,Linux命令手册
- python链接器编译器实现_一个链接器的实现「一」
- 荐书|图解深度学习与神经网络:从张量到TensorFlow实现
- WeUI for 小程序使用教程文档总结
- 非平稳序列的确定性分析
- CVPR2018 ——(GAN)延时摄影视频的生成
- 我的一些杭电计算机考研资料
热门文章
- jQuery 实现 select模糊查询 反射机制
- 用计算机画函数图像教案,信息技术应用 用计算机画函数图象教案1
- android广播intent原理,Android中BroadcastReceiver详解
- 智能车竞赛技术报告 | 智能车视觉 - 山东大学(威海) - 山魂五队
- 允许自行设计赛道之后,参赛同学都想到了什么呢?
- 基于ESP32智能车竞赛比赛系统硬件初步调试-5-6
- 一些信号与自己的卷积结果
- 商城模板网站html5手机端_网站建设中,pc端与手机移动端设计一样吗
- 怎么体验华为鸿蒙系统,华为mate40升级鸿蒙系统体验_华为mate40升级鸿蒙系统使用感受...
- linux排除多个文件,linux – 通过排除其父文件夹为多个目录创建单个tar文件