lomg 发表于 2018-12-29 14:02:33

lvs之keepalived

  集ha,lb与一体的功能
  需要四台机器
  当某台real server把httpd进程停掉,那么director照样会把请求转发过去,这样就造成了某些请求不正常。所以需要有一种机制用来检测real server的状态,这就是keepalived。它的作用除了可以检测rs状态外,还可以检测备用director的状态,也就是说keepalived可以实现ha集群的功能,当然了也需要一台备用director.
  备用director也需要安装一下keepalived软件
  yum install -y keepalived
  安装好后,编辑配置文件
  ipvsadm -C
  vim /etc/keepalived/keepalived.conf   //加入如下:
  vrrp_instance VI_1 {
  state MASTER   #备用服务器上为 BACKUP
  interface eth0
  virtual_router_id 51
  priority 100#备用服务器上为90
  advert_int 1
  authentication {
  auth_type PASS
  auth_pass 1111
  }
  virtual_ipaddress {
  192.168.1.128
  }
  }
  virtual_server 192.168.1.128 80 {
  delay_loop 6                  #(每隔10秒查询realserver状态)
  lb_algo wlc                  #(lvs 算法)
  lb_kind DR                  #(Direct Route)
  persistence_timeout 60      #(同一IP的连接60秒内被分配到同一台realserver)
  protocol TCP                #(用TCP协议检查realserver状态)
  

  real_server 192.168.1.122 80 {
  weight 100               #(权重)
  TCP_CHECK {
  connect_timeout 10       #(10秒无响应超时)
  nb_get_retry 3
  delay_before_retry 3
  connect_port 80
  }
  }
  real_server 192.168.1.124 80 {
  weight 100
  TCP_CHECK {
  connect_timeout 10
  nb_get_retry 3
  delay_before_retry 3
  connect_port 80
  }
  }
  }
  

  以上为主director的配置文件,从director的配置文件只需要修改
  state MASTER-> state BACKUP
  priority 100 -> priority 90
  配置完keepalived后,需要开启端口转发(主从都要做):
  echo 1 > /proc/sys/net/ipv4/ip_forward
  然后,两个rs上执行 /usr/local/sbin/lvs_dr_rs.sh 脚本
  最后,两个director上启动keepalived服务(先主后从):
  /etc/init.d/keepalived start
  另外,需要注意的是,启动keepalived服务会自动生成vip和ipvsadm规则,不需要再去执行上面提到的/usr/local/sbin/lvs_dr.sh 脚本。
  




页: [1]
查看完整版本: lvs之keepalived