设为首页 收藏本站
查看: 1176|回复: 0

[经验分享] LVS负载均衡器NAT和DR工作模式详解

[复制链接]

尚未签到

发表于 2017-11-7 09:58:08 | 显示全部楼层 |阅读模式
在试验之前为了更好理解设置的参数,所以先讲解一下命令。 一、lvs配置文件和命令:
  程序包:ipvsadm(LVS管理工具)
  配置文件:/etc/sysconfig/ipvsadm-config 【rpm -ql ipvsadm  查询包的具体列表】
  -A  在服务器列表中新添加一条新的虚拟服务器记录
  -t 表示为tcp服务
  -u 表示为udp服务
  -s 使用的调度算法  (rr|wrr|wlc|lc|dh|sh|lblb|lblcr
  -a 在服务器里添加一条新的真是主机记录
  -m 说明lvs提供nat工作模式
  -g 说明lvs提供直接路由器模式(也是lvs默认的工作模式)
  -i 指定lvs工作模式为隧道模式
  -m 真实服务器的权值
  -E 编辑内核虚拟服务器表中的一条虚拟服务器记录
  -D  删除内核虚拟服务器列表中的一条虚拟服务器记录
  -C 清楚内核虚拟服务器中的所有记录
  -R 恢复虚拟服务器所有规则
  -e 编辑虚拟服务器记录中一条真实服务器记录
  -d  删除虚拟服务器记录中的某条真实服务器记录
  -L 显示内核服务器列表
  -n 以数字方式显示地址和端口号
  --stats  统计信息
  -Z 虚拟服务器记录器清零
  -S –save 保存虚拟服务器规则,输出为-R 选项可读的格式
二、lvs负载均衡调度算法:
(1)静态
  ①RR 轮叫调度     【一个接着一个来,平均分配】
  ②WRR:加权轮叫 【负载能力较大者分配的更多】
  ③DH:目标地址散列调度   【据请求的目标IP地址,作为散列键(HashKey)从静态分配的散列表找出对应的服务器,若该服务器是可用的且未超载,将请求发送到该服务器,否则返回空。】
  ④SH:源地址hash   源【地址散列”调度算法根据请求的源IP地址,作为散列键(HashKey)从静态分配的散列表找出对应的服务器,若该服务器是可用的且未超载,将请求发送到该服务器,否则返回空】
  (2)动态:
  ①LC:最少链接        【通过用户请求数和服务器承载的数量,把多余请求数发送到最少的一台服务器上】
  ②WLC:加权最少连接         【给服务器不忙的派发任务,同时性能较好的服务器也能劳动更多】
  ③SED:最短延迟调度  【在WLC基础上改进,Overhead = (ACTIVE+1)*256/加权,不再考虑非活动状态,把当前处于活动状态的数目+1来实现,数目最小的,接受下次请求,+1的目的是为了考虑加权的时候,非活动连接过多缺陷:当权限过大的时候,会倒置空闲服务器一直处于无连接状态。】
  ④NQ:永不排队,最小列队调度。 【需队列。如果有台 realserver的连接数=0就直接分配过去,不需要再进行sed运算,保证不会有一个主机很空间。在SED基础上无论+几,第二次一定给下一个,保证不会有一个主机不会很空闲着,不考虑非活动连接,才用NQ,SED要考虑活动状态连接,对于DNS的UDP不需要考虑非活动连接,而httpd的处于保持状态的服务就需要考虑非活动连接给服务器的压力。】
  三、LVS负载均衡器NAT工作模式。
  大概网络拓扑图:
   c0d531c48f77c52afa779946faa08bb6.png
  详细说明:
  CIP:指客户端IP
  VIP:指负载均衡服务器的虚拟IP
  DIP:指负载均衡服务器的真实IP
  RS:指后端服务器
  RIP:指后端服务器IP
  LVS:负载均衡服务器
  ①当用户请求到达LVS,此时请求的数据报文会先到达内核空间的PREROUTING链,此刻报文源IP为CIP,目标IP为VIP。
  ②当PREROUTING链检查数据包是访问自己的,就将数据包发送到INPUT链。
  ③LVS由用户空间的ipvsadm和内核空间的IPVS组成,ipvsadm用来定义规则,IPVS利用ipvsadm定义的规则工作,IPVS工作在INPUT链上,当数据包到达INPUT链时,首先会被IPVS检查,如果数据包里面的目的地址及端口没有在规则里面,那么这条数据包将被放行至用户空间,如果在就修改数据包的目标IP地址为后端服务器IP,然后将数据包发送至POSTROUTING链。此刻源IP为CIP,目标地址为RIP
④POSTROUTING链通过选路,将数据包发送到后端服务器(RS),后端服务器(RS)对比发现目标是发自己的IP,开始构建响应报文发回给LVS,此刻报文的源地址为RIP,目标地址为CIP。

⑤LVS在响应客户端钱,此刻会把源地址修改为自己的VIP地址,然后响应给客户端。此刻报文的源IP为VIP,目标地址为CIP。
具体步骤:
  三台主机,一台为LVS服务器,两外两台为RS服务器。
  centos7.4为LVS服务器,172.17.66.88为虚拟IP(VIP),192.168.11.11为真实IP(DIP)。
  centos7和centos7-2为后台服务器(RS),两个网段分别为192.168.88.88和192.168.23.23(确保此地址和RS服务器能通)。
  ①装包。
  命令:yum install ipvsadm
  ②负载就均衡服务器上配置
  命令:ipvsadm -A -t 172.17.66.88:80 -s wrr 【在负载均衡服务器上开一个为80端口的虚拟记录,并使用wrr调度方式】
  命令:ipvsadm -a -t 172.17.66.88:80 -t 192.168.88.88 -m -w 1 【配置web服务器后端RIP为NAT工作方式,权重为1】
  命令:ipvsadm -a -t 172.17.66.88:80 -t 192.168.23.23 -m -w 1 【配置web服务器后端RIP为NAT工作方式,权重为1】
   e9445cd55faf4057cb1aacf8ce570469.png
  ③开启LVS的转发功能
  echo 1 > /proc/sys/net/ipv4/ip_forward 【临时开启转发功能】
  vim /sysctl.conf
  添加net.ipv4.ip_forward=1 sysctl -p    【永久生效】
   9a9be1918ba4c75b5a393a2c47e794dd.png
  ④添加RS到LVS的默认路由。
  命令:route add default gw 192.168.11.11
   cde84ad36c050e6e672044b746277b15.png
  ⑤测试。
  在后端两个服务器(RS)写两个测试页面index.html
   e81ff00fd93a1b5e9e19f9c73f3ee668.png
  以上就实现了负载均衡,由于使用的wrr调度以及权重都是1,所以每次访问都是轮流。
  注意:做该实验把RS桥接断掉,不然影响添加的默认路由器工作。
  四、基于LVS实现DR工作模式。
  这种模式是解决基于NAT模式的弊端,因为NAT模式发送的数据进出都经过LVS服务器,会对LVS造成太大压力。
  大概网络拓扑图:
   b0b22668b4fc7e27a9d5b59aca799d58.png
  详细说明:
  ①当客户端发送请求到LVS,此时的请求报文会先到内核的PREROUTING链。此刻的源IP为CIP,目标IP 为VIP。
  ②PREROUTING链检查数据包是访问自己的,就发送到INPUT链。
  ③IPVS对比数据包请求的服务是否在定义的规则里,如果是就将报文中的源MAC地址修改为DIP的MAC地址,将目标MAC地址修改为RIP的MAC地址,然后将数据包发送到POSTROUTING链。此刻的源IP和目标IP都未发送改变,只是修改了源MAC为DIP的MAC,目标MAC为RID的MAC地址。
  ④由于DS和RS在同一段网段,所以工作在二层。POSTROUTING检查目标地址为RIS的MAC地址,就将数据包发送到RS。
  ⑤RS查看MAC地址为自己的MAC地址,就接下包。处理完成后,将响应报文通过lo接口传送到eth0网卡后发出。此时的源地址为VIP,目标地址为CIP,由此完成了数据的传输。
  具体步骤:
  三台服务器在同一个网段,一个为lvs服务器【虚拟IP(别名):172.17.252.251;真实IP(DIP):172.17.66.88】,后台服务器1(RIP):172.17.110.111,后台服务器2(RIP)172.17.33.34
  ①由于都在一个网段,多以在LVS配置一个网卡别名。【并只广播自己】
   1a1ffa0c705a9bae959d26b1cd62155a.png   ②配置LVS的虚拟IP(VIP)和真实IP(DIP)。
   77dad483c5f145ddd81740a0e4b35fc3.png
  ③在后台服务器(RS)上配置VIP并只广播自己。
   8d2b7979414b46f76a7301e8e07833b2.png   ④设置RIP到本地VIP上的路由记录,即本地回旋网卡路由。
   cb260f9e441457cdd10c30d95255cd21.png
  ⑤配置只回答目标IP地址是来访网络接口本地地址的ARP查询请求以及在此模式下将忽略这个IP数据包的源地址并尝试选择与能与该地址通信的本地地址.
   ecde329be835216b29bea58227f71c21.png
  ⑥RS2服务器上设置和RS1一样的配置
    b96001012f10f8aa0d941b581739f8df.png   ⑦测试。
a5d4a37871890544a407c610d96b8fd1.png


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-406617-1-1.html 上篇帖子: 实现LVS负载均衡NAT模式 下篇帖子: 基于CentOS实现LVS的nat模式和DR模式
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表