阿里云CentOS ECS Linux 在VPC环境下自建NAT访问外网,重启后依旧有效

本文介绍如何在阿里云VPC中自建NAT软路由,通过配置跳板机实现内网服务器访问外网,同时确保配置的持久化,避免因跳板机重启而失效。

最近工作中要用到阿里云VPC,发现VPC内的机器访问外网没法访问,购买阿里云的NAT服务最少也要12元/天,我就几台机器,10台都没到,感觉有点太浪费了,于是寻找自建NAT软路由的方式,发现网上确实有很多文章介绍了如何配置,但是缺少了一部分,就是配置持久化的操作,导致只要跳板机一重启,配置就归0了,这是不允许的,谁还能保证跳板机永远不重启,总有个万一不,所以将自己的配置过程公布下来,亲测有效:

1、假定已经在VPC下,购买了N台服务器

2、配置跳板机

     选择其中一台,配置固定IP或者配置EIP,让其能够访问外网,我们称之为跳板机

3、配置路由表

      在阿里云控制台“专有网络”-->“路由表”,选择自己的VPC对应的路由表记录,选择“管理”-->“添加路由条目”,添加一条:0.0.0.0/0的路由条目,下一跳,选择ECS,然后指定ECS为你的跳板机,具体如下图:

4、在跳板机上配置软路由

echo 1 > /proc/sys/net/ipv4/ip_forward  配置转发

cat /proc/sys/net/ipv4/ip_forward      检查下配置是不是1

使用 sysctl -p 命令重新加载使配置立即生效 

启用iptables的SNAT链: 
iptables -t nat -R POSTROUTING 1 -s 192.168.0.0/24 -j MASQUERADE
(其中192.168.0.0/24,为你的vpc内网网段,可以在阿里云的“专有网络”-->“交换机”栏目看到)

5、配置重启后生效

经过以上配置,VPC的ECS其实已经可以访问外网了,但是发现一个问题,跳板机不能重启,重启有就会又无法访问,所以还要进行如下配置,保证重启后,配置依旧有效:

保存防火墙规则
iptables-save > /etc/sysconfig/iptables

配置重启后自动执行相关命令,使软路由生效

vim /etc/rc.d/rc.local  增加如下配置:
iptables-restore < /etc/sysconfig/iptables
echo 1 > /proc/sys/net/ipv4/ip_forward
sysctl -p

 

<think>嗯,用户这次想解决阿里云ECS无法ping通百度的问题。从引用内容看,用户之前似乎关注过ECS的ping通问题,但这次特别指向了百度这个外部地址,说明问题场景更具体了。 用户可能正在调试服务器网络连接,而且提到"百度"这个具体目标,或许是在测试外网连通性。考虑到百度是常见检测地址,用户应该具备基础网络知识,但可能对云平台特殊配置不熟悉。ta现在应该有点着急,毕竟网络不通会影响后续所有操作。 仔细看三个引用:引用1强调客户端环境差异和MTR测试,引用2提到本地主机连接超时,引用3有数据库配置内容——显然引用3和当前问题关联最小。重点要结合引用1的链路测试思路和引用2的本地排查经验。 需要特别注意云服务器的特殊性:安全组默认禁止ICMP是很常见的坑,还有VPC路由表可能影响外部访问。用户没提是否其他网站也ping不通,这很关键——如果只是百度不通可能是目标限制,但用户没说明这个细节,我得把两种情况都覆盖到。 上次回答快速排序时结构很清晰,这次也要保持:先基础检查(安全组/实例状态),再分层测试(本机→内网→外网),最后用MTR工具。特别要强调阿里云特有的诊断工具,比如"实例健康状态"和"网络智能服务NIS",这些在引用1里提到过但没展开。 用户可能不知道MTR工具的使用方法,虽然引用1说"文档与帮助中有",但最好给出具体命令示例。考虑到用户系统可能是Linux或Windows,得准备两套命令。另外,ta如果做链路测试发现中间节点故障,不一定知道怎么处理,需要提示提交工单时要附上哪些数据(比如测试结果截图、时间戳)。 </think>以下是针对阿里云ECS无法ping通百度的问题排查方法,结合阿里云官方议和网络通用排查逻辑整理成**阶梯式排查步骤**: --- ### **第一步:基础环境检查** 1. **ECS实例状态** - 登录阿里云控制台 → 云服务器ECS → 实例列表 - 确认实例状态为 **"运行中"**,网络状态为 **"已分配公网IP"**(经典网络)或 **"已分配公网IPv4地址"**(VPC网络)[^1]。 2. **安全组规则** - 检查安全组是否放行 **ICMP协议**(ping依赖此协议): - 入方向规则:添加规则 `协议类型: ICMP(-1)`,源地址设为 `0.0.0.0/0` ![安全组ICMP规则示例](https://example.com/sg-icmp.png) *(图示:阿里云安全组配置界面)* [^1] 3. **操作系统防火墙** - **Linux**:执行命令关闭临时测试(测试后恢复) ```bash sudo iptables -I INPUT -p icmp --icmp-type any -j ACCEPT # 允许ICMP sudo systemctl stop firewalld # 临时关闭firewalld(CentOS) ``` - **Windows**: 控制面板 → Windows Defender 防火墙 → 高级设置 → 入站规则 → 启用 **"文件和打印机共享(回显请求 - ICMPv4-In)"** [^2]。 --- ### **第二步:分层网络诊断** 1. **测试ECS本地网络** - 在ECS实例内部执行命令: ```bash ping 127.0.0.1 # 检查本地协议栈 ping <ECS内网IP> # 检查内网驱动 ping <阿里云DNS> # 如 ping 223.5.5.5(阿里公共DNS) ``` - 若前两项通但DNS不通 → 检查 `/etc/resolv.conf`(Linux)或网卡DNS配置(Windows)[^1]。 2. **测试公网连通性** - 尝试ping其他公网地址(如阿里云官网IP `47.246.15.103`): ```bash ping 47.246.15.103 ``` - 若通 → **百度可能主动屏蔽ICMP**(常见于大型网站) - 若不通 → 继续下一步[^1][^2]。 --- ### **第三步:深度链路分析** 1. **双向MTR测试** - **从ECS向百度发起测试**: ```bash mtr --report --tcp --port 80 www.baidu.com # 使用TCP模拟HTTP流量 ``` - **从本地PC向ECS公网IP测试**: ```bash mtr --report <ECS公网IP> ``` - **关键关注点**: - 最后一跳是否超时(目标服务器限制) - 中间节点是否存在 `100% Loss`(网络中断点)[^1]。 2. **阿里云网络诊断工具** - 控制台 → **云服务器ECS → 实例 → 网络诊断** - 使用 **"实例健康状态"** 和 **"网络智能服务NIS"** 自动检测路由异常。 --- ### **第四步:特殊场景排查** 1. **VPC网络限制** - 若使用VPC网络,检查: - 路由表是否有指向百度IP段的**自定义路由**(如NAT网关配置错误) - 虚拟交换机绑定的**NAT网关/公网网关**状态是否正常 [^1]. 2. **运营商策略干扰** - 部分地域运营商可能过滤ICMP(如校园网/企业专线) - 使用 **TCP端口测试** 替代ping: ```bash telnet www.baidu.com 80 # 检查80端口连通性 curl -Iv https://www.baidu.com # 检查HTTPS握手 ``` --- ### **结论与议** - ✅ **若telnet/curl通而ping不通** → 百度屏蔽ICMP,属正常现象,**无需处理**。 - ❌ **若所有测试均失败**: 1. 提交阿里云工单,附上 **双向MTR报告** 和 **安全组/防火墙配置截图** 2. 描述测试时间、实例ID、错误现象([工单模板参考](https://help.aliyun.com/document_detail/108195.html))[^1]。 > **注**:阿里云部分Region(如海外节点)访问国内服务可能存在跨境延迟,议用 `traceroute` 观察骨干网路径。 ---
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值