LVS之高可用性群集实现

高可用性(HA)技术能自动检测服务器节点和服务进程错误、失效,并且当发生这种情况时能够自动适当地重新配置系统,使得集群中的其他节点能够自动承担这些服务,以实现服务不中断

HA实际上是两台(或更多)计算机通过一定方式互相监听,实现热备份。当其中Primary server出现问题时,Standby server能够自动立即接替工作,使用户感觉不到停机。在Primary server恢复正常之后,Standby server又会把工作还给Primary server。

ldirectord+heartbeat

“ldirectord”(Linux Director Daemon)是Jacob Rief编程实现的一个独立进程,以实现对服务和物理服务器的监测,广泛地用于http和https服务。

“ldirectord”安装简单,能很好地与“heartbeat”配合工作。“ldirectord”程序包含在“ipvs”包中的“contrib”目录中。

以下是“ldirectord”的一些优点:

“ldirectord”是专门撰写的LVS监测程序。

它从/etc/ha.d/xxx.cf文件中读取所有关于IPVS路由表的配置信息。当“ldirectord”运行起来后,IPVS路由表将会被适当地配置。

可以将Virtual service配置放在多个配置文件中,所以可以单独修改某一种服务的参数,而不影响其他的服务。“ldirectord”能被“heartbeat”轻松地管理----启动、关闭。

将“ldirectord”放到/etc/ha.d/resource.d/目录下,然后在/etc/ha.d/haresources中增加一行:

node1 IPaddr::10.0.0.3

ldirectord::www ldirectord::mail

“ldirectord”能够手动开启、关闭。可以在无备份负载均衡器的LVS集群中使用它。

Xlinux的LATCH HA方案

正如前面所述,高可用性解决方案(HA)是极为重要的,许多厂商为此投入了大量的研究。其中,Xlinux发行版就提供LATCH HA解决方案。下面我们就一起看看LATCH HA方案。

LATCH HA解决方案的最典型的系统结构:两台主机A、B共享一个磁盘阵列,A为工作机,B为备份机。它们之间用一根心跳线来连接,这称为“心跳检测”,主要通过一条RS232检测链路来完成。LATCH HA也采用了用Ping来验证系统宕机的方法。安装在主机上的HA软件通过心跳线来实时监测对方的运行状态,一旦正在工作的主机A因为各种硬件故障导致系统发生故障,主机B立即投入工作。怎么样,与IBM的HACMP有点像吧!

LATCH HA实现了“高可靠性共享存储”架构。该架构由两个或三个冗余服务器、一个共享冗余磁盘阵列、一个可选DBMS及LATCH HA系统软件构成。在LATCH HA的保护下,企业的计算机系统能够提供不间断的信息服务,避免由于硬件故障或日常维护所带来的宕机,因而能够保障最佳的可靠性及最大程度地减少宕机时间。

方案应用

LATCH HA能够应用在各种集中式、客户机/服务器模式或OLTP系统中。同时其与市场上各种主流的数据库系统与OLTP软件(如:Oracle、SYBASE、Informix、Tuxedo)也都保持兼容。LATCH HA同时提供了各种应用程序接口。因此,客户能够在其私有软件中集成各种功能来保证系统的高可靠性。

LATCH HA /HS2000 在线待机模式

在这种模式下,一个服务器作为主服务器。正常情况下其承当所有的服务。另外一台服务器作为待机服务器(正常情况下除了监控主服务器的状态,不进行其他的操作)。一旦主服务器宕机,待机服务器就接手工作,成为新的主服务器。客户仍然可以拥有同样的服务器IP地址、NFS、数据、数据库及其他……这种应用模式近似于上面介绍的典型应用模式(两台服务器实际上是在完成同一个功能应用),安装在主机上的HA软件通过心跳线来实时监测对方的运行状态,一旦正在工作的主机A因为各种硬件故障,如电源失效、主要部件失效或者启动盘失效等导致系统发生故障,主机B立即投入工作。

案例

实现高可用性的服务器与负载均衡的服务相结合

拓扑图

主机wj1.a.com

编辑

vim /etc/sysconfig/network

vim /etc/hosts

安装 高可用性群集应用软件 heartbeat

cd /usr/share/doc/heartbeat-2.1.4/

拷贝文件

cd /etc/ha.d

vim ha.cf

vim haresource

dd if=/dev/random bs=512 count=1 |openssl md5 加密

vim authkeys

Ipvsadm 配置负载均衡

保存 查看

Wj2.a.com 配置跟wj1.a.com 一样

Real1 real2配置请参考上一篇配置一样

连接好四台服务器 之后打开wj1 wj2 服务器的heartbeat服务

确定ipvsadm是关闭的

可以看到wj1首先是活动的

可以访问web服务器

Ipvsadm也自动打开了

并且是轮询访问

把wj1的heartbeat关掉

Web依旧访问并且wj2的ipvsadm打开

访问real1也不会间断

Wj1的ipvsadm也会关闭

高可用性的服务器与负载均衡的服务相结合

具有探测服务功能的高性能服务器

当有一个服务消失的时候 ipvsadm的列表上那个服务就自动消失

`在wj1 wj2上安装软件rpm -ivh heartbeat-ldirectord

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

文件ha.cf && authkeys编辑和上面一样 如下

vim ha.cf

bcast eth1

node node1.a.com

node node2.a.com

vim authkeys

auth 3

3 md5

dd if=/dev/random bs=512 count=1 |openssl md5

vim haresources文件配置

编辑 vim /etc/ha.d/ldirectord.cf

Wj2服务器上配置一样

Real服务器上也需要添加含有hello的test.html文件

打开wj服务器上的heartbeat服务

所以是wj1服务器在工作

能正常访问real服务器

停掉real1

Real2能正常访问

但是1.100上的服务在ipvsadm上消失了

启动real1关闭real2

Wj1上的ipvsadm服务也会改变