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数据库可以采用双主热备,实现高可用性。

时间: 2024-10-29 17:17:18

Linux双机热备解决方案之Heartbeat的相关文章

双机热备方案及双机热备软件选择

1 什么是双机热备方案 企事业机构的信息化建设已经在随着社会建设的不断推进而改进和创新.众企事业机构的决策层也愈发重视企事业机构的信息化,不同程度的运营和发展着自身的业务信息系统.但是日趋普遍的业务信息系统在为企事业机构带来利益的同时,也存在着一个不容忽视的隐患--越来越多的业务依赖于业务信息系统.如果运行着关键业务信息系统的服务器发生宕机或是因为不可控的原因而停止,从而导致整个企事业机构的信息运营系统瘫痪,将会给企事业机构带来巨大的经济损失,而由于企事业机构的业务不能正常运行也会影响企事业机构

动手搭建centos下用heartbeat实现双机热备

中介交易 http://www.aliyun.com/zixun/aggregation/6858.html">SEO诊断 淘宝客 云主机 技术大厅 双机热备就是使用两台服务器共同执行同一服务,在运行过程中实时相互备份,当一台服务器出现故障时候,另一台可以立即发现故障并接管那天服务器的服务,从而在不需要人工干预的情况下自动保证系统能持续提供服务.常见的有两种情况:使用共同存储设备.使用不同存储设备(需要通过软件保持同步),在同一时间内主服务器保持激活状态,备份服务器处于监听状态,当主服务器

双机热备常见问题及解决方案

对于企业重要的应用系统而言,保证系统能持续.可靠地提供服务是非常重要的,因此就出现了对高可用性的需求和高可用性的解决方案. 对于如何选择高可用性的解决方案,特别是关于双机热备的方案选择,常见的有以下问题: Q:高可用性的解决方案有哪些? A:从广义讲,高可用性包括一切避免系统服务中断的技术.而一般所说的系统高可用性,往往特指服务器的双机或多机热备/容错. Q:什么时候需要双机热备? A:决定是否使用双机热备,正确的方法是要分析一下系统的重要性以及对服务中断的容忍程度,以此决定是否使用双机热备.即

双机热备常见问题与方案选择

问题 对于企业重要的应用系统而言,保证系统能持续.可靠地提供服务是非常重要的,因此就出现了对高可用性的需求和高可用性的解决方案. 对于如何选择高可用性的解决方案,特别是关于双机热备的方案选择,常见的有以下问题: Q:已经采取了RAID技术和数据备份技术,还有必要做双机吗? A:参见:双机热备与数据备份的关系 Q:高可用性的解决方案有哪些? A:从广义讲,高可用性包括一切避免系统服务中断的技术.而一般所说的系统高可用性,往往特指服务器的双机或多机热备/容错. Q:什么时候需要双机热备? A:决定是

Pluswell硬件方式热备解决方案

一.概述: 对于日益承担企事业单位核心业务的NT网络来说,数据的高可用性和系统的连续运转能力极其重要,作为实时服器与http://www.aliyun.com/zixun/aggregation/13681.html">数据保护解决方案,双机热备提供了数据的高可用性.运行系统的自动切换及最少的恢复时间. 在信息系统建设中充满安全危机,一个小小的硬件故障或误操作都有可能造成您的网络出现停滞或瘫痪,使您的业务蒙受损失.同时,信息系统建设的目标是对来自内外的业务信息.业务数据.重要信息.安全保密

纯软件方式的双机热备方案深入分析

数据库双机热备有两种典型的方式,一种是比较标准的,两台服务器通过一个共享的存储设备(一般是共享的磁盘阵列或存储区域网SAN),并且安装双机软件,实现双机热备,称为共享方式.另一种方式是通过纯软件的方式,一般称为纯软件方式或镜像方式(Mirror). 对于共享方式,数据库放在共享的存储设备上.当一台服务器提供服务时,直接在存储设备上进行读写.而当系统切换后,另一台服务器也同样读取该存储设备上的数据. 对于纯软件的方式,通过镜像软件,将数据可以实时复制到另一台服务器上,这样同样的数据就在两台服务器上

rose ha 维护技术-安装了ROSE HA双机热备的服务器,重装系统,需要怎么重新配置

问题描述 安装了ROSE HA双机热备的服务器,重装系统,需要怎么重新配置 公司有两台服务器做了双机热备的,但是其中一台后备机器阵列卡坏了,换了阵列卡,现在需要重新安装操作系统和rose ha,需要怎样去配置这个ROSE,求教程,谢谢... 解决方案 看你是什么阵列,raid 1 raid5之类的才可以恢复,raid 0就不可以.开机进入阵列的bios(不是系统的bios)设置,里面有重构raid的.

LVS+Keepalived实现负载均衡和双机热备

 1. 说明          在<keepalived实现Tomcat服务双机热备>中主要讲述如何安装及配置Keepalived来实现双机热备,主要功能是:MASTER和BACKUP两台服务器处于热备状态,对用户虚拟一个IP,屏蔽底层的真实IP地址,用户通过虚拟IP访问当前的MASTER服务器:当MASTER服务器宕机或者发生其他故障时,BACKUP自动切换为MASTER,这个过程对用户时透明的.          本文主要讲述如何安装ipvsadm.如何配置LVS+Keepalived实现

oracle双机热备,hibernate的配置以及listener.ora和tnsname.ora的配置

问题描述 oracle双机热备一台IP:172.16.0.1,虚拟ip:10.10.10.10.另一台IP:172.16.0.2,虚拟IP:10.10.10.11.请问:listener.ora和tsnnames.ora应该如何配置,以及hibernate如何配置.高手请赐教.调好立刻给分. 解决方案 解决方案二:关注....