热门标签 | 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


推荐阅读
  • 本文详细介绍了Linux系统中用于管理IPC(Inter-Process Communication)资源的两个重要命令:ipcs和ipcrm。通过这些命令,用户可以查看和删除系统中的消息队列、共享内存和信号量。 ... [详细]
  • packagecom.panchan.tsmese.utils;importjava.lang.reflect.ParameterizedType;importjava.lang. ... [详细]
  • 解决SQL Server数据库sa登录名无法连接的问题
    在安装SQL Server数据库后,使用Windows身份验证成功,但使用SQL Server身份验证时遇到问题。本文将介绍如何通过设置sa登录名的密码、启用登录名状态以及开启TCP协议来解决这一问题。 ... [详细]
  • LDAP服务器配置与管理
    本文介绍如何通过安装和配置SSSD服务来统一管理用户账户信息,并实现其他系统的登录调用。通过图形化交互界面配置LDAP服务器,确保用户账户信息的集中管理和安全访问。 ... [详细]
  • 如果应用程序经常播放密集、急促而又短暂的音效(如游戏音效)那么使用MediaPlayer显得有些不太适合了。因为MediaPlayer存在如下缺点:1)延时时间较长,且资源占用率高 ... [详细]
  • 蒜头君的倒水问题(矩阵快速幂优化)
    蒜头君将两杯热水分别倒入两个杯子中,每杯水的初始量分别为a毫升和b毫升。为了使水冷却,蒜头君采用了一种特殊的方式,即每次将第一杯中的x%的水倒入第二杯,同时将第二杯中的y%的水倒入第一杯。这种操作会重复进行k次,最终求出两杯水中各自的水量。 ... [详细]
  • 经过一年的思考,我发现自己对开发的兴趣并不浓厚,而对算法研究则更加热衷。本文将探讨开发与算法之间的本质差异,并分享我的未来学习计划。 ... [详细]
  • 本文介绍了Java编程语言的基础知识,包括其历史背景、主要特性以及如何安装和配置JDK。此外,还详细讲解了如何编写和运行第一个Java程序,并简要介绍了Eclipse集成开发环境的安装和使用。 ... [详细]
  • Bootstrap 缩略图展示示例
    本文将展示如何使用 Bootstrap 实现缩略图效果,并提供详细的代码示例。 ... [详细]
  • 本文介绍了一种支付平台异步风控系统的架构模型,旨在为开发类似系统的工程师提供参考。 ... [详细]
  • 使用 Git Rebase -i 合并多个提交
    在开发过程中,频繁的小改动往往会生成多个提交记录。为了保持代码仓库的整洁,我们可以使用 git rebase -i 命令将多个提交合并成一个。 ... [详细]
  • Manacher算法详解:寻找最长回文子串
    本文将详细介绍Manacher算法,该算法用于高效地找到字符串中的最长回文子串。通过在字符间插入特殊符号,Manacher算法能够同时处理奇数和偶数长度的回文子串问题。 ... [详细]
  • 自定义滚动条美化页面内容
    当页面内容超出显示范围时,为了提升用户体验和页面美观,通常会添加滚动条。如果默认的浏览器滚动条无法满足设计需求,我们可以自定义一个符合要求的滚动条。本文将详细介绍自定义滚动条的实现过程。 ... [详细]
  • importpymysql#一、直接连接mysql数据库'''coonpymysql.connect(host'192.168.*.*',u ... [详细]
  • 微软推出Windows Terminal Preview v0.10
    微软近期发布了Windows Terminal Preview v0.10,用户可以在微软商店或GitHub上获取这一更新。该版本在2月份发布的v0.9基础上,新增了鼠标输入和复制Pane等功能。 ... [详细]
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社区 版权所有