PART 1
ICP在提供网络服务的时候,访客往往来自各种各样的大小ISP,比如电信、联通、移动、长宽、广电、xx通,甚至还有小区或者写字楼物业垄断下自己搞的宽带。面对这么多复杂的访问来源,如何保证服务的网络质量是内容提供商不得不面对的挑战。解决方案不外乎以下几个:
- 1. 在多个地区为用户就近部署服务器;
- 2. 选择多个网络运营商的线路接入机房,让用户选择和自己相同运营商的服务器地址;
- 3. 选择提供BGP网络的机房(包括线下机房和云服务提供商)进行托管;
- 4. 买CDN节点(广泛应用于各类下载站、VOD、直播或类似单向服务场景)。
生产环境实际部署的过程中,并不会局限于一种方案,而是将多种方案进行组合建设,即在某个/些地区架设服务器,同时接入多家运营商网络,比如广州+电信,青岛+阿里云,北京+移动+联通。
自建机房由于需要自行架设网络,所以只能采用多家运营商网络同时接入的方案;托管方案(包括云)则取决于托管机房的网络资源,条件允许的情况下,一般直接使用机房的BGP网络,条件不具备的时候才会进行多线接入。
data:image/s3,"s3://crabby-images/037d7/037d7e70c28fbd45ac49c710c8cd7da0014418ad" alt=""
PART 2
下面将演示如何为服务器接入多个网络并提供服务。
1. 拓扑图
data:image/s3,"s3://crabby-images/a93a8/a93a80652ab03a05a3a079ed43920a9a0796ae80" alt=""
- 真实服务器借助负载均衡设备为每个ISP发布一个具备独立IP的虚拟服务(本例中发布到10.1.1.2作为电信服务,发布到10.1.1.3作为联通服务);
- 由防火墙设置源地址策略,不同虚拟服务的地址出站时选择各自对应的ISP出口,这样就将一个服务发布到了多个线路上(每条线路都有一个地址);
- 客户端提供服务器地址时,有两种方式可选:
- 所有客户使用相同域名,根据客户所处的运营商网络,由DNS智能解析返回该网络下相应的发布地址;
- 所有发布地址都在客户端列出来,供客户自己选择,或测速后自动选择。
2. 配置
2.1 真实服务器
服务器IP地址为192.168.2.254,安装nginx充当真实服务器,网站首页显示访客IP。
server {
listen 80;
server_name localhost;
default_type text/html;
return 200 'USER IP: $remote_addr';
}
data:image/s3,"s3://crabby-images/f4397/f4397a83f5969df6603b7339a14808e08acd68d0" alt=""
data:image/s3,"s3://crabby-images/ade12/ade1264c3e44dc30cccbf111d6911a8c1d38b4da" alt=""
2.2 负载均衡器
2.2.1 配置接口IP和网关等基本网络设置
负载均衡器(pfSense)的内侧IP为192.168.2.20,外侧IP为10.1.1.4,网关为10.1.1.1。
data:image/s3,"s3://crabby-images/fb866/fb8664a037f265621e9f3b3c1601f73fe142704c" alt=""
data:image/s3,"s3://crabby-images/74359/74359f7150b3f429f96e0a5df428350e5c5a8035" alt=""
2.2.2 配置负载均衡服务
- 添加VIP:
data:image/s3,"s3://crabby-images/bb83b/bb83bc4a46f34db6ac85709f14f50eba9858c41f" alt=""
- 创建服务资源池(真实服务):
data:image/s3,"s3://crabby-images/ac509/ac509e2ae1012cf6a64c0a8845815106cf406c28" alt=""
- 创建负载服务器(需要为电信和联通各创建一个服务,对应VIP为10.1.1.2和10.1.1.3):
data:image/s3,"s3://crabby-images/eb8c1/eb8c1278666d270e110ec24e6adf73c93b5afd58" alt=""
2.2.3 在两个接口上配置防火墙策略,放行负载均衡器发布的服务
data:image/s3,"s3://crabby-images/8ce11/8ce1141f257e4119fa1151041cc125cf1012984f" alt=""
data:image/s3,"s3://crabby-images/7da13/7da1365a45a266601847e9aeba22153be2cfbc5b" alt=""
2.3 防火墙
2.3.1 IP设置
- WAN电信:1.1.2.10
- WAN联通:1.1.3.10
- LAN:10.1.1.1
data:image/s3,"s3://crabby-images/b335f/b335fdf160eb6be0b612bf4486913de8d6d4089b" alt=""
2.3.2 添加映射(电信联通各一条)与防火墙允许策略
- 电信WAN口,映射80到10.1.1.2的80;
- 联通WAN口,映射80到10.1.1.3的80;
- 为两个接口添加映射以后,还需要建立防火墙策略放行对应两个端口。
data:image/s3,"s3://crabby-images/fce1d/fce1d600b7536160c83d8fd41c6812864a5f4ed5" alt=""
2.3.3 策略路由
- 源地址10.1.1.3使用出接口WanUnicom;
- 源地址10.1.1.2使用出接口WanTelecom。
data:image/s3,"s3://crabby-images/de9b6/de9b60992e060d1c509a53e4ad42c03451523e71" alt=""
data:image/s3,"s3://crabby-images/6fc3f/6fc3fb8f4302ca406dd0e76f3d9adba211400a41" alt=""
3 客户端测试
3.1 电信客户端(1.1.2.9)访问电信WAN口
data:image/s3,"s3://crabby-images/e6f8d/e6f8d082608a2fc49b29b74d0baeab25c9accf57" alt=""
3.2 联通客户端(1.1.3.9)访问联通WAN口
data:image/s3,"s3://crabby-images/938d5/938d599b776786f760cb26187475911c5bca00bf" alt=""