D26 kubernetes Service服务发现

1、简介

	kubernetes提供了两种的服务发现模式,环境变量和DNS。pod中的应用程序可以通过它们访问其他Service

2、环境变量

	当创建一个pod时,kubernetes默认会见同一命名空间下的所有Service信息以环境变量的形式注入pod中。其中SERVICE_NAME_SERIVICE_HOST环境变量保存了Service的虚拟IP地址。SERVICE_NAME_SERIVICE_PORT环境变量保存了Service的端口号。这样,容器中的应用程序可以通过这些变量来获取Service的访问地址
  • 创建一个临时pod并进入容器中以执行env命令查看环境变量
[root@k8s-master ~]# kubectl run -it --rm  test3 --image=uhub.service.ucloud.cn/librarys/busybox:latest -- sh
If you don't see a command prompt, try pressing enter.
/ # env | grep _SERVICE_
POD_READINESS_SERVICE_PORT=80
KUBERNETES_SERVICE_PORT=443
SEARCH_API_SERVICE_PORT=80
PORTAL_SERVICE_HOST=10.107.176.157
NGINX_SERVICE_HOST=10.99.169.247
PORTAL_SERVICE_PORT=80
NGINX_SERVICE_PORT=180
MYSQL_PROXY_SERVICE_HOST=10.98.237.25
KUBERNETES_SERVICE_PORT_HTTPS=443
KUBERNETES_SERVICE_HOST=10.96.0.1
POD_READINESS_SERVICE_HOST=10.107.77.122
SEARCH_API_SERVICE_HOST=10.108.242.82
MYSQL_PROXY_SERVICE_PORT=3306

3、DNS

	kubernetes默认使用coredns作为集群内部的dns服务,它主要负责解析Service名称,这允许集群中的应用程序可以通过Service名称进行通信,而无需硬编码具体的虚拟IP地址
	Service名称的域名格式为SERVICE_NAME.NAMESPACE>svc.cluster.local
  • 在busybox容器中进行域名解析测试,结果如下
/ # nslookup nginx.default.svc.cluster.local
Server:		10.96.0.10
Address:	10.96.0.10:53

Name:	nginx.default.svc.cluster.local
Address: 10.99.169.247

域名 nginx.default.svc.cluster.local解析的IP正式对应的虚拟IP地址,这意味着可以通过这个域名访问Service
[root@k8s-master ~]# kubectl get service
NAME            TYPE           CLUSTER-IP       EXTERNAL-IP   PORT(S)        AGE
nginx           ClusterIP      10.99.169.247    <none>        180/TCP        23h

3.1、coredns工作流程

	在容器中访问一个域名时,系统会将dns查询请求发送到/etc/resolv.conf文件中配置的dns服务器地址,既coredns的虚拟IP地址。coredns服务接收到dns查询的请求后,根据Service名称解析为相应的虚拟IP地址。coredns工作流程如下所示

image

  • 容器中的/etc/resolv.conf文件的内容如下
/ # cat /etc/resolv.conf
nameserver 10.96.0.10
search default.svc.cluster.local svc.cluster.local cluster.local
options ndots:5
  • 上述各字段含义如下:
nameserver:DNS服务器IP地址。这里的值为10.96.0.10,既Coredns Service的虚拟IP地址
search:DNS查询搜索域列表
options:选线参数。ndots参数表示,如果域名中的 . 少于5个,系统会先将域名与上述search搜索域列表中的 内容按顺序进行拼接并依次进行DNS查询。如果解析失败,系统将尝试使用原域名进行DNS查询。例如,对于域名“nginx”,系统将使用完整域名“nginx.default.svc.cluster.local”进行dns查询
  • 查看Coredns pod和service对象
[root@k8s-master ~]# kubectl get pod,svc -l k8s-app=kube-dns -n kube-system
NAME                           READY   STATUS    RESTARTS       AGE
pod/coredns-66f779496c-ftmmv   1/1     Running   24 (76m ago)   94d
pod/coredns-66f779496c-tdkk7   1/1     Running   25 (76m ago)   94d

NAME               TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)                  AGE
service/kube-dns   ClusterIP   10.96.0.10   <none>        53/UDP,53/TCP,9153/TCP   94d

3.2 Pod的DNS策略

	Pod的DNS策略指定了Pod内部用于域名解析的策略。在Pod配置中,“dnsPolicy”字段的设置具有以下可选值
  • ClusterFirst:默认值。优先使用机器内部的Coredns服务进行域名解析,如果无法解析,则尝试使用主机上配置的DNS服务器进行域名解析
    ClusterFirstWithHostNet:作用域ClusterFirst一样,但仅在pod运行在主机网络命名空间中(hostnetwork: true)时使用,确保pod仍然可以使用集群内部的Coredns服务进行域名解析
    Default:Pod使用主机上配置的dns服务器进行域名解析,这意味着它不支持service名称解析
    None:当设置为None时,需要通过“dnsConfig”字段来手动配置dns参数,如dns服务器、搜索路径等,以满足特定dns解析需求

PodDNS策略的配置示例如下:

[root@k8s-master k8s]# cat pod-dns-policy.yaml
apiVersion: v1
kind: Pod
metadata:
  name: pod-dns-policy-test
spec:
  containers:
  - image: uhub.service.ucloud.cn/k8s-repo/busybox:1.28
    name: busybox
    command: ['/bin/sh', '-c', 'sleep 1d']
  hostNetwork: true
  dnsPolicy: ClusterFirstWithHostNet

[root@k8s-master k8s]# kubectl apply -f pod-dns-policy.yaml
pod/pod-dns-policy-test created
[root@k8s-master k8s]# kubectl get pod
NAME                  READY   STATUS    RESTARTS        AGE
pod-dns-policy-test   1/1     Running   0               3s

3.3自定义DNS记录

	Coredns允许用户自定义DNS记录,以满足更多的域名解析需求。例如,集群中的应用程序可以通过自定义的域名mysql.k8s.com访问外部的MySQL服务。编辑Coredns配置文件,存储在ConfigMap对象中
posted @ 2024-09-26 10:06  Hello_worlds  阅读(10)  评论(0编辑  收藏  举报