Kubernetes 为pod指定DNS

在k8s里面,默认创建pod会给pod默认分配一个默认的dns,这个dns是哪来的呢?可不可以改成其他的dns呢?

先进入到pod里面来,可以看到这里面默认设置的DNS服务器,这个服务器地址为10.96.0.10。这个地址是k8s自动的为pod设置的dns服务器。通过coredns来创建的。

为什么会设置为这个地址呢?可不可以修改这个地址呢?

在创建pod的时候,首先要将请求发送给apiserver,apiserver将请求发送给kubelet,由kubelet去调用runtime去将对应的容器创建出来。

这里有dnsPolicy,设置为ClusterFirst ,表示优先使用集群里面的DNS服务器,那么集群里面的DNS服务器是谁呢?

kubelet是知道的,因为最终都是有kubelet告诉runtime,runtime是什么都不懂,全部由kubelet去告诉runtime怎么创建pod。

cat /var/lib/kubelet/config.yaml

所以说当创建pod的时候,并没有指定使用的是哪个DNS服务器,pod里面指定的是clusterfirst,优先使用集群里面的dns,kubelet知道既然使用集群里面的dns,那么集群里面的dns就是clusterdns 10.96.0.10。

所以kubelet创建的容器dns地址就是10.96.0.10。那么创建pod的时候可不可以去修改它所使用的dns呢?

这里的dnspolicy改为none,也即是不使用任何的dns。到底使用哪个由我自己来配置。

如果需要配置如下:

这样创建的pod不再使用集群里面的dns了,而是使用指定的dns,

上面就是在创建pod的时候具体怎么设置dns的。

相关推荐
mxpan2 小时前
Alpine Docker 容器中安装包缓存与 C/C++ 运行问题
运维·docker·容器
ldj20204 小时前
Docker制作镜像
java·docker·容器
yumuing blog4 小时前
实战指南:部署MinerU多模态文档解析API与Dify深度集成(实现解析PDF/JPG/PNG)
docker·pdf·ocr·markdown·dify·parse·mineru
tswddd4 小时前
项目:Gitlab HSD CI/CD总结
ci/cd·kubernetes·gitlab
18你磊哥8 小时前
Docker Compose部署Spring Cloud 微服务系统
spring cloud·docker·微服务
郝同学的测开笔记9 小时前
深入理解 kubectl port-forward:快速调试 Kubernetes 服务的利器
后端·kubernetes
Ac157ol11 小时前
不同系统修改 Docker Desktop 存储路径(从C盘修改到D盘)
运维·docker·容器
Cloud孙文波12 小时前
k8s 收集event事件至Loki
云原生·kubernetes·event
量化投资和人工智能13 小时前
【K8S】详解Labels 和 Annotations
运维·docker·云原生·容器·kubernetes
陌殇殇殇14 小时前
基于Helm部署Rancher容器管理平台
linux·云原生·容器·kubernetes·rancher