博客
关于我
LVS+heartbeat 高可用LINUX服务器
阅读量:806 次
发布时间:2023-02-06

本文共 3021 字,大约阅读时间需要 10 分钟。

LVS高可用配置 - Heartbeat安装与配置指南

1. 环境准备

在开始配置之前,请确保以下环境条件已满足:

  • 操作系统:CentOS 7.6及以上版本
  • 网络:所有节点间应有互联,且IP配置正确无误
  • 用户权限:建议使用root用户执行所有操作
  • 存储空间:至少需要100MB的存储空间用于安装依赖软件

2. 安装依赖软件

安装Heartbeat和相关工具包:

yum -y install libnet* heartbeat* ipvsadm

3. 配置Heartbeat

3.1 复制默认配置文件

将Heartbeat的默认配置文件复制到/etc/ha.d/目录:

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

3.2 修改配置文件

编辑/etc/ha.d/ha.cf文件:

vim /etc/ha.d/ha.cf

添加或修改以下参数:

logfacility local0keepalive 2deadtime 30warntime 10udpport 694ucast eth0 192.168.50.8auto_failback onnode lvs.abc.comnode lvs1.abc.comping 192.168.50.8ping_group group1 192.168.50.8 192.168.50.9ping_group group1 192.168.60.8 192.168.60.9respawn hacluster /usr/lib/heartbeat/ipfailapiauth ipfail gid=haclient uid=hacluster

3.3 验证authkeys文件

编辑/etc/ha.d/authkeys文件:

vim /etc/ha.d/authkeys

确保文件中的验证信息与主从节点一致,并设置文件权限为600:

chmod 600 /etc/ha.d/authkeys

3.4 修改ldirectord.cf

编辑/etc/ha.d/ldirectord.cf文件:

vim /etc/ha.d/ldirectord.cf

添加或修改以下内容:

checktimeout 3checkinterval 1autoreload yeslogfile "/var/log/ldirectord.log"fallback 127.0.0.1:80service httpscheduler wrrprotocol tcpchecktype negotiatecheckport 80request test.htmlreceive "Test Page"

4. 编写资源脚本

创建/etc/ha.d/lvs文件:

vim /etc/ha.d/lvs

添加以下内容:

#!/bin/bash# description: start LVS of DirectorServer# Written by: NetSeek http://www.linuxtone.orgGW=192.168.50.80WEB_VIP=192.168.50.80WEB_RIP1=192.168.50.5WEB_RIP2=192.168.50.6WEB_RIP3=1.1.1.18WEB_RIP4=1.1.1.19case "$1" instart)echo "start LVS of DirectorServer"/sbin/ifconfig eth0:0 $WEB_VIP broadcast $WEB_VIP netmask 255.255.255.255 up/sbin/route add -host $WEB_VIP dev eth0:0/sbin/ipvsadm -A -t $WEB_VIP:80 -s wrr -p 3/sbin/ipvsadm -a -t $WEB_VIP:80 -r $WEB_RIP1:80 -g -w 1/sbin/ipvsadm -a -t $WEB_VIP:80 -r $WEB_RIP2:80 -g -w 2/sbin/ipvsadm -a -t $WEB_VIP:80 -r $WEB_RIP3:80 -g -w 1/sbin/ipvsadm -a -t $WEB_VIP:80 -r $WEB_RIP4:80 -g -w 1touch /var/lock/subsys/ipvsadm > /dev/null 2>&1 &/sbin/arping -I eth0 -c 5 -s $WEB_VIP $GW > /dev/null 2>&1 &echo "ipvsadm started";;stop)echo "stop LVS of DirectorServer"/sbin/ipvsadm -C/sbin/ipvsadm -Z/sbin/ifconfig eth0:0 down/sbin/route del $WEB_VIP > /dev/null 2>&1 &rm -rf /var/lock/subsys/ipvsadm > /dev/null 2>&1 &/sbin/arping -I eth0 -c 5 -s $WEB_VIP $GW > /dev/null 2>&1 &echo "ipvsadm stopped";;status)if [ ! -e /var/lock/subsys/ipvsadm ]; thenecho "ipvsadm is stopped"exit 1fiipvsadm -lnecho "..........ipvsadm is OK."fi;;*)echo "Usage: $0 {start|stop|status}"exit 1esacexit 0

5. 设置服务启动

设置Heartbeat和ipvsadm的自启动:

chkconfig heartbeat onchkconfig ipvsadm on

6. 复制配置文件到从节点

从节点的配置文件可以通过scp从主节点复制:

scp root@192.168.50.9:/etc/ha.d/* /etc/ha.d/

7. 启动Heartbeat

在所有节点上执行以下命令:

systemctl start heartbeatsystemctl enable heartbeat

8. 测试与验证

8.1 查看Heartbeat状态

tail -F /var/log/ha-logtail -F /var/log/messages

8.2 查看LVS状态

ipvsadm -L -n -stats

8.3 访问测试页面

通过浏览器访问:

  • http://192.168.50.5/test.html
  • http://192.168.50.6/test.html

9. 故障恢复

在主节点或从节点发生故障时,Heartbeat会自动切换到其他节点提供服务。

转载地址:http://ptufk.baihongyu.com/

你可能感兴趣的文章
net发布的dll方法和类显示注释信息(字段说明信息)[图解]
查看>>
Net操作配置文件(Web.config|App.config)通用类
查看>>
NeurIPS(神经信息处理系统大会)-ChatGPT4o作答
查看>>
neuroph轻量级神经网络框架
查看>>
Neutron系列 : Neutron OVS OpenFlow 流表 和 L2 Population(7)
查看>>
NEW DATE()之参数传递
查看>>
New Relic——手机应用app开发达人的福利立即就到啦!
查看>>
new 一个button 然后dispose,最后这个button是null吗???
查看>>
next项目部署到服务器pm2进程守护
查看>>
nexus上传jar
查看>>
Nexus指南中的更新强调集成和透明度的重要性
查看>>
Nexus指南已经发布
查看>>
NFinal学习笔记 02—NFinalBuild
查看>>
NFS
查看>>
NFS Server及Client配置与挂载详解
查看>>
NFS 服务配置篇
查看>>
NFS共享文件系统搭建
查看>>
nfs复习
查看>>
NFS安装配置
查看>>
NFS服务器配置-服务启动与停止
查看>>