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

[经验分享] LVS DR 模式实现web负载均衡(iptables(DNAT)+lvs(DR) real server 使用内网ip)

[复制链接]

尚未签到

发表于 2019-1-3 10:46:23 | 显示全部楼层 |阅读模式

  

2.1.1-web基本配置
web1配置
[root@web1 ~]# fdisk /dev/sdb
Command (m for help): n
Command action
  e  extended
  p  primary partition (1-4)
p
Partition number (1-4): 1
First cylinder (1-130, default 1):
Using default value 1
Last cylinder, +cylinders or +size{K,M,G} (1-130, default 130):
Using default value 130
Command (m for help): w
The partition table has been altered!
Calling ioctl() to re-read partition table.
Syncing disks.
[root@web1 ~]# partx /dev/sdb

[root@web1 ~]# mkdir /www/bbs -pv
[root@web1 ~]# mkfs.ext4 /dev/sdb1
[root@web1 ~]# e2label /dev/sdb1 web
  [root@web1 ~]# vim /etc/fstab
[root@web1 ~]# mount -a
[root@web1 ~]# echo "web1" >/www/bbs/test.html
[root@web1 ~]# vim /etc/httpd/conf/httpd.conf


[root@web2 ~]# service httpd start

web2网络配置

[root@web2 ~]# yum -y install httpd php php-mysql
[root@web2 ~]# mkdir -pv /www/bbs
[root@web2 ~]# echo "web2" >/www/bbs/test.html
[root@web2 ~]# vim /etc/httpd/conf/httpd.conf


[root@web2 ~]# service httpd start
[root@web2 ~]# chkconfig httpd on

2.1.2-Director配置
ifconfig eth0:1 172.16.100.80 broadcast 172.16.100.80 netmask 255.255.255.255 up
route add -host 172.16.100.80 dev eth0:1
echo 1 > /proc/sys/net/ipv4/ip_forward
iptables -F
iptables -Z
ipvsadm -C
ipvsadm -A -t 172.16.100.80:80 -s wlc
ipvsadm -a -t 172.16.100.80:80 -r 172.16.100.81 -g -w 1
ipvsadm -a -t 172.16.100.80:80 -r 172.16.100.82 -g -w 1

2.1.3-Realserver配置

ifconfig lo down
ifconfig lo up
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
ifconfig lo:0 172.16.100.80 broadcast 172.16.100.80 netmask 255.255.255.255 up
route add -host 172.16.100.80 dev lo:0

2.1.4-集群服务测试
修改DNS
[root@ns1 ~]# sed -i 's/^\/80/' /var/named/innet.100.16.172.in-addr.arpa
[root@ns1 ~]# sed -i 's/\$/80/' /var/named/innet.sanyu.com.zone


[root@ns1 ~]# service named restart

集群服务内网测试

刷新后


集群服务公网测试
修改防火墙规则

echo 1 > /proc/sys/net/ipv4/ip_forward
iptables -t nat -A PREROUTING -s 202.111.0.0/16 -d 202.111.100.100 -p tcp --dport 80 -j DNAT --to-destination 172.16.100.80
iptables -t nat -A PREROUTING -s 202.110.0.0/16 -d 202.110.100.100 -p tcp --dport 80 -j DNAT --to-destination 172.16.100.80
iptables -t nat -A PREROUTING -s 202.111.0.0/16 -d 202.111.100.100 -p tcp --dport 443 -j DNAT --to-destination 172.16.100.43:443
iptables -t nat -A PREROUTING -s 202.110.0.0/16 -d 202.110.100.100 -p tcp --dport 443 -j DNAT --to-destination 172.16.100.43:443
iptables -t nat -A PREROUTING -s 202.111.0.0/16 -d 202.111.100.100 -p tcp --dport 53 -j DNAT --to-destination 172.16.100.53
iptables -t nat -A PREROUTING -s 202.110.0.0/16 -d 202.110.100.100 -p tcp --dport 53 -j DNAT --to-destination 172.16.100.53
iptables -t nat -A PREROUTING -s 202.111.0.0/16 -d 202.111.100.100 -p udp --dport 53 -j DNAT --to-destination 172.16.100.53
iptables -t nat -A PREROUTING -s 202.110.0.0/16 -d 202.110.100.100 -p udp --dport 53 -j DNAT --to-destination 172.16.100.53

guest1网络配置

guest2网络配置

注意:网关未指向R1
测试结果

  

  

  脚本:
  
#!/bin/bash
#
# LVS script for VS/DR
#
. /etc/rc.d/init.d/functions
#
VIP=172.16.100.80
RIP1=172.16.100.81
RIP2=172.16.100.82
PORT=80
#
case "$1" in
start)         
/sbin/ifconfig eth0:1 $VIP broadcast $VIP netmask 255.255.255.255 up
/sbin/route add -host $VIP dev eth0:1
# Since this is the Director we must be able to forward packets
echo 1 > /proc/sys/net/ipv4/ip_forward
# Clear all iptables rules.
/sbin/iptables -F
# Reset iptables counters.
/sbin/iptables -Z
# Clear all ipvsadm rules/services.
/sbin/ipvsadm -C
# Add an IP virtual service for VIP 192.168.0.219 port 80
# In this recipe, we will use the round-robin scheduling method.
# In production, however, you should use a weighted, dynamic scheduling method.
/sbin/ipvsadm -A -t $VIP:80 -s wlc
# Now direct packets for this VIP to
# the real server IP (RIP) inside the cluster
/sbin/ipvsadm -a -t $VIP:80 -r $RIP1 -g -w 1
/sbin/ipvsadm -a -t $VIP:80 -r $RIP2 -g -w 2
/bin/touch /var/lock/subsys/ipvsadm &> /dev/null
;;
stop)
# Stop forwarding packets
echo 0 > /proc/sys/net/ipv4/ip_forward
# Reset ipvsadm
/sbin/ipvsadm -C
# Bring down the VIP interface
/sbin/ifconfig eth0:1 down
/sbin/route del $VIP
/bin/rm -f /var/lock/subsys/ipvsadm
echo "ipvs is stopped..."
;;
status)
if [ ! -e /var/lock/subsys/ipvsadm ]; then
echo "ipvsadm is stopped ..."
else
echo "ipvs is running ..."
ipvsadm -L -n
fi
;;
*)
echo "Usage: $0 {start|stop|status}"
;;
esac  

  





运维网声明 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-658914-1-1.html 上篇帖子: 群集之lvs 下篇帖子: zabbix监控之lvs
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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