- Published on
How to build a network with FortiGate in the cloud
- Authors
- Name
- Sunway
1.配置 VPC 专有网络
data:image/s3,"s3://crabby-images/a61ed/a61ed2970142ba6c1c3b3f265f620b5ee9e02de5" alt="CreateAliVPC"
data:image/s3,"s3://crabby-images/301b2/301b2f98ad8f5699ce1a23881895656f3c99b476" alt="AliNetTopology"
如上所示:创建 VPC
时需要创建至少 1
个交换机来划分 VPC
下的子网
交换机功能是用来划分 VPC
下不同的子网,为云服务实例提供网络连接,同一 VPC
下的不同交换机之间内网互通。(可以为服务绑定不同可用区的交换机,提升服务的可用性)
10.0.1.0/24
子网下最多可以绑定 2^8 - 4 = 252
个云服务实例。减 4
而不是减 2
的原因是因为阿里云需要 .253 .254
ip作为网关 data:image/s3,"s3://crabby-images/8dc9f/8dc9f878b51a2c75912ae73a8385ba9d22720537" alt="ReduceIPCountReason"
2.内网 ECS 实例访问外网
2.1 配置辅助网卡
创建 1 台具备公网 IP 的 ECS 示例作为 VPC 门户,下面以 Fortigate 防火墙为例
data:image/s3,"s3://crabby-images/326bd/326bd65bd0c28db7ba34a914dfc662b2c36f7d68" alt="CreateFortiECS"
- 创建
Fortigate ECS
时可以使用云市场镜像的BYOL Edition(Bring Your Own License)
/License Included Edition
/CustomImage
然后创建 EIP
辅助网卡作为内网流量出入口, 如当前 VPC 下有 2 个 ECS 实例,1 个业务服务器,1 个 Fortigate
实例
data:image/s3,"s3://crabby-images/2fe3b/2fe3b45ec7e82495cf9dc5824b3c8bbd8f4bbf24" alt="CreateEIP1"
辅助网卡和业务服务器位于同一网段: 10.1.20.xxx
(交换机网段:10.1.20.0/24
), 一般选择10.1.20.252
,辅助网卡的安全组
和业务服务器共用
data:image/s3,"s3://crabby-images/b1e60/b1e60d7465a3fb4df46893f723c0fd3b303a9cf3" alt="CreateEIP2"
2.2 配置 Fortigate Interface
配置Interface
Interface port1(WAN)
默认绑定Forigate
实例的私网主网卡:10.1.21.252/255.255.255.0
Interface port2(LAN)
默认绑定Forigate
实例的私网辅助网卡:10.1.20.252/255.255.255.0
data:image/s3,"s3://crabby-images/13ec6/13ec6aed4de0df5b17fe1fe87353a400d60f3558" alt="ConfigInterface1"
data:image/s3,"s3://crabby-images/f1d53/f1d53c1bcdfccc7063e2b86e6b63a6d635f6f6cf" alt="ConfigInterface2"
2.3 配置 Fortigate Static Routes
data:image/s3,"s3://crabby-images/f83c0/f83c07d54c97809c18bb861c76df49a66d05cf34" alt="ConfigStaticRoute"
port1
通过网关10.1.21.253
访问互联网0.0.0.0/0
port2
通过网关10.1.20.253
访问内网10.0.0.0/8
2.4 配置 Fortigate Firewall policy
Fortigate Firewall Policy策略如下:
data:image/s3,"s3://crabby-images/0d9f9/0d9f92f4a298bcdc815261c5eb9858c05a619293" alt="ConfigFirewallPolicy1"
阿里云路由表条目配置如下,该VPC
下的交换机的下一跳为刚刚创建的辅助网卡,对上 Fortigate
上的 port2(LAN)
data:image/s3,"s3://crabby-images/3e259/3e259f63ed57027a39353961a87e91d1f36faf3f" alt="ConfigFirewallPolicy2"
- 流量从
VPC
内网的交换机通过路由表跳转到辅助网卡,辅助网卡对应Fortigate port2
- 因为
port2
连接了内网10.0.0.0/8
, 然后流量可以从port2 → port1
,至此内网的机器可以通过Fortigate
访问外网
3.外网访问专有网络内的实例
3.1 配置 Fortigate Virtual IPs
data:image/s3,"s3://crabby-images/b0e3f/b0e3f4f3dca6b97721a9bea8a34a891f44cad721" alt="ConfigVirtualIPs"
如上所示,配置Virtual IPs
规则, 当流量通过 Fortigate
公网ip:port
进来后, 映射(Mapper To)到内网的 ip:port
3.2 配置 Fortigate Firewall Policy
data:image/s3,"s3://crabby-images/ccf77/ccf775d6e9ec1328fcd5c18ceee8bfc1f4972e36" alt="ConfigVirtualIPsRule"
port1→port2
路径访问内网补充:安全组
是云平台提供的,在 ECS
外层,tcpdump
无法抓取被安全组过滤的流量,当通过 Port1->Port2
访问内网时,需要确保 ECS
所绑定的安全组策略
配置正确