外网数据包访问 WEB 服务器,它认准的目的地址是 WEB 服务器的公网 IP 10.0.1.201,当数据包到达该 IP 后,需要修改目的地址为 WEB 服务器的内网地址 192.168.0.1,因此这里需要用到 DNAT 。也正是因为用了 DNAT,那么必须将规则加入 PREROUTING 链。因为在数据包的流向是:PREROUTING 链 ---> 路由表 ---> WEB 服务进程。如果不在 PREROUTING 链中修改目的 IP 为内网 IP,那么路由表就不知道要将访问数据包往哪里投递,从而造成访问失败。
这一规则不一定需要。如果 WEB 服务器仅是提供 WEB 服务,其它的东西都不要联网,那么只要设置上面第 1 条规则就足够了。如果像管理员也要从WEB 服务器上访问因特网,那么需要添加上面的 “出去” 规则。由于要将源 IP 地址 192.168.0.1 最终变为公网 IP 10.0.1.201,因此需要用到 SNAT,因此这里需要将规则加入 POSTROUTING 链中。