LVS ipvsadm+heartbeat+ldirecrtord安装配置指南

简介:
LVS ipvsadm+heartbeat+ldirecrtord安装配置指南
VIP    172.16.6.250
master 172.16.6.204
backup 172.16.6.205
real   172.16.6.206
real   172.16.6.207
提供的服务器为web端口80
用到以下程序,ipvsadm,heartbeat,ldirecrtord,libnet,mailtools 
libnet和mailtools是用来支持heartbeat和ldirecrtord的
编译安装ipvsadm
tar zxf ipvsadm-1.24.tar.gz
cd ipvsadm-1.24/
make
make install
编译安装libnet
tar zxf libnet-1.1.2.1.tar.gz 
cd libnet
./configure 
make
make install
编译安装mailtools
tar zxf MailTools-2.04.tar.gz 
cd MailTools-2.04
perl Makefile.PL 
make
make test
make install
编译安装heartbeat和ldirecrtord,他两在一起
tar jxf Heartbeat-STABLE-2-1-STABLE-2.1.4.tar.bz2 
cd Heartbeat-STABLE-2-1-STABLE-2.1.4
./ConfigureMe configure
make 
make install
编译安装完成后会在/etc/ha.d中生成一些文件,但是配置文件还是需要我们手动来创建或者cp默认的模板,位置在Heartbeat-STABLE-2-1-STABLE-2.1.4/doc中
你可以cp  authkeys,ha.cf,haresources,../ldirectord/ldirectord.cf文件到/etc/ha.d目录中
下一步我们来修改主配置文件ha.cf
vi ha.cf
debugfile /var/log/ha-debug
logfile /var/log/ha-log                             日志文件的路径
logfacility local0
keepalive 2                                         心跳检测的平率为2秒一次       
deadtime 30                                         如果30秒内没有相应心跳就做切换
warntime 10                                         指明心跳的延时为10秒做警告记录一条日志,没有其他动作
initdead 120                                        这个值设置成deadtime的两倍就可以了
udpport 694                                         数据通信的端口
bcast eth1                              eth1为心跳工作接口
ucast eth1 192.168.1.3                              检测对端心跳接口的地址
auto_failback on                                    当主节点回复后,自动切换
node    lvs_master                                  主控机计算机名 //主控机的在前面
node lvs_backup                                  备用机计算机名 //备用机的在后面
ping 172.16.6.254                                   检测网络是否正常,可以设置成网关地址
respawn root /usr/lib/heartbeat/ipfail              ipfail文件的路径
apiauth ipfail gid=root uid=root                    启用ipfail进程的用户是root
vi haresources
lvs_master 172.16.6.250  ipvs ldirectord
lvs_master只主节点的计算机名 172.16.6.250是VIP地址,ipvs和ldirecrtord是启动脚本,当主节点宕机或者备用节点宕机后都会通过这个脚本文件去启动服务,ldirecrtord脚本的位置可以再/etc/rc.d/init.d中找到,ipvs是手工创建的
vi ipvs
ipvs
#!/bin/sh
VIP=172.16.6.250
RIP1=172.16.6.206
RIP2=172.16.6.207
. /etc/rc.d/init.d/functions
case "$1" in
    start)
        echo " start LVS  "
#      # set the Virtual  IP Address
       /sbin/ifconfig eth0:0 $VIP broadcast $VIP netmask 255.255.255.255 up
#       /sbin/route add -host $VIP dev eth0:1
       /sbin/ipvsadm -C
      /sbin/ipvsadm -A -t $VIP:80 -s rr
      /sbin/ipvsadm -a -t $VIP:80 -r $RIP1:80 -g
      /sbin/ipvsadm -a -t $VIP:80 -r $RIP2:80 -g
        ;;
    stop)
        echo "close LVS Director"
        /sbin/ipvsadm -C
        ;;
    *)
        echo "Usage: $0 {start|stop}"
        exit 1
esac
配置验证文件
vi authkeys
auth 1
1 crc
一共有三个级别,自己工具情况选择吧,我用的是第一种默认的
配置ldirecrtord.cf

checktimeout=3                        检测超时
checkinterval=1                       检测间隔
autoreload=yes                        从新载入客户机
logfile="/var/log/ldirectord.log"     日志路径
logfile="local0"
quiescent=no
virtual=172.16.6.250:80               VIP地址监听80端口
 real=172.16.6.206:80 gate     真机IP地址和端口 路由模式
 real=172.16.6.207:80 gate
  fallback=127.0.0.1:80 gate
 service=http                  服务是http
 request="test.html"           这个文件一定要在real的web目录中存在,并且能够正常访问的,ipvs通过它来判断客户端是否存活
 receive="test"                文件内容
 scheduler=rr                  
 protocol=tcp                  
   checktype=negotiate
   checkport=80
把上面所有的配置文件复制到backup机上,别忘了ipvs的脚本文件也一样要复制的,唯一要改的地方是ha.cf中ucast eth1 192.168.1.3把他修改成主节点的心跳监听接口的地址
下面我来配置real
real不需要安装任何软件,我这里从网上找了一个脚本效果还不错
vi /etc/rc.d/init.d/real.sh
#!/bin/bash
 #description : start realserver
 VIP=172.16.6.250
 /etc/rc.d/init.d/functions
 case "$1" in
 start)
 echo " start LVS of REALServer"
 /sbin/ifconfig lo:0 $VIP broadcast $VIP netmask 255.255.255.255 up
 echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore
 echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce
 echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore
 echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce
 ;;
 stop)
 /sbin/ifconfig lo:0 down
 echo "close LVS Directorserver"
 echo "0" >/proc/sys/net/ipv4/conf/lo/arp_ignore
 echo "0" >/proc/sys/net/ipv4/conf/lo/arp_announce
 echo "0" >/proc/sys/net/ipv4/conf/all/arp_ignore
 echo "0" >/proc/sys/net/ipv4/conf/all/arp_announce
 ;;
 *)
 echo "Usage: $0 {start|stop}"
 exit 1
 esac
修改它的执行权限,然后用./real.sh start来启动它
在master上运行/etc/rc.d/init.d/heartbeat start和/etc/rc.d/init.d/ldirectord start这两个服务
Backup上只运行/etc/rc.d/init.d/heartbeat start 就可以了ldirectord 服务器会在主节点宕机后自动通过读取haresources文件来启动
这样整个lvs结构就配置完成了,可以通过 http://172.16.6.250来访问web了
在lvs上可以通过ipvsadm -lnc来查看具体的信息









本文转自 走在右边 51CTO博客,原文链接:http://blog.51cto.com/gsliuyang/223912,如需转载请自行联系原作者

目录
相关文章
|
8天前
|
运维 算法 Linux
LVS详解(四)——LVS安装与配置命令
LVS详解(四)——LVS安装与配置命令
15 2
|
4月前
|
负载均衡 监控 调度
Keepalived+Lvs(dr)调度器主备配置小实验
Keepalived和LVS(Linux Virtual Server)是两个常用的开源软件,通常结合使用以提供高可用性和负载均衡的解决方案。 Keepalived是一种用于实现高可用性的软件,它可以监控服务器的健康状态,并在主服务器出现故障时自动切换到备份服务器。
95 2
|
11月前
|
监控 网络协议 数据安全/隐私保护
高可用 - 05 Keepalived配置(全局配置、VRRPD、LVS)
高可用 - 05 Keepalived配置(全局配置、VRRPD、LVS)
407 0
|
负载均衡 Linux Docker
LVS+keepalived配置高可用架构和负载均衡机制(2)
LVS+keepalived配置高可用架构和负载均衡机制(2)
175 0
|
负载均衡 网络协议 前端开发
LVS+keepalived配置高可用架构和负载均衡机制(1)
LVS+keepalived配置高可用架构和负载均衡机制(1)
654 1
|
负载均衡 并行计算 算法
Lvs-负载均衡配置 NAT与DR模式
Lvs-负载均衡配置 NAT与DR模式
315 1
Lvs-负载均衡配置 NAT与DR模式
|
负载均衡
|
网络协议
KEEPALIVED 做LVS+HA实例安装与配置
--------------------------------------master------------------------------------------------------- wget http://www.
1012 0
|
移动开发 网络协议 Shell
LVS+KEEPALIVED 安装与配置实例
--------------------------------------master--------------------------------------- echo "1" > /proc/sys/net/ipv4/ip_forward wget http://www.
1268 0
|
算法 网络协议 调度
LVS ipvsadm参数详解
https://blog.csdn.net/weiyuefei/article/details/52595095 --add-service     -A        add virtual service with option     在内核的虚拟服务器表中添加一条新的虚拟服务器记录。
1121 0