LVS负载均衡架构原理

2024-08-27 10:58
文章标签 负载 原理 架构 均衡 lvs

本文主要是介绍LVS负载均衡架构原理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


Linux Virtual Server

Ipvs : 嵌入到linux的内核

IPVsadm:管理应用程序


负载均衡器

1、硬件:

     F5BIG-IP

     CitrixNetScaler

     A10

2、软件

     四层:tcp 之上的第四层协议

               LVS:只能操作IP,端口 ,在操作系统内核中。

     七层:http,ajp,https,(应用层)

               nginx

               haproxy

               httpd

 

调度方法(静态方法和动态方法)

  四种静态:

         rr:轮循

         wrr:

         dh:

         sh:

 

  动态调度方法:

         lc:最少连接

                   active*256+inactive

                   谁的小,挑谁

         wlc:加权最少连接

                   (active*256+inactive)/weight

         sed:最短期望延迟

                   (active+1)*256/weight

         nq:never queue

         LBLC:基于本地的最少连接

                   DH:

         LBLCR:基于本地的带复制功能的最少连接

         默认方法:wlc


类型:

         NAT:地址转换

         DR:直接路由

         TUN:隧道

 

      NAT:

                   集群节点跟director必须在同一个IP网络中;

                   RIP通常是私有地址,仅用于各集群节点间的通信;

                   director位于client和real server之间,并负责处理进出的所有通信;

                   realserver必须将网关指向DIP;

                   支持端口映射;

                   realserver可以使用任意OS;

                   较大规模应该场景中,director易成为系统瓶颈;

                   VIP:虚拟服务器地址

                   DIP:   转发的网络地址

                    RIP:  后端真实主机(后端服务器)

                   CIP:客户端IP地址

     DR:  

                  集群节点跟director必须在同一个物理网络中;

                  后端服务器(真实服务器)可以使用公网地址,实现便捷的远程管理和监控;

                  director仅负责处理入站请求,响应报文则由realserver直接发往客户端;

                  不支持端口映射;


VIP(隐藏)的意思:

不对外广播

被叫不响应

Node1

VIP:192.168.1.251

DIP:192.168.239.3

集群服务器

Node2

RIP:192.168.1.248

VIP:192.168.239.10

RS,apache

Node3

RIP:192.168.1.249

VIP:192.168.239.10

RS,apache


      TUN:

                   集群节点可以跨越Internet;

                   RIP必须是公网地址;

                   director仅负责处理入站请求,响应报文则由realserver直接发往客户端;

                   realserver网关不能指向director;

                   只有支持隧道功能的OS才能用于realserver;

                   不支持端口映射;


Ipvsadm命令:

      管理集群服务

                   添加:-A -t|u|fservice-address [-s scheduler]

                            -t:TCP协议的集群

                            -u:UDP协议的集群

                                     service-address:     IP:PORT

                            -f:FWM: 防火墙标记

                                     service-address:Mark Number

                   修改:-E

                   删除:-D -t|u|fservice-address

 

                   #ipvsadm -A -t 172.16.100.1:80 -s rr

 

      管理集群服务中的RS

                   添加:-a -t|u|fservice-address -r server-address [-g|i|m] [-w weight]

                              -t|u|f service-address:事先定义好的某集群服务

                              -r server-address: 某RS的地址,在NAT模型中,可使用IP:PORT实现端口映射;

                              [-g|i|m]: LVS类型      

                                     -g:DR

                                     -i:TUN

                                     -m:NAT

                            [-wweight]: 定义服务器权重

                   修改:-e

                   删除:-d -t|u|fservice-address -r server-address

 

                   #ipvsadm -a -t 172.16.100.1:80 -r 192.168.10.8 –g

                   #ipvsadm -a -t 172.16.100.1:80 -r 192.168.10.9 -g

         查看

                   -L|l

                            -n:数字格式显示主机地址和端口

                            --stats:统计数据

                            --rate:速率

                            --timeout:显示tcp、tcpfin和udp的会话超时时长

                            -c:显示当前的ipvs连接状况

 

         删除所有集群服务

                   -C:清空ipvs规则

         保存规则

                   -S

                   #ipvsadm -S > /path/to/somefile

         载入此前的规则:

                   -R

                   # ipvsadm -R </path/form/somefile

----------------------------------------------------------------------------------------------------------------------------------

DR模式

VIP: 虚拟主机IP

         DIP:

         kernelparameter:

                   arp_ignore:定义接收到ARP请求时的响应级别;

                            0:只要本地配置的有相应地址,就给予响应;

                            1:仅在请求的目标(MAC)地址配置请求到达的接口上的时候,才给予响应;

 

                   arp_announce:定义将自己地址向外通告时的通告级别;

                            0:将本地任何接口上的任何地址向外通告;

                            1:试图仅向目标网络通告与其网络匹配的地址;

                            2:仅向与本地接口上(MAC)地址匹配的网络进行通告;


-----------------------------------------------------------------DR模式示例------------------------------------------------------------

Lvs DR模式集群步骤

1、  找一台主机作为DR(虚拟服务器),安装ipvsadm

       a) Yum install ipvsadm

2、  在DR设置两个IP地址:

       a) DIP: 192.168.1.134 ,设置静态ID

       b) VIP:192.168.1.200 , ifconfig eth0:1 192.168.1.200/24 (取消绑定ifconfig eth1 down)

3、  找多台机器作为RS(apeche或者tomcat )

       a) 两台:静态设置192.168.1.137

                                   192.168.1.138

       b) 修改报文源IP的设置,需要设置内核参数

                    i.  echo 1 >/proc/sys/net/ipv4/conf/eth0/arp_ignore

                    ii. echo 1 >/proc/sys/net/ipv4/conf/all/arp_ignore

                    iii.echo 2 >/proc/sys/net/ipv4/conf/eth0/arp_announce

                    iv.echo 2 >/proc/sys/net/ipv4/conf/all/arp_announce

       c)  在两台机器(RS)上,设置网卡的别名IP:192.168.1.200

                     i. ifconfig lo:0 192.168.1.200 netmask 255.255.255.255 broadcast 192.168.1.200

       d)  在两台机器(RS)上,添加一个路由

                      i. route add -host 192.168.1.200 dev lo:0

4、  DR上需要加一个路由设置:route add -host 192.168.1.200 dev eth0:1

5、  在RS 检查web服务是否正常

6、  在DR上使用ipvsadm添加集群服务

       a)  Ipvsadm –C

       b)  ipvsadm -A -t 192.168.1.200:80-s wlc

       c)  ipvsadm -a -t 192.168.1.200:80-r 192.168.1.137 -g -w 1

       d)  ipvsadm -a -t 192.168.1.200:80-r 192.168.1.138 -g -w 1


脚本

#!/bin/bash

#description : start realserver

VIP=125.38.38.64

/etc/rc.d/init.d/functions

case "$1" in

start)

echo " start LVS of REALServer"

echo "1">/proc/sys/net/ipv4/conf/lo/arp_ignore

echo "2">/proc/sys/net/ipv4/conf/lo/arp_announce

echo "1">/proc/sys/net/ipv4/conf/all/arp_ignore

echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce

/sbin/ifconfig lo:0 $VIP broadcast $VIPnetmask 255.255.255.255 up

 

;;

stop)

/sbin/ifconfig lo:0 down

echo "close LVS Directorserver"

echo "0">/proc/sys/net/ipv4/conf/lo/arp_ignore

echo "0">/proc/sys/net/ipv4/conf/lo/arp_announce

echo "0">/proc/sys/net/ipv4/conf/all/arp_ignore

echo "0">/proc/sys/net/ipv4/conf/all/arp_announce

;;

*)

echo "Usage: $0 {start|stop}"

exit 1

esac




这篇关于LVS负载均衡架构原理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1111475

相关文章

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

Java 队列Queue从原理到实战指南

《Java队列Queue从原理到实战指南》本文介绍了Java中队列(Queue)的底层实现、常见方法及其区别,通过LinkedList和ArrayDeque的实现,以及循环队列的概念,展示了如何高效... 目录一、队列的认识队列的底层与集合框架常见的队列方法插入元素方法对比(add和offer)移除元素方法

SQL 注入攻击(SQL Injection)原理、利用方式与防御策略深度解析

《SQL注入攻击(SQLInjection)原理、利用方式与防御策略深度解析》本文将从SQL注入的基本原理、攻击方式、常见利用手法,到企业级防御方案进行全面讲解,以帮助开发者和安全人员更系统地理解... 目录一、前言二、SQL 注入攻击的基本概念三、SQL 注入常见类型分析1. 基于错误回显的注入(Erro

Nginx概念、架构、配置与虚拟主机实战操作指南

《Nginx概念、架构、配置与虚拟主机实战操作指南》Nginx是一个高性能的HTTP服务器、反向代理服务器、负载均衡器和IMAP/POP3/SMTP代理服务器,它支持高并发连接,资源占用低,功能全面且... 目录Nginx 深度解析:概念、架构、配置与虚拟主机实战一、Nginx 的概念二、Nginx 的特点

Spring IOC核心原理详解与运用实战教程

《SpringIOC核心原理详解与运用实战教程》本文详细解析了SpringIOC容器的核心原理,包括BeanFactory体系、依赖注入机制、循环依赖解决和三级缓存机制,同时,介绍了SpringBo... 目录1. Spring IOC核心原理深度解析1.1 BeanFactory体系与内部结构1.1.1

CPython与PyPy解释器架构的性能测试结果对比

《CPython与PyPy解释器架构的性能测试结果对比》Python解释器的选择对应用程序性能有着决定性影响,CPython以其稳定性和丰富的生态系统著称;而PyPy作为基于JIT(即时编译)技术的替... 目录引言python解释器架构概述CPython架构解析PyPy架构解析架构对比可视化性能基准测试测

MySQL 批量插入的原理和实战方法(快速提升大数据导入效率)

《MySQL批量插入的原理和实战方法(快速提升大数据导入效率)》在日常开发中,我们经常需要将大量数据批量插入到MySQL数据库中,本文将介绍批量插入的原理、实现方法,并结合Python和PyMySQ... 目录一、批量插入的优势二、mysql 表的创建示例三、python 实现批量插入1. 安装 PyMyS

MySQL数据库读写分离与负载均衡的实现逻辑

《MySQL数据库读写分离与负载均衡的实现逻辑》读写分离与负载均衡是数据库优化的关键策略,读写分离的核心是将数据库的读操作与写操作分离,本文给大家介绍MySQL数据库读写分离与负载均衡的实现方式,感兴... 目录读写分离与负载均衡的核心概念与目的读写分离的必要性与实现逻辑读写分离的实现方式及优缺点读负载均衡

MySQL集群高可用架构的两种使用小结

《MySQL集群高可用架构的两种使用小结》本文介绍了MySQL的两种高可用解决方案:组复制(MGR)和MasterHighAvailability(MHA),文中通过示例代码介绍的非常详细,对大家的学... 目录一、mysql高可用之组复制(MGR)1.1 组复制核心特性与优势1.2 组复制架构原理1.3

深入理解Redis线程模型的原理及使用

《深入理解Redis线程模型的原理及使用》Redis的线程模型整体还是多线程的,只是后台执行指令的核心线程是单线程的,整个线程模型可以理解为还是以单线程为主,基于这种单线程为主的线程模型,不同客户端的... 目录1 Redis是单线程www.chinasem.cn还是多线程2 Redis如何保证指令原子性2.