K8S的Pod为什么可以解析访问集群之外的域名地址

对于以前刚学习的自己,知道Coredns是做K8S集群内解析的,但一直搞不懂主机node能访问网络,启动的Pod集群之外的域名服务也可以访问的疑问进行下说明。

DNS解析路径

Pod 发起外部请求 → CoreDNS 接收并识别为外部域名 → 转发到 Node 配置的上游 DNS → 上游 DNS 解析并返回结果 → Pod 访问目标 IP

DNS的对接配置

进入pod,然后查看/etc/resolv.conf

shell 复制代码
cat /etc/resolv.conf

nameserver 10.96.0.10:集群 DNS 服务的地址

search rook-ceph.svc.cluster.local svc.cluster.local cluster.local:域名搜索列表

options ndots:5:域名解析的 "点数量" 规则

也就是说Pod会找到coreDNS解析k8s内部这些域名,那么这些之外的域名呢?

shell 复制代码
kubectl  get   configmap coredns  -n kube-system -o yaml
yaml 复制代码
.:53 {
    errors          # 记录错误日志
    health          # 健康检查
    kubernetes cluster.local in-addr.arpa ip6.arpa {  # 处理集群内域名解析(Service、Pod等)
       pods insecure
       fallthrough in-addr.arpa ip6.arpa
    }
    prometheus :9153  # 监控指标
    forward . /etc/resolv.conf  # 关键:将非集群内的域名请求转发到上游 DNS
    cache 30           # 缓存解析结果
    loop               # 检测循环转发
    reload             # 自动重载配置
    loadbalance        # 负载均衡上游 DNS
}

CoreDns配置的上游DNS就是node本身的/etc/resolv.conf,forward . /etc/resolv.conf关键配置项的意思就是非集群内的域名请求转发到node本身的/etc/resolv.conf,然后看下node本身的/etc/resolv.conf。

shell 复制代码
cat /etc/resolv.conf

最后通过node本身的/etc/resolv.conf配置将dns请求转发到外部dns中,解析完成后就可以层层返回请求,已到达Pod解析外部域名的实现。

相关推荐
阿里云云原生15 小时前
香港站【企业 AI Agent 工程化实战专场】来啦,邀您7月9日见!
云原生·agent
阿里云云原生18 小时前
研发域与运维域的“数字握手”:通过 Agentic Skills 实现 DevOps 全链路自动化
云原生
运维开发故事3 天前
基于 Arthas 的多集群在线诊断系统设计与实现
kubernetes
Patrick_Wilson5 天前
从「改个端口」到 502:Next.js on k8s 的容器端口、Service 映射与 env 覆盖
docker·kubernetes·next.js
阿里云云原生5 天前
AI 开发新常态:当 Cursor、Claude、Codex 并行,如何统一管理散落的 Skill 资产?
云原生·ai编程
赵文宇5 天前
CoreDNS大屏看板、监控、和企业微信告警通知
dns
探索云原生5 天前
K8s 1.36 这个 GA 特性,把 initContainer 拉模型的 hack 干掉了
ai·云原生·kubernetes
云恒要逆袭5 天前
运行你的第一个Docker容器
后端·docker·容器
Java之美5 天前
从edge-trigger到level-trigger,谈谈 Kubernetes controller 的开发范式
云原生
阿里云云原生6 天前
深度解构:当 Append-only 的 SLS 遇上 Update/Delete,是如何实现设计权衡的?
云原生