准备工作

1 注意事项,集群事物信息传递靠节点名称来识别,靠IP来传递;

对于高可用节点名称的解析使用host文件,名称和uname -n 保持一致,不建议使用DNS解析

修改hosts,network文件中的主机名,hostname更改主机名

测试:通过主机名可以ping通

2 SSH互信通信,第一个节点自我启动,第二个节点需要在第一个节点远程ssh来操作

生成密钥文件:

# ssh-keygen -t rsa -f ~/.ssh/id_rsa -P ""

# ssh-copy-id -i ./.ssh/id_rsa.pub root@node2.hiyang.com

3 时间同步

可以把其中一台配置成时间服务器


heart相关下载

 heartbeat官网

 epel


实验环境:linux 为CentOs 5.1

1 安装

yum install -y epel-release

yum install -y heartbeat

2 目录说明

/etc/ha.d/{authkeys ha.cf haresources}配置文件

/etc/ha.d/rc.d/ask_resources

/etc/ha.d/rc.d/hb_takeover

/etc/ha.d/rc.d/ip-request

/etc/ha.d/rc.d/ip-request-resp

/etc/ha.d/rc.d/status

/etc/ha.d/resource.d 资源代理目录

3 node1配置文件

配置文件,在/etc/ha.d下未提供配置文件,可以

# rpm -ql heartbeat | grep -E “authkeys|ha.cf|haresources”

/usr/share/doc/heartbeat-2.1.4/authkeys

从中复制需要的配置文件到/etc/ha.d/下

3.1 heartbeat通信加密方法 authkeys 600

# chmod 600 authkeys

生成authkeys使用的随机数

# dd if=/dev/random count=1 bs=512 | md5sum

配置如下

# vim authjeys

auth 3

3 md5 0f58dcf475d107b8eb8c96499d384e84

3.2 服务主配置文件 ha.cf

只改两项:bcast和node 

nodenode1.hiyang.com

nodenode2.hiyang.com

bcasteth0# Linux 

3.3 资源管理配置文件 haresources

# node1  10.0.0.170 Filesystem::/dev/sda1::/data1::ext2

node1.hiyang.com IPaddr::192.168.8.110/24/eth0 Filesystem::192.168.8.111:/web/htdocs::/var/www/html::nfs httpd

#此处高可用了FIP、文件系统(NFS)、httpd服务

说明:主节点名称 FIP 资源代理::资源参数,资源代理间用空格隔开

资源代理寻找顺序/etc/ha.d/resource.d/ --> /etc/init.d

fip是否配置在和fip同一网段的网卡上的判定程序

/usr/lib/heartbeat/findif

4 node2配置

node2上,heartbeat配置,和node1完全相同,直接scp,注意保留文件属性

# scp -p authkeys ha.cf haresources node2.hiyang.com:/etc/ha.d

5 启动heartbeat

4.1 先手动测试网页是否可以正常打开,正常的话关闭httpd;

4.2 node1

# service heartbeat start

# ssh node2.hiyang.com “service heartbeat start

6 测试

    node1和node2上提供不同的页面文件,以便测试区分

6.1 浏览器访问fip,httpd服务在node1上,OK

6.2 在node1上执行/usr/lib/heartbeat/hb_standby,此时,node1宕掉

6.3 浏览器访问fip,看网页服务是否转移到node2;在node2上执行/usr/lib/heartbeat/hb_standby,此时,node2宕掉,服务转回node1

6.4 也可以通过ifcofnig,查看fip的转移


提供NFS,此处在另一台linux上,共享了一个目录

# vim /etc/exports

/web/htdocs 192.168.8.0/24(rw,async)

# showmount -e 192.168.8.111

Export list for 192.168.8.111:

/web/htdocs 192.168.8.0/24