heartbeat介绍与基于heartbeat+lvs

heartbeat工作原理

  通过修改Heartbeat的配置文件,可以制定那一台Heartbeat服务器作为主服务器,则另一台将自动成为热备服务器。然后在热备服务器上配置Heartbeat守护程序来监听来自主服务器的心跳消息。如果热备服务器在指定时间内为监听到来自主服务器的心跳,就会启动故障转义程序,并取得主服务器上的相关资源服务的所有权,接替主服务器继续不间断的提供服务,从而达到资源以及服务高可用的目的。

   以上的描述heartbeat的主备模式,heartbeat还支持主主模式,即两台服务器互为主备,这是他们之间还会互相发送报文来告诉对方自己的当前的状态,如果在指定的时间内未收到对方发送的心跳报文,那么,一方就会认为对方失效或者是已经宕机了,这时每个运行正常的主机就会启动自身的资源接管模块来接管运行在对方主机上的资源或者是服务,继续为用户提供服务。

准备以下几台虚拟机

serverX

ip:172.25.39.X

domain:serverX.example.com

Heartbeat配置

server1,2

安装以下rpm包

heartbeat-3.0.4-2.el6.x86_64.rpm

heartbeat-libs-3.0.4-2.el6.x86_64.rpm

heartbeat-devel-3.0.4-2.el6.x86_64.rpm

ldirectord-3.9.5-3.1.x86_64.rpm

rpm -q heartbeat -d#查看有关文件

其中Ha.cfharesourcesauthkeys为配置文件,要在/etc/ha.d/中才会生效

cp /usr/share/doc/heartbeat-3.0.4/{Ha.cf,haresource,authkeys} /etc/ha.d/

配置 ha.cf

两个server交换心跳的端口,同一网段内,端口不要重复

通过广播通知心跳

注意配置节点时主节点在前 网络测试不要选对方

配置haresources

配置authkeys

chmod 600 authkeys#密钥认证,只有所有人可以操作

/etc/init.d/heartbeat start

tail -f /var/log/ha-log#查看是否报错

ip addr show#vip在主节点上

drbd 分布式复制块设备

DRBD(Distributed Replicated Block Device),DRBD 号称是 “网络 RAID”,开源软件,由LINBIT 公司开发。DRBD实际上是一种块设备的实现,主要被用于Linux平台下的高可用(HA)方案之中。他有内核模块和相关程序而组成,通过网络通信来同步镜像整个设备,有点类似于一个网络RAID-1的功能。也就是说当你将数据写入本地的DRBD设备上的文件系统时,数据会同时被发送到网络中的另外一台主机之上,并以完全相同的形式记录在文件系统中。本地节点与远程节点的数据可以保证实时的同步,并保证IO的一致性。所以当本地节点的主机出现故障时,远程节点的主机上还会保留有一份完全相同的数据,可以继续使用,以达到高可用的目的

主机之间有解析,并配置时间同步

Server1,2

drbd-8.4.2.tar.gz

yum install -y rpm-build

rpmbuild -tb drbd-8.4.2.tar.gz            #失败,缺少spec file

tar zxf drbd-8.4.2.tar.gz

cd drbd-8.4.2

./configure --enable-spec --with-km

rpmbuild -bb drbd.spec            #失败,看报错

cp /file/drbd-8.4.2.tar.gz /root/rpmbuild/SOURCES/

rpmbuild -bb drbd.spec

yum install -y kernel-devel

rpmbuild -bb drbd-km.spec

在/root/rpmbuild/RPMS/x86_64/中编译成rpm包

rpm -ivh *

cat /etc/drbd.conf            #文件会提示include ”drbd.d/*.res”;

cd /etc/drbd.d/

vim example.res

resource example {

meta-disk internal;

device /dev/drbd1;

syncer {

verify-alg sha1;

}

#net {

#allow-two-primaries;

#}

on server1.example.com {

disk /dev/vda;

address 172.25.39.1:7789;

}

on server2.example.com {

disk /dev/vda;

address 172.25.39.2:7789;

}

}

此配置只允许primary挂载

drbdadm create-md example            #初始化

/etc/init.d/drbd start            #两边需同步开启

cat /proc/drbd            #查看状态,正确开启时cs:Conneced

drbdadm primary example --force            #两块硬盘开始同步,等待同步完成进行下一操作,同步完后的设备为配置文件中设定的/dev/drbd1

cat /proc/drbd            #查看状态,正确同步时ds:UpToDate

相关指令 drbdadm primary/secondary exampledrbd-overviewdrbdadm down exampledrbdadm up example

drbd+heartbeat 例,作为httpd的存储

vim /etc/ha.d/haresources

/etc/init.d/heartbeat start


lvs

server1

ip addr add 172.25.39.100/24 dev eth0

ipvsadm -A -t 172.25.39.100:80 -s rr            #rr 工作状态轮询

ipvsadm -a -t 172.25.39.100:80 -r 172.25.39.4:80 -g

ipvsadm -a -t 172.25.39.100:80 -r 172.25.39.5:80 -g

/etc/init.d/ipvsadm save

cat /etc/sysconfig/ipvsadm            #查看配置

server4,5

ip addr add 172.25.39.100/32 dev eth0

yum install -y arptables_jf

arptables -nL

arptables -A IN -d 172.25.39.100 -j DROP

arptables -A OUT -s 172.25.39.100 -j mangle --mangle-ip-s 172.25.39.4

/etc/init.d/arptables_jf save

vim /var/www/html/index.html

在物理机中

arp -an | grep 172.25.39.100            #正确结果,只会绑定server1的MAC

arp -d 172.25.39.100            #如有错误操作,需删除记录,才会重新绑定

curl 172.25.39.100            #会轮流访问server4,server5,但当一个server的httpd停止后,仍会轮流访问(没有资源检测)

heartbeat+lvs+ldirectord

sever1,2

先将/etc/init.d/ipvsadm stop

cp /usr/share/doc/ldirectord-3.9.5/ldirectord.cf /etc/ha.d/

cd /etc/ha.d/

vim ldirectord.cf

/etc/init.d/ldirectord start

Ipvsadm -l

/etc/init.d/ldirectord stop

Ip addr del 172.25.39.100/24 dev eth0

vim /etc/ha.d/haresources

/etc/init.d/heartbeat start            #ldirectord httpd 开启

ip addr show            #vip在主节点上

rs都挂掉,本机补上;primary 挂掉,secondary补上。


时间: 2024-10-20 08:43:44

heartbeat介绍与基于heartbeat+lvs的相关文章

基于heartbeat v1+ldirectord实现LVS集群高可用

前言 高可用集群,High Availability Cluster,简称HA Cluster,是指以减少服务中断时间为目的的服务器集群技术.通过上文可以看出,LVS集群本身并不能实现高可用,比如Director Server不能检测Real Server的健康度,一旦其中一台或全部Real Server宕机,Director Server还会继续转发请求,导致站点无法访问,同样,如果Director Server宕机站点就更不可能正常运转了.本文将讲解如何基于heartbeat v1实现LVS

CentOS6.4 高可用集群之基于heartbeat(crm)和nfs的mysql高可用

CentOS6.4 高可用集群之基于heartbeat和nfs的高可用mysql CentOS版本: CentOS release 6.4(Final) 2.6.32-358.el6.i686 效果演示: 使用ssh连接(nod-1.magedu.com)192.168.3.7 并执行以下命令: [[email protected] ha.d]# hb_gui & 说明:hb_gui是heartbeat为了方便管理集群资源而提供的一个图形用户接口 安装heartbeat默认会在系统中创建一个名为

通过LAMP组合,基于heartbeat v2 crm实现HA

Heartbeat的定义  Heartbeat 项目是 Linux-HA 工程的一个组成部分,也是目前开源HA项目中最成功的一个例子,Linux-HA的全称是High-Availability Linux,这个开源项目的目标是:通过社区开发者的共同努力,提供一个增强linux可靠性(reliability).可用性 (availability)和可服务性(serviceability)(RAS)的群集解决方案,它实现了一个高可用集群系统.心跳服务和集群通信是 高可用集群的两个关键组件,在 Hea

基于heartbeat的单播方式实现tomcat高可用

1.节点规划 在master.backup节点上添加eth0.eth1两网卡,具体添加过程,参考“基于VMware为CentOS 6.5配置两个网卡” 2.IP规划   master backup eth0 192.168.46.128 192.168.46.130 eth1 192.168.46.129 192.168.46.131 上面这个表格说明master节点中的eth0网卡的IP是192.168.46.128,eth1网卡的IP是192.168.46.129:backup节点中eth0

Linux基于heartbeat配置httpd高可用服务

Heartbeat是一个基于Linux开源的,被广泛使用的高可用集群系统.我们可以基于Heartbeat构建web高可用服务环境.本文在CentOS 6.5下做了一个简单示例,并对其日志进行了初步分析,供大家参考. 有关Heartbeat的相关知识,可以参考: Heartbeat 集群组件概述 Heartbeat 安装及配置 一.配置host解析及网络 ###主机名配置,与/etc/hosts中的解析两者配置保持一致 [[email protected] ~]# more /etc/syscon

Heartbeat v2 + CRM + heartbeat-ldirectord实现LVS高可用

一.简介 heartbeat v2 版的资源管理器(CRM)就是crm,废弃了haresouce.由于crm的配置文件都是xml格式的,没有xml功底的很难驾驭,因此我们可以使用gui的方式来配置,从而让gui来帮我们将配置文件转化为xml格式的.heartbeat保存cib.xml的位置如下:/var/lib/heartbeat/crm/cib.xml heartbeat-ldirectord是专门为lvs设计的,它可以实现lvs的配置,不需要通过ipvsadm去管理,ldirectord的配

Heartbeat V2版本基于ha-gui做高可用

一.Heartbeat介绍 请点击查看详细介绍 Heartbeat V1版本配置请点击 二.环境准备 1.配置主机名,两台主机相同 [[email protected] ~]# cat /etc/hosts 127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4 ::1         localhost localhost.localdomain localhost6 localhost6.l

高可用集群软件Heartbeat介绍

一.Heartbeat的定义 Heartbeat 项目是 Linux-HA 工程的一个组成部分,也是目前开源HA项目中最成功的一个例子,Linux-HA的全称是High-Availability Linux,这个开源项目的目标是:通过社区开发者的共同努力,提供一个增强linux可靠性(reliability).可用性(availability)和可服务性(serviceability)(RAS)的群集解决方案,它实现了一个高可用集群系统.心跳服务和集群通信是高可用集群的两个关键组件,在 Hear

基于heartbeat v1配置mysql和httpd的高可用双主模型

一.配置高可用集群的前提:(以两节点的heartbeat为例) ⑴时间必须保持同步 ⑵节点之间必须用名称互相通信 建议使用/etc/hosts,而不要用DNS 集群中使用的主机名为`uname -n`表示的主机名: ⑶ping node(仅偶数节点才需要) ⑷ssh密钥认证进行无障碍通信: 二.heartbeat v1的配置 程序主配置文件:ha.cf 认证密钥:authkeys, 其权限必须为组和其它无权访问: 资源配置文件:haresources /usr/share/doc/heartbe