热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

heartbeat介绍与基于heartbeat+lvs

heartbeat工作原理通过修改Heartbeat的配置文件,可以制定那一台Heartbeat服务器作为主服务器,则另一台将自动成为热备服务器。然后在热备服务器上配置Heartb

heartbeat工作原理

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

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

准备以下几台虚拟机serverX

ip:172.25.39.Xdomain:serverX.example.comHeartbeat配置

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            #查看状态,正确开启时csConneced

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

cat /proc/drbd            #查看状态,正确同步时dsUpToDate

相关指令 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            #正确结果,只会绑定server1MAC

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

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


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补上。



heartbeat介绍与基于heartbeat+lvs


推荐阅读
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 本文介绍了RPC框架Thrift的安装环境变量配置与第一个实例,讲解了RPC的概念以及如何解决跨语言、c++客户端、web服务端、远程调用等需求。Thrift开发方便上手快,性能和稳定性也不错,适合初学者学习和使用。 ... [详细]
  • 在project.properties添加#Projecttarget.targetandroid-19android.library.reference.1..Sliding ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • 本文介绍了在mac环境下使用nginx配置nodejs代理服务器的步骤,包括安装nginx、创建目录和文件、配置代理的域名和日志记录等。 ... [详细]
author-avatar
吴佑霖雅旺
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有