准备工作
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