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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:
前言:在上次用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
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
2月前
|
负载均衡 前端开发 JavaScript
LVS-DR模式、keepalived、Nginx与Tomcat合作,打造动静分离,高效负载均衡与高可用性
为了采用这样的架构,你需要对LVS-DR、Keepalived、Nginx与Tomcat有一定的理解和掌握,同时也需要投入一些时间去研究和配置,但是一旦你把它运行起来,你将会发现,这一切都是值得的。
110 11
|
3月前
|
负载均衡 算法 关系型数据库
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL集群架构负载均衡故障排除与解决方案
本文深入探讨 MySQL 集群架构负载均衡的常见故障及排除方法。涵盖请求分配不均、节点无法响应、负载均衡器故障等现象,介绍多种负载均衡算法及故障排除步骤,包括检查负载均衡器状态、调整算法、诊断修复节点故障等。还阐述了预防措施与确保系统稳定性的方法,如定期监控维护、备份恢复策略、团队协作与知识管理等。为确保 MySQL 数据库系统高可用性提供全面指导。
|
5月前
|
负载均衡 网络协议 Linux
LVS,软负载均衡
LVS(Linux Virtual Server)是一项广泛应用的负载均衡技术,由章文嵩博士于1998年发起,自Linux 2.4.24版本起成为官方内核的一部分。LVS通过四层负载均衡技术实现高性能、高可用的服务器集群,支持多种调度算法和工作模式(如D-NAT、full-NAT、IP隧道、DR),适用于HTTP、数据库等应用。相比7层负载均衡器(如Nginx、HAProxy),LVS具有更高的并发处理能力和更低的资源消耗,适合大规模流量分发。本期文章详细介绍了LVS的工作原理、优势与不足,并对比了常见的负载均衡产品,帮助读者根据具体需求选择合适的解决方案。
563 5
LVS,软负载均衡
|
7月前
|
负载均衡 算法 Linux
LVS+Keepalived:实现高效软负载均衡的利器
本文介绍了如何使用LVS(Linux Virtual Server)和Keepalived搭建高可用负载均衡集群。LVS通过不同调度算法将请求转发给后端服务器,而Keepalived基于VRRP协议实现服务高可用,避免IP单点故障。具体步骤包括环境准备、安装配置ipvsadm和Keepalived、启动服务及测试。文中还详细解释了配置文件中的关键参数,并提供了故障转移测试方法。最后,文章简要对比了软件、硬件和云负载均衡方案的特点,帮助读者选择合适的负载均衡策略。
1120 4
|
10月前
|
运维 负载均衡 网络协议
LVS+Keepalived 负载均衡
LVS+Keepalived 负载均衡
198 8
LVS+Keepalived 负载均衡
|
10月前
|
域名解析 运维 负载均衡
LVS+Keepalived 负载均衡(二)28-1
【8月更文挑战第28天】LVS+Keepalived 负载均衡 配置 LVS VIP
156 5
|
弹性计算 安全 前端开发
ECS实验体验
ECS的简单使用体验报告
201 1
ECS实验体验
|
3天前
|
存储 弹性计算 数据挖掘
阿里云2核4G5M带宽199元云服务器测评:价格、性能、适用场景与续费优势详解
阿里云目前活动中推出的“2核4G5M带宽199元1年”云服务器,是当下深受初创企业用户喜爱的云服务器。本文将从价格优势、性能优势和续费优势等几个方面,详细解析这款阿里云199元云服务器的各项特点,帮助大家更好地了解这款云服务器的性能和应用场景,以供选择参考。