Kubernetes无头服务A Record循环赛

时间:2016-08-25 18:37:24

标签: dns kubernetes google-kubernetes-engine skydns

我正在尝试创建两个kubernetes服务,一个是带有集群IP的负载均衡器,另一个是无头(没有集群IP),而是返回pod ip地址的A记录循环集合(应该做的,根据http://kubernetes.io/docs/user-guide/services/#headless-services)。

我需要这样做,因为我需要一个动态的pod ip集合来进行自动群集和服务发现。

我的服务如下:

apiVersion: v1
kind: Service
metadata:
  name: rabbitmq
  labels:
    app: rabbitmq
    tier: messaging
spec:
  ports:
  - name: amqp
    port: 5672
    targetPort: 5672
  selector:
    app: rabbitmq
    tier: messaging
---
apiVersion: v1
kind: Service
metadata:
  name: rabbitmq-cluster
  labels:
    app: rabbitmq
    tier: messaging
spec:
  clusterIP: None
  ports:
  - name: amqp
    port: 5672
    targetPort: 5672
  selector:
    app: rabbitmq
    tier: messaging

通过这两项服务,我得到以下内容:

$ kubectl get services
NAME               CLUSTER-IP      EXTERNAL-IP       PORT(S)     AGE
rabbitmq           10.23.255.174   <none>            5672/TCP    7m
rabbitmq-cluster   None            <none>            5672/TCP    7m

群集IP的DNS(来自另一个pod)工作:

[root@gateway-3738159135-a7wp9 app]# nslookup rabbitmq.td-integration
Server:     10.23.240.10
Address:        10.23.240.10#53

Name:   rabbitmq.td-integration.svc.cluster.local
Address: 10.23.255.174

但是,“无头”服务的dns不会返回:

[root@gateway-3738159135-a7wp9 app]# nslookup rabbitmq-cluster.td-integration
Server:     10.23.240.10
Address:        10.23.240.10#53

** server can't find rabbitmq-cluster.td-integration: NXDOMAIN

1 个答案:

答案 0 :(得分:1)

似乎没有与您的群集中的这些标签匹配的pod,因此DNS查询不会返回任何内容。这是预期的。

启动相应的窗格,您应该会看到A记录列表。

请注意,据我所知,这些A记录并未随机播放,因此您的客户应该使用DNS答案并执行自己的循环播放。