LVS集群-DR负载均衡集群

简介:

LVS集群-DR负载均衡集群

服务介绍

Director 分配请求到不同的real server. real server 处理请求后直接回应给用户,这样director 负载均衡器仅处理客户机与服务器的一半连接,负载均衡器处理一半的链接,避免了新的性能瓶颈,同样增加了系统的可伸缩性。Director Routing 采用物理层修改MAC 地址技术,因此所以服务器必须在同一个网段中。

DR的优点:NAT模式效率低

DR方式特点:都是公网地址


拓扑图:

wKioL1ZKA7ixbqrVAAA6II994n0724.png


实例 :配置LVS DR模式集群

实验环境

Localhost  DIP : 192.168.10.70 VIP: 192.168.10.63

配置Localhost

[root@localhost~]# cat /etc/sysconfig/network-scripts/ifcfg-eth1查看eth1的网卡

wKiom1ZKA5TiR8ZwAAAq1GoTfxc674.png


配置网卡  eth1:1  eth1 eth1:1网卡的MAC 地址必须一样

[root@localhostnetwork-scripts] #   cd/etc/sysconfig/network-scripts/

 [root@localhost network-scripts]# vimifcfg-eth1:1

wKiom1ZKA7eToYQ0AAA_KH09NuU107.png


查看网卡信息


wKiom1ZKA9ywsMX1AABlQp5yd1s492.png

配置LVS-DR规则

rpm -ivh/mnt/Packages/ipvsadm-1.26-2.el6.x86_64.rpm  #  安装软件包

[root@localhost~]# ipvsadm -A -t 192.168.10.63:80 -s rr 

-A : 添加-t: 表示tcp  -s: 指定调度算法 rr : 表示轮询  -g:表示DR  -r:指定real server

 [root@localhost ~]# ipvsadm -a -t192.168.10.63:80 -r 192.168.10.62 -g

[root@localhost~]# ipvsadm -a -t 192.168.10.63:80 -r 192.168.10.64 -g

 

[root@localhost~]# ipvsadm -L -n

IP VirtualServer version 1.2.1 (size=4096)

ProtLocalAddress:Port Scheduler Flags

  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn

TCP  192.168.10.63:80 rr

  -> 192.168.10.62:80             Route   1     0          0        

  -> 192.168.10.64:80             Route   1     0          0    

备注:在LVS 模式中,只要nat 模式需要开启路由转发功能

配置Real Server localhost1.cn

Eth1 IP:192.168.10.62  桥接模式

生成回环口配置文件

[root@localhost1 network-scripts]# pwd

[root@localhost1 network-scripts]# cpifcfg-lo ifcfg-lo:1

root@localhost1 network-scripts]# catifcfg-lo:1

DEVICE=lo:1

IPADDR=192.168.10.63

NETMASK=255.255.255.255

ONBOOT=yes

NAME=loopback

查看网卡信息

wKioL1ZKBFuSUjSnAAB4cXX1M5U187.png


关闭ARP转发

[root@localhost1 ~]# echo 1 >/proc/sys/net/ipv4/conf/eth1/arp_ignore

[root@localhost1 ~]# echo 2 >/proc/sys/net/ipv4/conf/eth1/arp_announce

net.ipv4.conf.eth1.arp_ignore =1

net.ipv4.conf.eth1.arp_announce =2

若要永久生效则要在 vim/etc/sysctl.conf最后添加,sysctl –p 生效

网关指向 公网出口路由器

GATEWAY=192.168.10.1

启动80端口

 [root@localhost1 ~]# echo 192.168.10.62 >/var/www/html/index.html

[root@localhost1html]# /etc/init.d/httpd restart

 

配置Real Server localhost2.cn

Eth1 IP:192.168.10.64  桥接模式

生成回环口配置文件

[root@localhost2 network-scripts]# cpifcfg-lo  ifcfg-lo:1

[root@localhost2 network-scripts]# catifcfg-lo:1

DEVICE=lo:1

IPADDR=192.168.10.63

NETMASK=255.255.255.255

ONBOOT=yes

NAME=loopback

查看网卡信息

wKioL1ZKBIWC6IvYAACNd8fSAkQ794.png


关闭ARP 转发

echo 1 >/proc/sys/net/ipv4/conf/eth1/arp_ignore

echo 2 >/proc/sys/net/ipv4/conf/eth1/arp_announce

网关指向 公网出口路由器

GATEWAY=192.168.10.1

启动80端口

echo 192.168.10.64 >/var/www/html/index.html

/etc/init.d/httpd restart

 

客户端测试vip

先测试real server

http://192.168.10.64

http://192.168.10.62

wKiom1ZKBFyzK_hQAAB7HJ_nPmM699.png


 

测试VIP http://192.168.10.63  多刷新几次


wKioL1ZKBOTzKPHbAABk_a3yvDE042.png


测试LVS其他的调度算法

[root@localhost~]# ipvsadm -A -t 192.168.10.63:80 -s wrr

Wrr 基于集群节点分配处理每一个节点的权重,权重值为2的服务器将为1的服务器的2倍,如果权重值为0,则不会收到新的连接

[root@localhost~]# ipvsadm -a -t 192.168.10.63:80 -r 192.168.10.62 -g -w 10

[root@localhost~]# ipvsadm -a -t 192.168.10.63:80 -r 192.168.10.64 -g -w 20

[root@localhost~]# ipvsadm -L -n --stats

IP VirtualServer version 1.2.1 (size=4096)

ProtLocalAddress:Port              Conns   InPkts  OutPkts InBytes OutBytes

  -> RemoteAddress:Port

TCP  192.168.10.63:80                    0        0       0        0        0

  -> 192.168.10.62:80                    0        0       0        0        0

  -> 192.168.10.64:80                    0        0       0        0        0

 

在物理机上,刷新9次链接 http://192.168.10.63   localhost 1:localhost2 1:2的关系

查看

wKioL1ZKBQ6jKXRTAAA4da9gG68534.png

如果一个real server 的权重是,就不会分配给客户端的请求

[root@localhost~]# ipvsadm -A -t 192.168.10.63:80 -s wrr

[root@localhost~]# ipvsadm -a -t 192.168.10.63:80 -r 192.168.10.62 -g -w 0

[root@localhost~]# ipvsadm -a -t 192.168.10.63:80 -r 192.168.10.64 -g -w 20

[root@localhost~]# ipvsadm -L -n --stats

IP VirtualServer version 1.2.1 (size=4096)

ProtLocalAddress:Port              Conns   InPkts  OutPkts InBytes OutBytes

  -> RemoteAddress:Port

TCP  192.168.10.63:80                    0        0       0        0        0

  -> 192.168.10.62:80                    0        0       0        0        0

  -> 192.168.10.64:80                    0        0       0        0        0



在物理机上,刷新链接 http://192.168.10.63,只会出现192.168.10.64

wKiom1ZKBPLysvf-AABhGgjHmAU166.png


清空内核虚拟服务器中的所有记录

[root@localhost~]# ipvsadm -L -n --stats   显示统计信息

IP VirtualServer version 1.2.1 (size=4096)

ProtLocalAddress:Port              Conns   InPkts  OutPkts InBytes OutBytes

  -> RemoteAddress:Port

 

 

 [root@localhost ~]# ipvsadm -L -n --rate  显示速率信息

IP VirtualServer version 1.2.1 (size=4096)

ProtLocalAddress:Port                CPS    InPPS   OutPPS   InBPS   OutBPS

  -> RemoteAddress:Port

[root@localhost~]# ipvsadm -L -n –c 显示目前链接

IPVS connectionentries

pro expirestate       source             virtual            destination

 

LVS 的配置文件保存在 /etc/init.d /ipvsadm

 [root@localhost ~]# cat/etc/sysconfig/ipvsadm-config  LVS 的规则存储文件保存位置




本文转自 水滴石川1 51CTO博客,原文链接:http://blog.51cto.com/sdsca/1713325,如需转载请自行联系原作者
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
相关文章
|
7月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
7月前
|
负载均衡 前端开发 JavaScript
LVS-DR模式、keepalived、Nginx与Tomcat合作,打造动静分离,高效负载均衡与高可用性
为了采用这样的架构,你需要对LVS-DR、Keepalived、Nginx与Tomcat有一定的理解和掌握,同时也需要投入一些时间去研究和配置,但是一旦你把它运行起来,你将会发现,这一切都是值得的。
307 11
|
8月前
|
负载均衡 算法 关系型数据库
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL集群架构负载均衡故障排除与解决方案
本文深入探讨 MySQL 集群架构负载均衡的常见故障及排除方法。涵盖请求分配不均、节点无法响应、负载均衡器故障等现象,介绍多种负载均衡算法及故障排除步骤,包括检查负载均衡器状态、调整算法、诊断修复节点故障等。还阐述了预防措施与确保系统稳定性的方法,如定期监控维护、备份恢复策略、团队协作与知识管理等。为确保 MySQL 数据库系统高可用性提供全面指导。
|
10月前
|
负载均衡 网络协议 Linux
LVS,软负载均衡
LVS(Linux Virtual Server)是一项广泛应用的负载均衡技术,由章文嵩博士于1998年发起,自Linux 2.4.24版本起成为官方内核的一部分。LVS通过四层负载均衡技术实现高性能、高可用的服务器集群,支持多种调度算法和工作模式(如D-NAT、full-NAT、IP隧道、DR),适用于HTTP、数据库等应用。相比7层负载均衡器(如Nginx、HAProxy),LVS具有更高的并发处理能力和更低的资源消耗,适合大规模流量分发。本期文章详细介绍了LVS的工作原理、优势与不足,并对比了常见的负载均衡产品,帮助读者根据具体需求选择合适的解决方案。
1396 5
LVS,软负载均衡
|
12月前
|
负载均衡 算法 Linux
LVS+Keepalived:实现高效软负载均衡的利器
本文介绍了如何使用LVS(Linux Virtual Server)和Keepalived搭建高可用负载均衡集群。LVS通过不同调度算法将请求转发给后端服务器,而Keepalived基于VRRP协议实现服务高可用,避免IP单点故障。具体步骤包括环境准备、安装配置ipvsadm和Keepalived、启动服务及测试。文中还详细解释了配置文件中的关键参数,并提供了故障转移测试方法。最后,文章简要对比了软件、硬件和云负载均衡方案的特点,帮助读者选择合适的负载均衡策略。
1690 4
|
运维 负载均衡 网络协议
LVS+Keepalived 负载均衡
LVS+Keepalived 负载均衡
371 8
LVS+Keepalived 负载均衡
|
域名解析 运维 负载均衡
LVS+Keepalived 负载均衡(二)28-1
【8月更文挑战第28天】LVS+Keepalived 负载均衡 配置 LVS VIP
259 5
|
负载均衡 算法 应用服务中间件
负载均衡技术在Web服务器集群中的应用
【8月更文第28天】随着互联网的发展和用户对Web服务需求的增长,单台服务器很难满足大规模访问的需求。为了提高系统的稳定性和扩展性,通常会采用Web服务器集群的方式。在这种架构中,负载均衡器扮演着至关重要的角色,它能够合理地分配客户端请求到不同的后端服务器上,从而实现资源的最优利用。
435 2
|
负载均衡 算法 关系型数据库
MySQL集群如何实现负载均衡?
【8月更文挑战第16天】MySQL集群如何实现负载均衡?
913 6
|
缓存 负载均衡 算法
在Linux中, LVS负载均衡有哪些策略?
在Linux中, LVS负载均衡有哪些策略?