前言:在上次用LVS+heartbeat+Ldirectord实现了www服务器负载均衡,这次用LVS+keepalived来实验,你为发现它实现起来比前者简单的多,只需要配置一个文件keepalived.conf文件,就可以了。如果不知道什么是keepalived那么去 http://www.keepalived.org/看看。
实验环境:
(1)realserver为ubserver2,ubserver3,IP分别为192.168.3.20和192.168.3.30
(2)主从负载均衡器为ubserver5,ubserver6; IP分别为192.168.3.50和192.168.3.60;虚拟IP为192.168.3.100,这4台机器都只装一块网卡
(3)操作系统为ubuntu server 10.4
1,主从负载均衡器为ubserver5,ubserver6的设置
安装ipvsadm及keepalived
    #sudo apt-get install ipvsadm
    #sudo apt-get install keepalived
    在/etc/keepalived下建立keepalived.conf文件
#sudo vim keepalived.conf
主负载均衡器为ubserver5 设置如下:
 
*:把配置中的所有80,替换成3306,就是对mysql的负载均衡
以下是对配置文件的解释:
1,在全局设置中
  routed_id 运行keepalived的机器的一个标识,这里是ubserver5
2,为什么要使用同步组vrrp_sync_group vg1{}?
  当机器有两个网段,一个是内网,一个是外网,每个网段开启一个vrrp实例,若vrrp配置为检查内网,那么当外网出现问题时,vrrp认为自己仍然是健康的,就不会发送MASTER与BACKUP的切换,采用同步组就是解决这个问题。这里我们只有一个vrrp的实例VIP_1。
3,什么是vrrp实例?
  就是表示在这台机器上开启了vrrp协议,可以在每个interface上开启一个实例。比如:要开启两个实例,就在机器上安装两块网块,每个网卡上开启一个vrrp实例,一个检查内网,一个外网。
  state MASTER/BACKUP 指定实例也就是一台机器的初始状态,两台机器(router)启动后,会根据priority的值竞选MASTER,高的为MASTER;所以这里的state并不表示一直是MASTER或BACKUP。
  interface 开启VRRP协议的网卡
  virtual_router_id  是VRID标记,其值在0-255,VRID是虚拟路由器的标识。这里是51
  priority  其值高的为MASTER,MASTER要高BACKUP至少50(keepalived指南是这样讲的)
  virtual_ipaddress 虚拟地址 了解了keepalived工作机制,就知道为什么要这个虚拟地址了。
  authentication 设置认证,auth_type 认证方式有两种PASS和AH,auth_pass 认证的密码
  advert_int 检查间隔,默认1秒
4,LVS的配置,都会传递给IPVSADM作为参数
  lb_algo LVS的调度算法(rr|wrr|lc|wlc|lblc|sh|dh)
        lb_kind  LVS的模式(NAT|DR|TUN)
        persistence_timeout  同一会话保持时间
  protocol 使用协议TCP或UDP
       weight 权重 默认为1,0为失效
  TCP_CHECK  TCP方式的健康检查还有如下的检查方式HTTP_GET|SSL_GET|TCP_CHECK|SMTP_CHECK|MISC_CHECK
  connect_port 健康检查的端口
  connect_timeout 连接超时的时间
  nb_get_retry 重连次数
  delay_before_retry 重连时间间隔
修改/etc/sysctl.conf文件如下:
lvs-keepalived0-3
到此主负载均衡器为ubserver5就配置完成了,从负载均衡器为ubserver6在以上配置中只做相应的改动即可。
#sudo ipvsadm –L –n
lvs-keepalved0-4
2,真机ubserver2,ubserver3的配置
只需添加虚拟IP,修改/etc/sysctl.conf文件即可
#sudo ifconfig lo:0 192.168.3.100 netmask 255.255.255.0 broadcast 192.168.3.100 up
  #sudo route add –host 192.168.3.100 dev lo:0
/etc/sysctl.conf内容与负载均衡器为ubserver5的内容相同,只是如果网卡名不同时要注意修改。
*:在这两台机器安装mysql后,都新增一个用户testkeep,密码为password,拥有超级用户权限。用以下命令
#sudo mysql -uroot -p110
>grant all on *.* to 'testkeep'@'%' identified by 'password';
>flush privileges;
在默认情况下,mysql只允许在本机登录,不允许在其它机器中登录,所以要做以下修改:
在/etc/mysql/my.cnf中找到 bind-address = 127.0.0.1 修改为 bind-address = 0.0.0.0
否则,在其它机器上远程连接时会无法登录,出现以下提示
MySQL Error Number 2003 Can't connect to MySQL server on 192.168.3.20(10060)
 
3,测试及模拟故障
(1)先在浏览器中查看 http://192.168.3.100是否可以轮流访问ubserver2,ubserver3的www服务器,看主从均衡器是否工作正常。能分别访问,则实验成功。
(2)把主负载均衡器为ubserver5关闭,看从负载均衡器为ubserver6能否接管其任务。查看ubserver6的日志文件
#sudo tail /var/log/messages
lvs-keepalived1
从中可以看出,刚开始ubserver6是backup状态,当ubserver5关闭后,ubserver6进入MASTER状态。再把ubserver5打开,看ubserver6能否由MASTER转变为BACKUP,若能,则实验目标达成。
(3) 测试MYSQL时,在其它机器远程登录多次,看能否轮流登录ubserver2,ubserver3上
#sudo mysql -h 192.168.3.100 -u testkeep -p password
为了方便判别是否登录到不同机器,在这两台机器中分别建立不同的数据库testno1,testno2;多次登录应该轮流访问到这两台机器上。经过实验按以上配置是可以的,也可以把mysql配置成集群http://xuchengji.blog.51cto.com/160472/330655(ubuntu server 8.04下mysql5.0集群实验),这样就实现了lvs-DR+keepalived+mysql5.0集群,经过实验,按照这两片文中的配置是成功的。
总结:用LVS+keepalived比较简单,不像LVS+heartbeat+ldirectord那样要配置4个文件,还要写脚本。这给以后的维护也带来方便。过程中在负载均衡器为ubserver5上用#sudo ipvsadm –L –n 看到与www服务器连接不上也就是权重为“0”,搞了好长时间原来是网卡设置的不对(在VMware workstation里做的实验)。有一本叫”keepalived权威指南“的PDF档,写的不错。