LVS-DR+keepalived实现www/mysql服务器负载均衡实验

本文涉及的产品
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
传统型负载均衡 CLB,每月750个小时 15LCU
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
简介:
前言:在上次用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档,写的不错。


本文转自xcjgutong 51CTO博客,原文链接:http://blog.51cto.com/xuchengji/335595
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
计算机网络:思科实验【1-访问WEB服务器】
计算机网络:思科实验【1-访问WEB服务器】
计算机网络:思科实验【1-访问WEB服务器】
|
3月前
|
网络协议 Shell 网络安全
实验目的1.编译安装httpd2.优化路径3.并将鲜花网站上传到web服务器为网页目录4.在客户机访问网站http://www.bdqn.com
实验目的1.编译安装httpd2.优化路径3.并将鲜花网站上传到web服务器为网页目录4.在客户机访问网站http://www.bdqn.com
196 0
|
3月前
|
负载均衡 网络协议 算法
LVS 负载均衡部署的三种模式 与搭建dr模式具体步骤
LVS 负载均衡部署的三种模式 与搭建dr模式具体步骤
|
11天前
|
负载均衡 网络协议
使用LVS搭建集群实现负载均衡(二)安装使用
【8月更文挑战第8天】使用LVS搭建集群实现负载均衡(二)安装使用
28 4
|
11天前
|
存储 负载均衡 算法
使用LVS搭建集群实现负载均衡(一)
【8月更文挑战第8天】使用LVS搭建集群实现负载均衡
32 4
|
3月前
|
弹性计算 Linux 测试技术
ECS网页问题之认证实验考不了如何解决
ECS(Elastic Compute Service,弹性计算服务)是云计算服务提供商提供的一种基础云服务,允许用户在云端获取和配置虚拟服务器。以下是ECS服务使用中的一些常见问题及其解答的合集:
|
1月前
|
负载均衡 网络协议 算法
使用IPVSADM配置LVS负载均衡
使用IPVSADM配置LVS负载均衡
|
3月前
|
负载均衡 网络协议
NAT模式 LVS负载均衡部署
NAT模式 LVS负载均衡部署
|
3月前
|
负载均衡 算法 网络协议
LVS、Nginx和HAProxy负载均衡器对比总结
LVS、Nginx和HAProxy负载均衡器对比总结
|
3月前
【计网·湖科大·思科】实验一 熟悉仿真软件及访问WEB服务器
【计网·湖科大·思科】实验一 熟悉仿真软件及访问WEB服务器
39 0