我有一个问题,尽管我有外部IP,但我无法使用curl访问服务。我遇到超时请求。这是我的服务
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
crawler-manager-1 NodePort 10.103.18.210 192.168.0.10 3001:30029/TCP 2h
redis NodePort 10.100.67.138 192.168.0.11 6379:30877/TCP 5h
这是我的Yaml服务文件:
apiVersion: v1
kind: Service
metadata:
annotations:
kompose.cmd: C:\ProgramData\chocolatey\lib\kubernetes-kompose\tools\kompose.exe
convert -f docker-compose.yml
kompose.version: 1.17.0 (a74acad)
creationTimestamp: null
labels:
io.kompose.service: crawler-manager-1
name: crawler-manager-1
namespace: cbpo-example
spec:
type: NodePort
externalIPs:
- 192.168.0.10
ports:
- name: "3001"
port: 3001
targetPort: 3001
selector:
io.kompose.service: crawler-manager-1
run: redis
status:
loadBalancer: {}
这是我的部署yml文件
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
annotations:
kompose.cmd: C:\ProgramData\chocolatey\lib\kubernetes-kompose\tools\kompose.exe
convert -f docker-compose.yml
kompose.version: 1.17.0 (a74acad)
creationTimestamp: null
labels:
io.kompose.service: crawler-manager-1
name: crawler-manager-1
namespace: cbpo-example
spec:
replicas: 1
strategy: {}
template:
metadata:
creationTimestamp: null
labels:
io.kompose.service: crawler-manager-1
spec:
hostNetwork: true
containers:
- args:
- npm
- start
env:
- name: DB_HOST
value: mysql
- name: DB_NAME
- name: DB_PASSWORD
- name: DB_USER
- name: REDIS_URL
value: redis://cbpo-redis
image: localhost:5000/manager
name: crawler-manager-1
ports:
- containerPort: 3001
resources: {}
restartPolicy: Always
status: {}
使用kubernetes时,有人像我这样遇到问题吗?我需要访问检查我的命名空间中的2个服务是否可以相互连接,非常感谢。
答案 0 :(得分:0)
您可以使用其DNS名称进行通信,而不必通过服务的IP地址进行通信。
为“普通”(非无头)服务分配了DNS A记录,用于 格式为my-svc.my-namespace.svc.cluster.local的名称。这样解决 服务的群集IP。
“无头”(没有群集IP) 还为服务分配了DNS A记录,用于填写表单名称 my-svc.my-namespace.svc.cluster.local。与普通服务不同,这 解析为服务选择的Pod的IP集。 希望客户消费该套装或使用标准 从集合中进行循环选择。
有关更多信息,请检查Kubernetes DNS for Services