• 企业架构LNMP学习笔记32


    企业架构LB-服务器的负载均衡之LVS实现:

    学习目标和内容

    1)能够了解LVS的工作方式;

    2)能够安装和配置LVS负载均衡

    3)能够了解LVS-NAT的配置方式;

    4)能够了解LVS-DR的配置方式;

    LVS介绍与安装:

    LVS(Linux virtual server)即Linux虚拟服务器,是由章文嵩博士主导的开源负载均衡项目,目前LVS已经被集成到Linux内核模块中。该项目在Linux内核中实现了基于IP的数据请求负载均衡调度算法。

    LVS的IPVS模块在Linux内核2.4之后以上都被默认支持了,只需要安装ipvsadm管理配置软件即可。

    1. [root@server04 ~]# uname -r
    2. 3.10.0-1160.95.1.el7.x86_64

    作用及优势:

    1)工作在网络层、可以实现高性能、高可用的服务器集群技术;

    2)廉价、可以把很多低性能的服务器组合形成一个超级服务器;

    3)易用、配置非常简单,且有多种负载均衡的方法;

    4)稳定可靠,即使在集群的服务器中某台服务器无法正常工作,也不影响整体效果;

    5)可扩展性非常好;

    安装:安装ipvsadm 只在负载均衡调度服务器上安装即可

    安装在server04服务器上:

    yum install -y ipvsadm
    1. [root@server04 ~]# ipvsadm --help
    2. ipvsadm v1.27 2008/5/15 (compiled with popt and IPVS v1.2.1)
    3. Usage:
    4. ipvsadm -A|E -t|u|f service-address [-s scheduler] [-p [timeout]] [-M netmask] [--pe persistence_engine] [-b sched-flags]
    5. ipvsadm -D -t|u|f service-address
    6. ipvsadm -C
    7. ipvsadm -R
    8. ipvsadm -S [-n]
    9. ipvsadm -a|e -t|u|f service-address -r server-address [options]
    10. ipvsadm -d -t|u|f service-address -r server-address
    11. ipvsadm -L|l [options]
    12. ipvsadm -Z [-t|u|f service-address]
    13. ipvsadm --set tcp tcpfin udp
    14. ipvsadm --start-daemon state [--mcast-interface interface] [--syncid sid]
    15. ipvsadm --stop-daemon state
    16. ipvsadm -h
    17. Commands:
    18. Either long or short options are allowed.
    19. --add-service -A add virtual service with options
    20. --edit-service -E edit virtual service with options
    21. --delete-service -D delete virtual service
    22. --clear -C clear the whole table
    23. --restore -R restore rules from stdin
    24. --save -S save rules to stdout
    25. --add-server -a add real server with options
    26. --edit-server -e edit real server with options
    27. --delete-server -d delete real server
    28. --list -L|-l list the table
    29. --zero -Z zero counters in a service or all services
    30. --set tcp tcpfin udp set connection timeout values
    31. --start-daemon start connection sync daemon
    32. --stop-daemon stop connection sync daemon
    33. --help -h display this help message
    34. Options:
    35. --tcp-service -t service-address service-address is host[:port]
    36. --udp-service -u service-address service-address is host[:port]
    37. --fwmark-service -f fwmark fwmark is an integer greater than zero
    38. --ipv6 -6 fwmark entry uses IPv6
    39. --scheduler -s scheduler one of rr|wrr|lc|wlc|lblc|lblcr|dh|sh|sed|nq,
    40. the default scheduler is wlc.
    41. --pe engine alternate persistence engine may be sip,
    42. not set by default.
    43. --persistent -p [timeout] persistent service
    44. --netmask -M netmask persistent granularity mask
    45. --real-server -r server-address server-address is host (and port)
    46. --gatewaying -g gatewaying (direct routing) (default)
    47. --ipip -i ipip encapsulation (tunneling)
    48. --masquerading -m masquerading (NAT)
    49. --weight -w weight capacity of real server
    50. --u-threshold -x uthreshold upper threshold of connections
    51. --l-threshold -y lthreshold lower threshold of connections
    52. --mcast-interface interface multicast interface for connection sync
    53. --syncid sid syncid for connection sync (default=255)
    54. --connection -c output of current IPVS connections
    55. --timeout output of timeout (tcp tcpfin udp)
    56. --daemon output of daemon information
    57. --stats output of statistics information
    58. --rate output of rate information
    59. --exact expand numbers (display exact values)
    60. --thresholds output of thresholds information
    61. --persistent-conn output of persistent connection info
    62. --nosort disable sorting output of service/server entries
    63. --sort does nothing, for backwards compatibility
    64. --ops -o one-packet scheduling
    65. --numeric -n numeric output of addresses and ports
    66. --sched-flags -b flags scheduler flags (comma-separated)

    LVS的常见工作方式:

    1)NAT地址转换;

    2)DR直接路由;

    LVS调度算法:

    1、静态调度算法Fixed Scheduling Method

    ①RR 轮询 调度器通过"轮叫"调度算法将外部请求按顺序轮流分配到集群中的真实服务器上,它均等地对待每一台服务器,而不管服务器上实际的连接数和系统负载。

    ②WRR 加权轮询 调度器通过"加权轮叫"调度算法根据真实服务器的不同处理能力来调度访问请求。 这样可以保证处理能力强的服务器处理更多的访问流量。调度器 可以自动问询真实服务器的负载情况,并动态地调整其权值。

    ③DH 目标地址hash 算法也是针对目标IP地址的负载均衡,但它是一种静态映射算法,通过一个散列(Hash)函数将一个目标IP地址映射到一台服务器。 目标地址散列调度算法先根据请求的目标IP地址,作为散列键(Hash Key)从静态分配的散列表找出对应的服务器,若该服务器是可用的且未超载,将请求发送到该服务器,否则返回空。

    ④SH 源地址hash 算法正好与目标地址散列调度算法相反,它根据请求的源IP地址,作为散列键(Hash Key)从静态分配的散列表找出对应的服务器,若该服务器是 可用的且未超载,将请求发送到该服务器,否则返回空。 它采用的散列函数与目标地址散列调度算法的相同。除了将请求的目标IP地址换成请求的源IP地址外,它的算法流程与目标地址散列调度算法的基本相似。在实际应用中,源地址散列调度和目标地址散列调度可以结合使用在防火墙集群中,它们可以保证整个系统的唯一出入口。

    2.Dynamic Scheduling Method 动态调度方法

    ①LC 最少连接 调度器通过"最少连接"调度算法动态地将网络请求调度到已建立的链接数最少的服务器上。 如果集群系统的真实服务器具有相近的系统性能,采用"最小连接"调度算法可以较好地均衡负载。

    ②WLC 加权最少连接 在集群系统中的服务器性能差异较大的情况下,调度器采用"加权最少链接"调度算法优化负载均衡性能,具有较高权值的服务器将承受较大比例的活动连接负载。调度器可以自动问询真实服务器的负载情况,并动态地调整其权值。

    ③SED 最少期望延迟 基于wlc算法,举例说明:ABC三台机器分别权重123,连接数也分别是123,name如果使用WLC算法的话一个新请求 进入时他可能会分给ABC中任意一个,使用SED算法后会进行这样一个运算 A:(1+1)/2 B:(1+2)/2 C:(1+3)/3 根据运算结果,把连接交给C

    ④NQ 从不排队调度方法 无需列队,如果有台realserver的连接数=0 就直接分配过去,不需要进行sed运算.

    ⑤LBLC 基于本地的最少连接 "基于局部性的最少链接" 调度算法是针对目标IP地址的负载均衡,目前主要用于Cache集群系统。 该算法根据请求的目标IP地址找出该 目标IP地址最近使用的服务器,若该服务器 是可用的且没有超载,将请求发送到该服务器; 若服务器不存在,或者该服务器超载且有服务器处于一半的工作负载,则用"最少链接"的原则选出一个可用的服务器,将请求发送到该服务器。

    ⑥LBLCR 带复制的基于本地的最少连接 "带复制的基于局部性最少链接"调度算法也是针对目标IP地址的负载均衡,目前主要用于Cache集群系统。 它与LBLC算法的不同 之处是它要维护从一个 目标IP地址到一组服务器的映射,而LBLC算法维护从一个目标IP地址到一台服务器的映射。 该算法根据请求的目标IP地址找出该目标IP地址对应的服务器组,按"最小连接"原则从服务器组中选出一台服务器, 若服务器没有超载,将请求发送到该服务器;若服务器超载,则按"最小连接"原则从这个集群中选出一 台服务器 ,将该服务器加入到服务器组中,将请求发送到该服务器。同时,当该服务器组有一段时间没有被修改, 将最忙的服务器从服务器组中删除,以降低复制的程度。

    我们平时用的最多的还是轮询算法。

    默认是WLC:加权最少连接。

    LVS实现负载均衡:

    LVS-NAT实现:

    需要知道的几个名词:

    DS: 负载均衡调度服务器

    RS:真实服务器

    CIP:客户端IP

    DIP:负载均衡调度服务器IP

    VIP:负载均衡调度服务器的虚拟IP,对外提供服务的IP,用户访问的IP

    RIP:真实服务器的IP。

    不管采用什么网络工作方式

    用户访问的服务器IP永远是通过VIP,域名必须绑定解析到VIP上。

    LVS的VIP跟Keepalived的VIP没有关系,不要搞混。

  • 相关阅读:
    SpringBoot开发实用篇复习1
    QT总结汇总
    人工智能知识全面讲解:初识生成对抗网络
    人工智能基础_机器学习045_逻辑回归的梯度下降公式推导_更新公式---人工智能工作笔记0085
    从字节码角度带你彻底理解异常中catch,return和finally,再也不用死记硬背了
    web前端网页设计与制作——华夏第一县HTML+CSS+JavaScript
    FPGA刷题——存储器(RAM和FIFO的Verilog实现)
    golang工程中间件——redis常用结构及应用(set,zset)
    野火FPGA入门(3):简单组合逻辑
    C语言程序编译过程中自动添加编译时间等相关信息
  • 原文地址:https://blog.csdn.net/chang_chunhua/article/details/132781383