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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
传统型负载均衡 CLB,每月750个小时 15LCU
简介:
前言:在上次用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
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8月前
|
负载均衡 应用服务中间件 Linux
企业实战(13)LVS负载均衡NAT(网络地址转换)模式实战详解(一)
企业实战(13)LVS负载均衡NAT(网络地址转换)模式实战详解(一)
128 0
|
8月前
|
存储 负载均衡 网络协议
企业实战(13)LVS负载均衡DR(直接路由)模式实战详解(二)
企业实战(13)LVS负载均衡DR(直接路由)模式实战详解(二)
141 0
|
7月前
|
负载均衡 应用服务中间件 Linux
Nginx系列教程(14) - LVS+KeepAlived+Nginx实现高性能负载均衡集群
Nginx系列教程(14) - LVS+KeepAlived+Nginx实现高性能负载均衡集群
331 0
|
27天前
|
负载均衡 网络协议 算法
LVS 负载均衡部署的三种模式 与搭建dr模式具体步骤
LVS 负载均衡部署的三种模式 与搭建dr模式具体步骤
|
27天前
|
负载均衡 网络协议
NAT模式 LVS负载均衡部署
NAT模式 LVS负载均衡部署
|
1月前
|
负载均衡 算法 网络协议
LVS、Nginx和HAProxy负载均衡器对比总结
LVS、Nginx和HAProxy负载均衡器对比总结
|
1月前
|
负载均衡 关系型数据库 MySQL
MySQL Router读写节点支持负载均衡策略
`routing_strategy`是MySQL Router配置选项,用于设定数据路由策略。可选值包括:`first-available`, `next-available`, `round-robin`和`round-robin-with-fallback`,分别对应不同的负载均衡和故障转移策略。更多详情参考:<https://dev.mysql.com/doc/mysql-router/8.0/en/mysql-router-conf-options.html#option_mysqlrouter_routing_strategy>。
40 1
|
1月前
|
存储 Java 关系型数据库
实验设备管理系统【GUI/Swing+MySQL】(Java课设)
实验设备管理系统【GUI/Swing+MySQL】(Java课设)
17 0
|
1月前
|
负载均衡 算法 安全
一文带你了解LVS负载均衡模式与F5负载均衡
一文带你了解LVS负载均衡模式与F5负载均衡
451 0
|
1月前
|
缓存 负载均衡 应用服务中间件
【分布式技术专题】「分析Web服务器架构」Tomcat服务器的运行架构和LVS负载均衡的运行机制(修订版)
在本章内容中,我们将深入探讨 Tomcat 服务器的运行架构、LVS 负载均衡的运行机制以及 Cache 缓存机制,并提供相应的解决方案和指导。通过理解这些关键概念和机制,您将能够优化您的系统架构,提高性能和可扩展性。
221 4
【分布式技术专题】「分析Web服务器架构」Tomcat服务器的运行架构和LVS负载均衡的运行机制(修订版)

热门文章

最新文章