当前位置:   article > 正文

2024年8月13日(lvs NAT脚本 RS脚本 ds脚本)

2024年8月13日(lvs NAT脚本 RS脚本 ds脚本)

lvs-nat模式的优点配置简单,缺点是请求和响应都必须经过ds,容易称为性能瓶颈

希望有这样的模式,请求的时候使用input链进行负载均衡,响应的时候就不要经过ds,直接由rs响应给客户端
在nat模式的时候,请求vip,接收vip的响应

构想 请求vip,接受rip响应,这是不允许lvs-dr模式

NAT脚本 
  1. # ds脚本
  2. #!/bin/bash
  3. #配置网卡
  4. echo TYPE="Ethernet" >> /etc/sysconfig/network-
  5. scripts/ifcfg-ens36
  6. echo BOOTPROTO="none" >> /etc/sysconfig/network-
  7. scripts/ifcfg-ens36
  8. read -p "router name:" router_name
  9. echo NAME='"$rount_name"' >> /etc/sysconfig/network-
  10. scripts/ifcfg-ens36
  11. uuidkey=$( uuidgen )
  12. echo UUID='"$uuidkey"' >> /etc/sysconfig/network-
  13. scripts/ifcfg-ens36 >> /etc/sysconfig/network-
  14. scripts/ifcfg-ens36
  15. echo DEVICE='"$rount_name"' >> /etc/sysconfig/network-
  16. scripts/ifcfg-ens36
  17. echo ONBOOT="yes" >> /etc/sysconfig/network-scripts/ifcfg-
  18. ens36
  19. echo IPADDR=192.168.10.100 >> /etc/sysconfig/network-
  20. scripts/ifcfg-ens36
  21. systemctl restart network
  22. #安装ipvsadm
  23. yum list installed|grep ipvsadm
  24. if[ $? -ne 0 ];then
  25. yum -y install ipvsadm
  26. fi
  27. #配置规则
  28. read -p "vip:" vip
  29. read -p "port:" port
  30. read -p "rule:" s
  31. ipvsadm -A -t $vip:$port -s $s
  32. # ip forward
  33. echo "net.ipv4.ip_forward=1" >/etc/sysctl.conf
  34. sysctl -p
  35. # rs脚本
  36. #!/bin/bash
  37. read -p "dip:" dip
  38. # 设置网关
  39. route del default
  40. route add defualt gw $dip
DR模式

1.性能更优,回路不再经过ds

2.ds和rs为了保证用户响应,都要求配置统一的vip

3.由于rs是直接响应client,网关一定不能设置为ds的dip

4.对rs的vip进行抑制,让ds的vip接收请求,rs的vip不接受请求

5.rs的vip绑定点lo回路网卡上

1.在ds的ens33上挂一个vip 10.1.1.102
  1. [root@dr03 ~]# ifconfig
  2. ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
  3.       inet 10.1.1.101 netmask 255.255.255.0 broadcast 10.1.1.255
  4. [root@dr03 ~]# ifconfig ens33:0 10.1.1.102 broadcast
  5. 10.1.1.102 netmask 255.255.255.255 up
  6. [root@dr03 ~]# route add -host 10.1.1.102 dev ens33:0
  7. # 10.1.1.101 dip
  8. # 10.1.1.102 vip 在rs上的vip和这个vip相同
 2.设置规范
  1. # 安装ipvsadm
  2. yum -y install ipvsadm
  3. $ 设置规则
  4. ipvsadm -A -t 10.1.1.102:80 -s rr
  5. ipvsadm -a -t 10.1.1.102:80 -r 10.1.1.200 -g
  6. ipvsadm -a -t 10.1.1.102:80 -r 10.1.1.201 -g
  7. # rs不在需要指定端口,dr不支持端口映射,vip上是80端口,最终就是80端
  8. # -m nat -g gateway
设置RS主机
1.在lo接口上绑定vip
  1. [root@web01 ~]# ifconfig lo:0 10.1.1.102 broadcast
  2. 10.1.1.102 netmask 255.255.255.255 up
2.设置主机路由
[root@web01 ~]# route add -host 10.1.1.102 dev lo:0 
3.抑制rs接收请求
  1. echo 1 > /proc/sys/net/ipv4/conf/lo/arp_ignore
  2. echo 2 > /proc/sys/net/ipv4/conf/lo/arp_announce
  3. echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
  4. echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce
4.生成脚本,对web02使用
  1. ifconfig lo:0 10.1.1.102 broadcast 10.1.1.102 netmask
  2. 255.255.255.255 up
  3. route add -host 10.1.1.102 dev lo:0
  4. echo 1 > /proc/sys/net/ipv4/conf/lo/arp_ignore
  5. echo 2 > /proc/sys/net/ipv4/conf/lo/arp_announce
  6. echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
  7. echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce
5.测试使用,查看状态
[root@dr03 ~]# ipvsadm -Ln --stats
DR模式的脚本
1.ds脚本
  1. #! /bin/bash
  2. #在ens33上挂载一个ip地址
  3. read -p "vip:" vip
  4. read -p "mac:" mac
  5. read -p "num" num
  6. ifconfig $mac: $num $vip broadcast $vip netmask
  7. 255.255.255.255
  8. # 主机路由
  9. route add -host $vip dev $mac:$num
  10. #安装ipvsadm
  11. yum list installed|grep ipvsadm
  12. if [ $? -ne 0 ] ; then
  13. yum -y install ipvsadm
  14. fi
  15. #配置规则(不需要设置ip_forword)
  16. ipvsadm -C
  17. read -p "rule:" rule
  18. read -p "port:" port
  19. ipvsadm -A -t $vip:$port -s $rule
  20. read -p "rip1:" rip1
  21. ipvsadm -a -t $vip:$port -r $rip1 -g
  22. read -p "rip2:" rip2
  23. ipvsadm -a -t $vip:$port -r $rip2 -g
2. rs脚本
  1. #!/bin/bash
  2. #在ens33上挂载一个ip地址
  3. read -p "vip:" vip
  4. read -p "mac:" mac
  5. read -p "num" num
  6. ifconfig $mac:$num $vip broadcast $vip netmask
  7. 255.255.255.255
  8. # 主机路由
  9. route add -host $vip dev $mac:$num
  10. echo 1 > /proc/sys/net/ipv4/conf/lo/arp_ignore
  11. echo 2 > /proc/sys/net/ipv4/conf/lo/arp_announce
  12. echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
  13. echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/喵喵爱编程/article/detail/986802
推荐阅读
相关标签
  

闽ICP备14008679号