设为首页 收藏本站
查看: 619|回复: 0

[经验分享] 基于LVS+heartbeat的web负载均衡

[复制链接]

尚未签到

发表于 2019-1-6 08:01:42 | 显示全部楼层 |阅读模式
  文档配置环境:
  主调度器A192.168.0.111(eth0) 内网:172.16.1.1(eth1)
  从调度器B192.168.0.112(eth0) 内网:172.16.1.2(eth1)
  真实服务器R1192.168.0.113
  真实服务器R2192.168.0.114
  虚拟IP(VIP)192.168.0.110
  准备工作:调度器AB/etc/hosts内加入以下内容:以便解析
  vi /etc/hosts
  192.168.0.111 quxinyao
  192.168.0.112 slave
  配置主调度器A:
  1.安装libnet-1.1.2.1.tar.gz
  (1)tar –zxvf libnet-1.1.2.1.tar.gz
  (2)cd libnet-1.1.2.1
  (3)./configure
  (4)make && make install
  libnet安装完成。
  2.安装kernel-devel
  (1)首先查看内核:uname –a
  (2)然后在安装对应内核的kernel-devel
  rpm -ivh kernel-devel-2.6.9-78.EL.i686.rpm
  (3)将当前使用内核连接到/usr/src/linux
  ln -s /usr/src/kernels/2.6.9-78.EL-i686 /usr/src/linux
  3.安装ipvsadm-1.24.tar.gz
  (1)tar –zxvf ipvsadm-1.24.tar.gz
  (2)cd ipvsadm-1.24
  (3)make && make install
  ipvsadm安装完成。
  4.安装pkgconfig
  rpm -ivh /media/cdrom/RedHat/RPMS/pkgconfig-0.15.0-3.i386.rpm
  5.安装glib2-devel
  rpm -ivh /media/cdrom/RedHat/RPMS/glib2-devel-2.4.7-1.i386.rpm
  6.安装heartbeat-2.0.2.tar.gz
  (1)tar –zxvf heartbeat-2.0.2.tar.gz
  (2)cd heartbeat-2.0.2
  (3)./ConfigureMe configure --disable-swig --disable-snmp-subagent
  (4)make && make install
  heartbeat安装完成。
  7.配置lvs启动脚本
  本文档采用的是lvs-DR模式,该模式的特点是客户端的请求从调度器进入分配到真实服务器,然后真实服务器的响应是直接交付给客户端的。
  配置如下:
  vi /etc/init.d/lvs
  #!/bin/sh
  #chkconfig: 2345 20 80
  # description: start LVS of Directorserver
  VIP1=192.168.0.110 //指定虚拟IP
  RIP1=192.168.0.111
  RIP2=192.168.0.112
  RIP3=192.168.0.113
  RIP4=192.168.0.114
  // RIP1-RIP4为真实服务器IP,如有更多真实服务器则可以添加更多,如RIP5等
  . /etc/rc.d/init.d/functions
  case "$1" in
  start)
  echo " start LVS of DirectorServer"
  # set the Virtual IP Address
  /sbin/ifconfig eth0:0 $VIP1 broadcast $VIP1 netmask 255.255.255.255 up //LVS启动时添加VIP的网口eth0:0
  /sbin/route add -host $VIP1 dev eth0:0
  #Clear IPVS table
  /sbin/ipvsadm -C
  #set LVS
  /sbin/ipvsadm -A -t $VIP1:80 -s lc
  /sbin/ipvsadm -a -t $VIP1:80 -r $RIP1:80 -g
  /sbin/ipvsadm -a -t $VIP1:80 -r $RIP2:80 -g
  /sbin/ipvsadm -a -t $VIP1:80 -r $RIP3:80 -g
  /sbin/ipvsadm -a -t $VIP1:80 -r $RIP4:80 -g
  #Run LVS //使用ipvsadm来转发客户端请求,-s lc 为最小连接数算法,-g指的是采用DR模式。有几个真实服务器就添加几条记录。
  /sbin/ipvsadm
  #end
  ;;
  stop)
  echo "close LVS Directorserver"
  /sbin/ipvsadm –C //关闭时清除ipvsadm表
  ;;
  *)
  echo "Usage: $0 {start|stop}"
  exit 1
  esac
  注意:这个资源脚本不要使用chkconfig管理,放入/etc/init.d内即可。
  用chkconfig管理使其随系统启动
  chkconfig --add lvs
  chkconfig --level 35 lvs on
  8.配置heartbeat
  首先创建所需的用户和组
  groupadd haclient
  useradd -g haclient hacluster
  (1)cd heartbeat-2.0.4
  (2)cp doc/ha.cf doc/haresources doc/authkeys /etc/ha.d/
  (3)cp ldirectord/ldirectord.cf /etc/ha.d/
  heartbeat的主目录是:/etc/ha.d/
  ha.cf为heartbeat的主配置文件,配置如下,其余可以按照默认配置:
  (4)vi /etc/ha.d/ha.cf(下面所用的选项均将前面的注释去掉)
  日志文件位置 logfile /var/log/ha-log
  指定主备服务器多久发送一次心跳 keepalive 2
  指定30秒没有收到对方心跳就认为对方已经DOWN机 deadtime 30
  10秒没有收到心跳,便发出警报。warntime 10
  对方DOWN后120秒重新检测一次。initdead 120
  指定监听端口 udpport 694
  心跳监听网口,这里为eth1
  bcast eth1 //在文件中把第一个bcast前面的#去掉,还要把后面的#linux去掉
  主节点恢复后,自动收回资源。 auto_failback on
  指定主备服务器的主机名称,即在hosts文件中指定的。
  第一个node为主服务器,第二个node为备服务器。
  node quxinyao //服务器的主机名
  node slave
  当192.168.0.1(网关),192.168.0.111这两个IP都不能ping通时对方即开始接管资源。
  ping_group group1 192.168.0.1 192.168.0.111
  启用ipfail脚本 respawn root /usr/lib/heartbeat/ipfail
  指定运行ipfail的用户。 apiauth ipfail gid=root uid=root
  主配置文件配置完成
  9.haresources文件配置,这个文件指定虚拟IP和该主机控制的资源脚本
  内容如下:
  vi /etc/ha.d/haresources
  # quxinyao为主调度器主机名,192.168.0.110为虚拟IP,
  lvs ldirectord 为heartbeat控制的资源脚本,这些脚本预先要放在
  /etc/init.d中。
  quxinyao 192.168.0.110 lvs ldirectord
  资源文件配置完成。
  用chkconfig管理使其随系统启动
  chkconfig --add ldirectord
  chkconfig --level 35 ldirectord on
  10.ldirectord.cf是ldirectord进程的配置文件,该进程用来监视真实服务器的运行状况,如果真实服务器不能响应请求则把它排除在转发列表外。
  vi /etc/ha.d/ldirectord.cf
  设置真实服务器的超时时间 checktimeout=30
  监视真实服务器的时间间隔 checkinterval=10
  如全部真实服务器失败,则转发至本地 fallback=127.0.0.1:80
  改变配置文件内容,不需要重新ldirectord autoreload=yes
  指定日志位置 logfile="/var/log/ldirectord.log" quiescent=no
  指定虚拟IP virtual=192.168.0.110:80
  指定真实服务器IP及监听端口
  real=192.168.0.111:80 gate
  real=192.168.0.112:80 gate
  real=192.168.0.113:80 gate
  real=192.168.0.114:80 gate
  fallback=127.0.0.1:80 gate
  service=http
  监听测试页面名称,这个页面放入真实服务器web服务的根目录
  request="test.html"
  指定测试页面返回内容
  receive="Test Page"
  virtualhost=v.abc.cn
  指定转发算法
  scheduler=lc //这里的算法要和LVS脚本的算法一样
  protocol=tcp
  ldirectord.cf配置完成。
  11.authkeys文件配置
  authkeys文件的作用是用来设置心跳信息的加密方式。
  vi /etc/ha.d/authkeys
  auth 1
  1 crc
  这里的设置是使用crc循环冗余校验,并不采用加密的方式。
  这个文件的权限必须是600。
  整个lvs和heartbeat配置完成。
  12.从调度器B的配置与A完全一样。
  Heartbeat应用chkconfig进行管理,将其随机启动。
  chkconfig --add heartbeat
  chkconfig --level 35 heartbeat on
  13.配置真实服务器脚本,在每台真实服务器的/etc/init.d目录内放置realserver脚本,这里主备调度器同时也为真实服务器。
  vi /etc/init.d/realserver
  #!/bin/bash
  #
  # lvsdrrs init script to hide loopback interfaces on LVS-DR
  # Real servers. Modify this script to suit
  # your needs. You at least need to set the correct VIP address(es).
  #
  # Script to start LVS DR real server.
  #
  # chkconfig: 2345 20 80
  # description: LVS DR real server
  #
  # You must set the VIP address to use here:
  #指定虚拟IP
  VIP=192.168.0.110
  host=`/bin/hostname`
  case "$1" in
  start)
  # Start LVS-DR real server on this machine.
  /sbin/ifconfig lo down
  /sbin/ifconfig lo 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
  /sbin/ifconfig lo:0 $VIP netmask 255.255.255.255 up
  /sbin/route add -host $VIP dev lo:0
  ;;
  stop)
  # Stop LVS-DR real server loopback device(s).
  /sbin/ifconfig lo:0 down
  ;;
  status)
  # Status of LVS-DR real server.
  islothere=`/sbin/ifconfig lo:0 | grep $VIP`
  isrothere=`netstat -rn | grep "lo" | grep $VIP`
  if [ ! "$islothere" -o ! "$isrothere" ];then
  # Either the route or the lo:0 device
  # not found.
  echo "LVS-DR real server Stopped."
  else
  echo "LVS-DR Running."
  fi
  ;;
  *)
  # Invalid entry.
  echo "$0: Usage: $0 {start|status|stop}"
  exit 1
  ;;
  esac
  14.真实服务器的配置脚本完成,将脚本放置到每个真实服务器/etc/init.d中(包括主从调度器),并用chkconfig进行管理,让其随机启动。
  chkconfig --add realserver
  chkconfig --level 35 realserver on
  15.最后将heartbeat在主从调度器上,realserver在真实服务器上开启,测试其是否切换与转发正常工作。
  用ipvsadm –ln查看服务器列表
  用查ipvsadm -Lcn看访问日志


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-659815-1-1.html 上篇帖子: 通过lvs+heartbeat实现对mysql的负载均衡高可用 下篇帖子: Heartbeat v2+heartbeat
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表