阿里云平台使用的ack创建的pod与服务器中的MongoDB不在同一网段如何解决

在阿里云 Kubernetes (ACK) 环境中,Pod 在 100.210.20.0/24 网段,服务器(ECS)在 100.210.10.0/24 网段,默认情况下 Pod 无法直接访问服务器上的 MongoDB。原因和解决方案如下:


一、网络不通的原因

  1. 跨子网隔离

    • Pod 网段 (100.210.20.0/24) 和服务器网段 (100.210.10.0/24) 属于不同子网
    • 阿里云 VPC 默认不会为不同子网自动配置路由
  2. 安全组限制

    • 服务器的安全组可能未放行 K8s Pod 网段
    • MongoDB 默认监听 127.0.0.1 或内网 IP,未暴露给其他网段
  3. 容器网络特性

    • Pod 网络是 Overlay 网络,与主机网络隔离
    • Pod 访问跨子网服务需要 VPC 路由支持

二、解决方案

通过以下任一方案打通网络:

方案一:配置 VPC 路由表
graph TD A[Pod 100.210.20.5] -->|跨子网访问| B[路由表] B --> C[添加路由规则] C --> D[目标:100.210.10.0/24
下一跳:服务器ECS] D --> E[MongoDB服务器]
  1. VPC 控制台路由表添加路由条目
    • 目标网段100.210.10.0/24
    • 下一跳类型ECS 实例
    • 选择 MongoDB 服务器
  2. 反向路由(服务器到Pod):
    • 目标网段100.210.20.0/24
    • 下一跳Kubernetes Worker 节点
方案二:调整安全组规则

ECS 控制台安全组 → 添加规则:

yaml 复制代码
规则方向:入方向
协议类型:TCP
端口范围:27017(或MongoDB端口)
授权对象:100.210.20.0/24  # Pod网段
优先级:1(高优先级)
方案三:修改 MongoDB 绑定地址

在 MongoDB 服务器执行:

bash 复制代码
# 修改配置文件
sudo nano /etc/mongod.conf

修改为:

yaml 复制代码
net:
  bindIp: 0.0.0.0  # 监听所有地址
方案四:通过 Kubernetes Service 暴露

在 K8s 集群中创建 Service:

yaml 复制代码
apiVersion: v1
kind: Service
metadata:
  name: mongo-external
spec:
  type: ExternalName
  externalName: mongodb-server.private  # 服务器内网域名
  ports:
  - port: 27017

Pod 通过 mongo-external:27017 访问


三、连通性测试方法

bash 复制代码
# 1. 在Pod中测试端口连通性
kubectl exec -it <pod-name> -- telnet 100.210.10.x 27017

# 2. 在服务器抓包验证
sudo tcpdump -i any port 27017 and host 100.210.20.x

四、阿里云特殊配置建议

  1. 使用 VPC对等连接

    对等连接 K8s VPC ECS VPC

    • 专有网络控制台创建双向对等连接
  2. 启用 NAT网关

    • 为 Pod 配置 SNAT,使其使用 Worker 节点 IP 访问外部服务

重要提示 :生产环境建议组合使用方案一 + 方案二,既保持网络隔离又保证连通性。修改后重启 MongoDB 服务生效。

相关推荐
清水白石00830 分钟前
解构异步编程的两种哲学:从 asyncio 到 Trio,理解 Nursery 的魔力
运维·服务器·数据库·python
代码游侠1 小时前
应用——智能配电箱监控系统
linux·服务器·数据库·笔记·算法·sqlite
Tisfy1 小时前
网站访问耗时优化 - 从数十秒到几百毫秒的“零成本”优化过程
服务器·开发语言·性能优化·php·网站·建站
2501_933513041 小时前
Linux下载离线rpm和依赖包的方法
linux·运维·服务器
闲人编程1 小时前
消息通知系统实现:构建高可用、可扩展的企业级通知服务
java·服务器·网络·python·消息队列·异步处理·分发器
XiaoHu02071 小时前
Linux多线程(详细全解)
linux·运维·服务器·开发语言·c++·git
Xの哲學1 小时前
Linux Platform驱动深度剖析: 从设计思想到实战解析
linux·服务器·网络·算法·边缘计算
gaize12132 小时前
服务器怎么选择与配置才能满足企业需求?
运维·服务器·架构
清风6666663 小时前
基于单片机的电加热炉智能温度与液位PID控制系统设计
单片机·嵌入式硬件·mongodb·毕业设计·课程设计·期末大作业
列御寇3 小时前
MongoDB分片集概述
数据库·mongodb