Kubelet clusterDNS参数

Kubelet config file -- > clusterDNS

clusterDNS:

- "10.32.0.10"

The above is a flag passed to the kubelet file, i dont know what it refers to clsuter DNS ? Is it refers to VPC CIDR or any subnet CIDR ?

1 Answer

ActiveOldestScore

It is the address of the DNS server (probably CoreDNS but possibly kube-dns) for the cluster.

它是集群的 DNS 服务器地址(可能是 CoreDNS,也可能是 kube-dns) 

Kubernetes uses a DNS server within the cluster so pods can find each other using service names. This is the "cluster DNS" server. Every time a service is created, it gets registered in the DNS server.

Kubernetes 在集群中使用 DNS 服务器,因此 pod 可以使用服务名称找到彼此。这是“集群 DNS”服务器。每次创建服务时,它都会在 DNS 服务器中注册。 

In Linux, the /etc/resolv.conf file is where the DNS server is configured. If you want to use Google's public DNS server (8.8.8.8) your /etc/resolv.conf file has the entry nameserver 8.8.8.8.

在 Linux 中,该/etc/resolv.conf文件是配置 DNS 服务器的位置。如果您想使用 Google 的公共 DNS 服务器 (8.8.8.8),您的/etc/resolv.conf文件包含nameserver 8.8.8.8.

In Kubernetes, the kubelet process on a worker node configures each pod. Part of the configuration process is to create the file /etc/resolv.conf and specify the correct DNS server. That server is spec'ed by the clusterDNS configuration option.

在 Kubernetes 中,工作节点上的 kubelet 进程配置每个 pod。配置过程的一部分是创建文件/etc/resolv.conf并指定正确的 DNS 服务器。该服务器由clusterDNS配置选项指定。 

How you set it (if you even need to set it yourself) depends on how you're installing kubernetes. It ultimately depends on the CNI provider you're using, but also if you're doing "kubernetes the hard way" versus kubeadm.

 配置Kubernetes DNS服务kube-dns · Jimmy Songhttps://jimmysong.io/blog/configuring-kubernetes-kube-dns/

在我们安装Kubernetes集群的时候就已经安装了kube-dns插件,这个插件也是官方推荐安装的。通过将 Service 注册到 DNS 中,Kuberentes 可以为我们提供一种简单的服务注册发现与负载均衡方式。

CoreDNS作为CNCF中的托管的一个项目,在Kuberentes1.9版本中,使用kubeadm方式安装的集群可以通过以下命令直接安装CoreDNS。

kubeadm init --feature-gates=CoreDNS=true

您也可以使用CoreDNS替换Kubernetes插件kube-dns,可以使用 Pod 部署也可以独立部署,请参考Using CoreDNS for Service Discovery,下文将介绍如何配置kube-dns。

本文已归档到kubernetes-handbook中。

ClusterDNS和服务发现


Kubernetes 系统之上用于名称解析和服务发现的ClusterDNS是集群的核心附件之一,集群中创建的每个Service对象,都会尤其自动生成相关的资源记录。默认情况下,集群内各Pod资源会自动配置其作为名称解析服务器,并在其DNS搜索中包含它所属名称空间的域名后缀。

无论是使用kubeDNS还是CoreDNS,它们提供的基于DNS的服务发现解决方案都会负责解析以下资源记录(Resource Record)类型以实现服务发现。

  1. 拥有ClusterIP的Service资源,需要具有以下类型的资源记录。

    • A记录:<service>.<ns>.svc.<zone>. <ttl> IN A <cluster-ip>
    • SRV记录:_<port>._<proto>.<service>.<ns>.svc.<zone>. <ttl> IN SRV <weight> <priority> <port-number> <service>.<ns>.svc.<zone>
    • PTR记录:<d>.<c>.<b>.<a>.in-addr.arpa. <ttl> IN PTR <service>.<ns>.svc.<zone>
  2. Headless 类型的Service资源,需要具有以下类型的资源记录。

    • A记录:<service>.<ns>.svc.<zone>. <ttl> IN A <endpoint-ip>
    • SRV记录:_<port>._<proto>.<service>.<ns>.svc.<zone>. <ttl> IN SRV <weight> <priority> <port-number> <hostname>.<service>.<ns>.svc.<zone>
    • PTR记录:<d>.<c>.<b>.<a>.in-addr.arpa. <ttl> IN PTR <hostname>.<service>.<ns>.svc.<zone>
  3. ExternalName 类型的Service资源,需要具有CNAME类型的资源记录。

    • CNAME记录:<service>.<ns>.svc.<zone>. <ttl> IN CNAME <extname>

名称解析和服务发现是Kubernetes系统许多功能得以实现的基础服务,它通常是集群安装完成后应该立即部署的附加组件。使用kubeadm初始化一个集群时,它甚至会自动进行部署。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值