实现负载均衡LVS 三种方式配置实例
2013-06-14 22:19
190 查看
LVS是Linux Virtual Server的简写,意即Linux虚拟服务器,是一个虚拟的服务器集群系统。本项目在1998年5月由章文嵩博士成立,是中国国内最早出现的自由软件项目之一。章文嵩博士目前工作于中国国家并行与分布式处理重点实验室,主要从事集群技术、操作系统、对象存储与数据库的研究。
LVS/NAT 方式
三台服务器要求 防火墙关闭 SELinux 也关闭
lvsserver 安装ipvsadm
物理机ip 200.168.10.4
lvs 两块网卡 eth0 eth1
eth0 200.168.10.1 eth1 192.168.10.1
webserver
realserver1 eth0 192.168.10.2
realserver2 eth0 192.168.10.3
lvsserver eth0 连接在vmnet1 交换机
lvsserver eth1 连接在vmnet2 交换机
realserver1 eth0 连接在vmnet2 交换机
realserver2 eth0 连接在vmnet2 交换机
虚拟外网 200.168.10.1 netmask 255.255.255.0
lvs server:
ifconfig eth0 200.168.10.1 netmask 255.255.255.0
ifconfig eth0 192.168.10.1 netmask 255.255.255.0
#开启路由功能
echo 1 > /proc/sys/net/ipv4/ip_forward
#清楚已有调度表
ipvsadm -C
#增加一个调度算法 -A增加 -t tcp -s rr 模式
ipvsadm -At 200.168.10.1:80 -s rr
#增加真实服务器1 -m 以nat模式运作 -g 以dr 模式 -i ip隧道模式
ipvsadm -at 200.168.10.1:80 -r 192.168.10.2:80 -m
#增加真实服务器2
ipvsadm -at 200.168.10.1:80 -r 192.168.10.3:80 -m
#打印出转发设置信息
ipvsadm -L -n
webserver1 设置
ifconfig eth0 192.168.10.2
route add default gw 192.168.10.1
webserver2 设置
ifconfig eth0 192.168.10.3
route add default gw 192.168.10.1
测试
在webserver1 下的/var/www/html/下创建一个简易的网页
echo "192.168.10.2" > /var/www/html/index.html
在webserver2 下的/var/www/html/下创建一个简易的网页
echo "192.168.10.3" > /var/www/html/index.html
在物理机浏览器中输入200.168.10.1 可以看到能正常访问, 并且每次刷新后
返回的ip是轮换的
ip-tun 方式
物理机ip 200.168.10.4
虚拟机所有网卡连接到vmnet1交换机 lvs server 只需要一块网卡
directoryserver 200.168.10.1
realserver 200.168.10.2
realserver 200.168.10.3
vip=200.168.10.10
lvs server:
ifconfig eth0 192.168.10.1
ifconfig tunl0 200.168.10.10 netmask 255.255.255.255 up
#添加路由表
route add -host 200.168.10.10 dev tunl0
ipvsadm -C
#增加一个调度算法 -A增加 -t tcp -s rr 模式
ipvsadm -At 200.168.10.10 -s rr
#增加真实服务器1 -m 以nat模式运作 -g 以dr 模式 -i ip隧道模式
ipvsadm -at 200.168.10.10:80 -r 200.168.10.2:80 -i
#增加真实服务器2
ipvsadm -at 200.168.10.10:80 -r 200.168.10.3:80 -i
#打印出转发设置信息
ipvsadm -L -n
webserver1 设置
ifconfig eth0 200.168.10.2
route del default
ifconfig tunl0 200.168.10.10 netmask 255.255.255.255 up
#添加路由表
route add -host 200.168.10.10 dev tunl0
echo 1 > /proc/sys/net/ipv4/conf/tunl0/arp_ignore
echo 2 > /proc/sys/net/ipv4/conf/tunl0/arp_announce
echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce
webserver2 设置
ifconfig eth0 200.168.10.3
route del default
ifconfig tunl0 200.168.10.10 netmask 255.255.255.255 up
#添加路由表
route add -host 200.168.10.10 dev tunl0
#arp 忽略
echo 1 > /proc/sys/net/ipv4/conf/tunl0/arp_ignore
echo 2 > /proc/sys/net/ipv4/conf/tunl0/arp_announce
echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce
测试
在webserver1 下的/var/www/html/下创建一个简易的网页
echo "200.168.10.2" > /var/www/html/index.html
在webserver2 下的/var/www/html/下创建一个简易的网页
echo "200.168.10.3" > /var/www/html/index.html
在物理机浏览器中输入200.168.10.10 可以看到能正常访问, 并且每次刷新后
返回的ip是轮换的
lvs-dr方式
server:
ifconfig tunl0 down
ifconfig eth0 200.168.10.1
ifconfig eth0:0 200.168.10.10 netmask 255.255.255.255
route add -host 200.168.10.10 dev eth0:0
ipvsadm -At 200.168.10.10:80 -s rr
ipvsadm -at 200.168.10.10 -r 200.168.10.2 -g
ipvsadm -at 200.168.10.10 -r 200.168.10.3 -g
webserver1 设置
ifconfig tunl0 down
ifconfig eth0 200.168.10.2
ifconfig lo:0 200.168.10.10 netmask 255.255.255.255
route add -host 200.168.10.10 dev lo:0
#arp 忽略
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
webserver2 设置
ifconfig tunl0 down
ifconfig eth0 200.168.10.3
ifconfig lo:0 200.168.10.10 netmask 255.255.255.255
route add -host 200.168.10.10 dev lo:0
#arp 忽略
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
测试
在webserver1 下的/var/www/html/下创建一个简易的网页
echo "200.168.10.2" > /var/www/html/index.html
在webserver2 下的/var/www/html/下创建一个简易的网页
echo "200.168.10.3" > /var/www/html/index.html
在物理机浏览器中输入200.168.10.10 可以看到能正常访问, 并且每次刷新后
返回的ip是轮换的
本文出自 “My linux life” 博客,请务必保留此出处http://mllakb.blog.51cto.com/6842774/1222162
LVS/NAT 方式
三台服务器要求 防火墙关闭 SELinux 也关闭
lvsserver 安装ipvsadm
物理机ip 200.168.10.4
lvs 两块网卡 eth0 eth1
eth0 200.168.10.1 eth1 192.168.10.1
webserver
realserver1 eth0 192.168.10.2
realserver2 eth0 192.168.10.3
lvsserver eth0 连接在vmnet1 交换机
lvsserver eth1 连接在vmnet2 交换机
realserver1 eth0 连接在vmnet2 交换机
realserver2 eth0 连接在vmnet2 交换机
虚拟外网 200.168.10.1 netmask 255.255.255.0
lvs server:
ifconfig eth0 200.168.10.1 netmask 255.255.255.0
ifconfig eth0 192.168.10.1 netmask 255.255.255.0
#开启路由功能
echo 1 > /proc/sys/net/ipv4/ip_forward
#清楚已有调度表
ipvsadm -C
#增加一个调度算法 -A增加 -t tcp -s rr 模式
ipvsadm -At 200.168.10.1:80 -s rr
#增加真实服务器1 -m 以nat模式运作 -g 以dr 模式 -i ip隧道模式
ipvsadm -at 200.168.10.1:80 -r 192.168.10.2:80 -m
#增加真实服务器2
ipvsadm -at 200.168.10.1:80 -r 192.168.10.3:80 -m
#打印出转发设置信息
ipvsadm -L -n
webserver1 设置
ifconfig eth0 192.168.10.2
route add default gw 192.168.10.1
webserver2 设置
ifconfig eth0 192.168.10.3
route add default gw 192.168.10.1
测试
在webserver1 下的/var/www/html/下创建一个简易的网页
echo "192.168.10.2" > /var/www/html/index.html
在webserver2 下的/var/www/html/下创建一个简易的网页
echo "192.168.10.3" > /var/www/html/index.html
在物理机浏览器中输入200.168.10.1 可以看到能正常访问, 并且每次刷新后
返回的ip是轮换的
ip-tun 方式
物理机ip 200.168.10.4
虚拟机所有网卡连接到vmnet1交换机 lvs server 只需要一块网卡
directoryserver 200.168.10.1
realserver 200.168.10.2
realserver 200.168.10.3
vip=200.168.10.10
lvs server:
ifconfig eth0 192.168.10.1
ifconfig tunl0 200.168.10.10 netmask 255.255.255.255 up
#添加路由表
route add -host 200.168.10.10 dev tunl0
ipvsadm -C
#增加一个调度算法 -A增加 -t tcp -s rr 模式
ipvsadm -At 200.168.10.10 -s rr
#增加真实服务器1 -m 以nat模式运作 -g 以dr 模式 -i ip隧道模式
ipvsadm -at 200.168.10.10:80 -r 200.168.10.2:80 -i
#增加真实服务器2
ipvsadm -at 200.168.10.10:80 -r 200.168.10.3:80 -i
#打印出转发设置信息
ipvsadm -L -n
webserver1 设置
ifconfig eth0 200.168.10.2
route del default
ifconfig tunl0 200.168.10.10 netmask 255.255.255.255 up
#添加路由表
route add -host 200.168.10.10 dev tunl0
echo 1 > /proc/sys/net/ipv4/conf/tunl0/arp_ignore
echo 2 > /proc/sys/net/ipv4/conf/tunl0/arp_announce
echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce
webserver2 设置
ifconfig eth0 200.168.10.3
route del default
ifconfig tunl0 200.168.10.10 netmask 255.255.255.255 up
#添加路由表
route add -host 200.168.10.10 dev tunl0
#arp 忽略
echo 1 > /proc/sys/net/ipv4/conf/tunl0/arp_ignore
echo 2 > /proc/sys/net/ipv4/conf/tunl0/arp_announce
echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce
测试
在webserver1 下的/var/www/html/下创建一个简易的网页
echo "200.168.10.2" > /var/www/html/index.html
在webserver2 下的/var/www/html/下创建一个简易的网页
echo "200.168.10.3" > /var/www/html/index.html
在物理机浏览器中输入200.168.10.10 可以看到能正常访问, 并且每次刷新后
返回的ip是轮换的
lvs-dr方式
server:
ifconfig tunl0 down
ifconfig eth0 200.168.10.1
ifconfig eth0:0 200.168.10.10 netmask 255.255.255.255
route add -host 200.168.10.10 dev eth0:0
ipvsadm -At 200.168.10.10:80 -s rr
ipvsadm -at 200.168.10.10 -r 200.168.10.2 -g
ipvsadm -at 200.168.10.10 -r 200.168.10.3 -g
webserver1 设置
ifconfig tunl0 down
ifconfig eth0 200.168.10.2
ifconfig lo:0 200.168.10.10 netmask 255.255.255.255
route add -host 200.168.10.10 dev lo:0
#arp 忽略
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
webserver2 设置
ifconfig tunl0 down
ifconfig eth0 200.168.10.3
ifconfig lo:0 200.168.10.10 netmask 255.255.255.255
route add -host 200.168.10.10 dev lo:0
#arp 忽略
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
测试
在webserver1 下的/var/www/html/下创建一个简易的网页
echo "200.168.10.2" > /var/www/html/index.html
在webserver2 下的/var/www/html/下创建一个简易的网页
echo "200.168.10.3" > /var/www/html/index.html
在物理机浏览器中输入200.168.10.10 可以看到能正常访问, 并且每次刷新后
返回的ip是轮换的
本文出自 “My linux life” 博客,请务必保留此出处http://mllakb.blog.51cto.com/6842774/1222162
相关文章推荐
- Cent OS上安装配置LVS(DR方式)+keepalived,实现负载均衡和双机热备
- spring整合apache activemq实现消息发送的三种方式代码配置实例
- Hibernate连接池配置三种方式实例
- haproxy+keepalived实现高可用负载均衡(实例配置)
- Silverlight中,很多实例可以使用Xaml的方式进行配置实现的注意事项和原理
- 实例说明Spring实现AOP的2种方式(注解和XML配置)
- 负载均衡(lvs的机制优势和配置方式的汇总)
- nginx的配置及以反向代理方式实现动静分离、负载均衡
- 使用LVS实现负载均衡原理及安装配置详解
- 使用LVS实现负载均衡原理及安装配置详解
- [转]使用 LVS 实现负载均衡原理及安装配置详解
- ApplicationContext的三种实现方式以及在web.xml配置的两种方式
- 负载均衡(lvs的机制优势和配置方式的汇总)
- 使用 LVS 实现负载均衡原理及安装配置详解
- C#实现多级子目录Zip压缩解压实例 NET4.6下的UTC时间转换 [译]ASP.NET Core Web API 中使用Oracle数据库和Dapper看这篇就够了 asp.Net Core免费开源分布式异常日志收集框架Exceptionless安装配置以及简单使用图文教程 asp.net core异步进行新增操作并且需要判断某些字段是否重复的三种解决方案 .NET Core开发日志
- SSM整合SpringSecurity实现权限管理实例 javaconfig配置方式
- 使用LVS实现负载均衡原理及安装配置详解
- 使用 LVS 实现负载均衡原理及安装配置详解
- SSM整合SpringSecurity实现权限管理实例 javaconfig配置方式
- 转ApplicationContext的三种实现方式以及在web.xml配置的两种方式