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

[经验分享] linux高可用(HA)keepalived 主从备份

[复制链接]

尚未签到

发表于 2018-12-29 12:27:16 | 显示全部楼层 |阅读模式
  利用keepalived可以实现对linux服务器的高可用性,即主从备份,一台线上服务器出故障另外一台服务器顶替它,当出故障的服务器恢复时又自动转换成主服务器,顶替它的服务器再次转换为备胎,当主服务器宕机、主服务器网卡坏掉、甚至主服务器服务挂掉(要用脚本监控实现转换)都可以自动切换到从服务器,下面针对这三种故障进行模拟。
  实验环境:2台rhel5.6,keepalived-1.1.20.tar.gz
  实验过程:
  本实验以web服务为例,两台linux都安装Apache服务。
  配置yum源,做准备工作,因为本次模拟的是主从备份,所以除了keepalived配置文件有区别外其他配置均相同。在实验前,将selinux和防火墙都关掉。
  

  主服务器配置:
  [root@web1_master ~]# yum install gcc gcc-c++ openssl-devel httpd kernel-devel -y
  [root@web1_master ~]# echo "master" > /var/www/html/index.html
  [root@web1_master ~]# tar zxf keepalived-1.1.20.tar.gz
  [root@web1_master ~]# cd keepalived-1.1.20/
  #./configure --sysconf=/etc/ --with-kernel-dir=/usr/src/kernels/2.6.18-238.el5-i686/
  #make &&make install
  #cp /usr/local/sbin/keepalived /usr/sbin/
  

  [root@web1_master ~]# cat /etc/keepalived/keepalived.conf
  ! Configuration File for keepalived
  

  global_defs {
  notification_email {
  acassen@firewall.loc
  failover@firewall.loc
  sysadmin@firewall.loc
  }
  notification_email_from Alexandre.Cassen@firewall.loc
  smtp_server 192.168.200.1
  smtp_connect_timeout 30
  router_id LVS_DEVEL
  }
  

  vrrp_instance VI_1 {
  state MASTER
  interface eth0
  virtual_router_id 51
  priority 100
  advert_int 1
  authentication {
  auth_type PASS
  auth_pass 1111
  }
  virtual_ipaddress {
  192.168.65.65
  }
  }
  ####将keepalived.conf配置文件修改成以上配置,即修改虚拟地址为192.168.65.65,这个虚拟地址是虚拟不存在的,用户在访问网页的时候访问的就是这个虚拟地址,本配置文件要注意修改服务器的主从状态、优先级、组id以及虚拟ip,还可以修改Email地址通知自己等。
  

  # service keepalived start
  # service httpd start
  # chkconfig --add httpd
  # chkconfig --add keepalived
  # chkconfig httpd on
  # chkconfig keepalived on
  

  从服务器配置:
  [root@web1_slave keepalived]# cat /etc/keepalived/keepalived.conf
  ! Configuration File for keepalived
  

  global_defs {
  notification_email {
  acassen@firewall.loc
  failover@firewall.loc
  sysadmin@firewall.loc
  }
  notification_email_from Alexandre.Cassen@firewall.loc
  smtp_server 192.168.200.1
  smtp_connect_timeout 30
  router_id LVS_DEVEL
  }
  

  vrrp_instance VI_1 {
  state BACKUP
  interface eth0
  virtual_router_id 51
  priority 90
  advert_int 1
  authentication {
  auth_type PASS
  auth_pass 1111
  }
  virtual_ipaddress {
  192.168.65.65
  }
  }
  #####从服务器keepalived.conf的主配置文件,优先级改为比主的优先级(100)小,这里是90.
  # echo "slave" > /var/www/html/index.html
  ######其他配置内容和主服务器相同
  当主服务器宕机或是网卡出问题,从服务器都会取代它变成主服务器
上图是当主服务器网卡重启时,在从服务器日志记录上显示从服务器先是切换成主服务器,后又切换成从服务器。

  当web站点挂了时,还想让从服务器自动切换成主服务器就需要脚本来执行。
  下面新建一个脚本,名叫check_httpd.sh ,其位置都放在主从服务器的/etc/keepalived/下面,(主从服务器使用相同的脚本,脚本放的位置也都相同,在keepalived.conf修改的地方、内容也都相同)
  下面是check_httpd.sh 脚本的内容
  [root@web1_master keepalived]# cat check_httpd.sh
  #!/bin/bash
  

  CHECK_TIME=2
  

  check()
  {
  curl http://127.0.0.1/ >/dev/null 2>&1
  ret=$?
  if [ $ret -ne 0 ];then
  return $ret;
  fi
  }
  while [ $CHECK_TIME -ne 0 ]
  do
  let "CHECK_TIME -= 1"
  check
  HTTP_OK=$?
  if [ $HTTP_OK -eq 0 ];then
  exit 0
  fi
  if [ $HTTP_OK -ne 0 ] &&  [ $CHECK_TIME -eq 0 ]
  then
  exit 1
  fi
  done
  修改主服务器keepalived.conf配置文件,结果如下:
  [root@web1_master keepalived]# cat keepalived.conf
  ! Configuration File for keepalived
  

  global_defs {
  notification_email {
  acassen@firewall.loc
  failover@firewall.loc
  sysadmin@firewall.loc
  }
  notification_email_from Alexandre.Cassen@firewall.loc
  smtp_server 192.168.200.1
  smtp_connect_timeout 30
  router_id LVS_DEVEL
  }
  

  vrrp_script check_http {
  script "/etc/keepalived/check_httpd.sh"
  weight -5
  interval 1
  }
  

  vrrp_instance VI_1 {
  state MASTER
  interface eth0
  virtual_router_id 51
  priority 100
  advert_int 1
  track_script {
  check_http
  }
  authentication {
  auth_type PASS
  auth_pass 1111
  }
  virtual_ipaddress {
  192.168.65.65
  }
  }
  修改从服务器keepalived.conf配置文件,结果如下:
  [root@web1_slave keepalived]# cat keepalived.conf
  ! Configuration File for keepalived
  

  global_defs {
  notification_email {
  acassen@firewall.loc
  failover@firewall.loc
  sysadmin@firewall.loc
  }
  notification_email_from Alexandre.Cassen@firewall.loc
  smtp_server 192.168.200.1
  smtp_connect_timeout 30
  router_id LVS_DEVEL
  }
  

  vrrp_script check_http {
  script "/etc/keepalived/check_httpd.sh"
  weight -5
  interval 1
  }
  

  vrrp_instance VI_1 {
  state BACKUP
  interface eth0
  virtual_router_id 51
  priority 90
  advert_int 1
  track_script {
  check_http
  }
  authentication {
  auth_type PASS
  auth_pass 1111
  }
  virtual_ipaddress {
  192.168.65.65
  }
  }
  分别重启两台服务器的keepalived服务
  #service keepalivedrestart
  到这里,如果主服务器的web程序出现故障,则从服务器会在1秒钟后自动切换成主服务器,当主服务器恢复时,从服务器会自动切换成备胎,主服务器依然是主服务器。
  至此,linux高可用性(HA_keepalived)配置完成。




运维网声明 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-657249-1-1.html 上篇帖子: keepalived与lvs结合使用配置实例 下篇帖子: keepalived源码安装及编译遇到的错误
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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