kubernetes - 如何为 statefulset headless 服务获取 SRV DNS 地址

标签 kubernetes minikube kube-dns srv kubernetes-statefulset

有状态集 srv 记录的 dns 查找问题

我的yaml文件

kind: List
apiVersion: v1
items:
- apiVersion: v1
  kind: Service
  metadata:
    name: sfs-svc
    labels:
      app: sfs-app
  spec:
    ports:
    - port: 80
      name: web
    clusterIP: None
    selector:
      app: sfs-app
- apiVersion: apps/v1
  kind: StatefulSet
  metadata:
    name: web
  spec:
    selector:
      matchLabels:
        app: sfs-app # has to match .spec.template.metadata.labels
    serviceName: "sfs-svc"
    replicas: 3 
    template:
      metadata:
        labels:
          app: sfs-app # has to match .spec.selector.matchLabels
      spec:
        terminationGracePeriodSeconds: 10
        containers:
        - name: test-container
          image: nginx
          imagePullPolicy: IfNotPresent
          command: [ "sh", "-c"]
          args:
          - while true; do
              printenv MY_NODE_NAME MY_POD_NAME MY_POD_NAMESPACE >> /var/sl/output.txt;
              printenv MY_POD_IP >> /var/sl/output.txt;
              date >> var/sl/output.txt; 
              cat /var/sl/output.txt;
              sleep 999999;
            done;
          env:
            - name: MY_NODE_NAME
              valueFrom:
                fieldRef:
                  fieldPath: spec.nodeName
            - name: MY_POD_NAME
              valueFrom:
                fieldRef:
                  fieldPath: metadata.name
            - name: MY_POD_NAMESPACE
              valueFrom:
                fieldRef:
                  fieldPath: metadata.namespace
            - name: MY_POD_IP
              valueFrom:
                fieldRef:
                  fieldPath: status.podIP
          volumeMounts:
          - name: www
            mountPath: /var/sl
    volumeClaimTemplates:
    - metadata:
        name: www
      spec:
        accessModes: [ "ReadWriteOnce" ]
        #storageClassName: classNameIfAny
        resources:
          requests:
            storage: 1Mi


$ Kubectl 集群信息

Kubernetes master is running at https://192.168.99.100:8443 KubeDNS is running at https://192.168.99.100:8443/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy



$ kubectl 版本

Client Version: version.Info{Major:"1", Minor:"13", GitVersion:"v1.13.3", GitCommit:"721bfa751924da8d1680787490c54b9179b1fed0", GitTreeState:"clean", BuildDate:"2019-02-01T20:08:12Z", GoVersion:"go1.11.5", Compiler:"gc", Platform:"linux/amd64"} Server Version: version.Info{Major:"1", Minor:"14", GitVersion:"v1.14.1", GitCommit:"b7394102d6ef778017f2ca4046abbaa23b88c290", GitTreeState:"clean", BuildDate:"2019-04-08T17:02:58Z", GoVersion:"go1.12.1", Compiler:"gc", Platform:"linux/amd64"}



$ kubectl 获取 po,svc,statefulset
> NAME        READY   STATUS    RESTARTS   AGE
> pod/web-0   1/1     Running   0          45m
> pod/web-1   1/1     Running   0          45m
> pod/web-2   1/1     Running   0          45m
> 
> NAME                 TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)   AGE
> service/kubernetes   ClusterIP   10.96.0.1    <none>        443/TCP   46m
> service/sfs-svc      ClusterIP   None         <none>        80/TCP    45m
> 
> NAME                   READY   AGE
> statefulset.apps/web   3/3     45m
> 

问题:我没有获得 statefulset headless 服务的 DNS 地址

当我尝试 $ nslookup sfs-svc.default.svc.cluster.local
> Server:       127.0.0.53
> Address:  127.0.0.53#53
> 
**> ** server can't find sfs-svc.default.svc.cluster.local: SERVFAIL**
> 

最佳答案

我的第一个猜测是,您正在运行 nslookup来自 localhost而不是从 pod 内部.

我尝试了yaml,我只能在运行nslookup sfs-svc.default.svc.cluster.local时重新生成这个问题从本地主机。

无论如何,要检查服务的 DNS 条目,请运行 nslookup从 pods 内部。这是一个例子,

~ $ kubectl run -it --rm --restart=Never dnsutils2 --image=tutum/dnsutils  --command -- bash

root@dnsutils2:/# nslookup sfs-svc.default.svc.cluster.local
Server:     10.96.0.10
Address:    10.96.0.10#53

Name:   sfs-svc.default.svc.cluster.local
Address: 172.17.0.6
Name:   sfs-svc.default.svc.cluster.local
Address: 172.17.0.5
Name:   sfs-svc.default.svc.cluster.local
Address: 172.17.0.4

root@dnsutils2:/# exit

关于kubernetes - 如何为 statefulset headless 服务获取 SRV DNS 地址,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56118024/

相关文章:

Docker 在 Kubernetes 中使用 docker 私有(private)注册表拉取没有 ssl 的镜像

kubernetes - 通过 DNS 或静态 ClusterIP 为 PersistentVolume 配置 NFS 服务器

kubernetes - core_dns 卡在 ContainerCreating 状态

mongodb - 如何在 kubernetes 中通过身份验证运行 mongo

PostgreSQL bitnami Helm Chart 不更新用户密码

deployment - 当服务在 minikube 中正确部署时,为什么应用部署状态为 "Available:0"?

docker - Minikube - 无法访问updates.jenkins.io

kubernetes - 如何在 Google Cloud Platform VM 上启用 VT-X/AMD-v?

Kubernetes DNS 间歇性失败,kube-dns 服务和 CoreDNS pod 似乎正常

Kubernetes 自动缩放器 objective-c PUUtilizationPercentage