我正在尝试创建两个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
答案 0 :(得分:1)
似乎没有与您的群集中的这些标签匹配的pod,因此DNS查询不会返回任何内容。这是预期的。
启动相应的窗格,您应该会看到A记录列表。
请注意,据我所知,这些A记录并未随机播放,因此您的客户应该使用DNS答案并执行自己的循环播放。