为什么不能通过名称访问ClusterIP服务?

时间:2019-07-09 11:42:03

标签: docker kubernetes

我设置了一个简单的redis ClusterIP服务,供集群内部的php LoadBalancer服务访问。 php日志显示连接超时错误。 Redis服务不可访问。

'production'.ERROR: Operation timed out {"exception":"[object] (RedisException(code: 0): 
Operation timed out at /var/www/html/vendor/laravel/framework/src/Illuminate/Redis
/html/vendor/laravel/framework/src/Illuminate/Redis/Connectors/PhpRedisConnector.php(109): 
    Redis->connect('redis-svc', '6379', 0, '', 0, 0)

我的redis服务非常简单,所以我不知道出了什么问题:

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  labels:
    io.kompose.service: redis
  name: redis
spec:
  replicas: 1
  strategy: {}
  template:
    metadata:
      labels:
        io.kompose.service: redis
    spec:
      containers:
      - image: redis:alpine
        name: redis
        resources: {}
        ports:
        - containerPort: 6379
      restartPolicy: Always
status: {}
---
kind: Service
apiVersion: v1
metadata:
  name: redis-svc
spec:
  selector:
    app: redis
  ports:
  - protocol: TCP
    port: 6379
    targetPort: 6379
  type: ClusterIP

我确认redis-svc正在运行,为什么其他服务无法访问它

kubectl get service redis-svc                                                                                                                                  git:k8s*
NAME        TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)    AGE
redis-svc   ClusterIP   10.101.164.225   <none>        6379/TCP   22m

此SO kubernetes cannot ping another service说ping与服务的群集IP(实际上)不兼容。如何验证redis-svc是否可以访问?

----更新----

我的第一个问题是一个愚蠢的错误,但是我仍然不知道如何验证是否可以访问该服务(按其名称)。例如,我将服务名称更改为与部署名称相同,然后发现php无法再次访问redis。

kubectl get endpoints现在无济于事。

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: redis
...
status: {}
---
kind: Service
apiVersion: v1
metadata:
  name: redis
...

我的php是另一个带有env设置redis服务名称的服务

spec:
  containers:
  - env:
    - name: REDIS_HOST # the php code access this variable
      value: redis-svc #changed to "redis" when redis service name changed to "redis"

-----更新2 ------

我无法将Redis服务名称设置为“ redis”的原因是b / c“ kubelet adds a set of environment variables for each active Service”,因此名称为“ redis”的情况下,会有REDIS_PORT=tcp://10.101.210.23:6379会覆盖我自己的{ {1}} 但是我的PHP只是期望REDIS_PORT的值为6379

1 个答案:

答案 0 :(得分:4)

我运行了您提供的yaml配置,它创建了部署和服务。但是,当我运行以下命令时:

>>> kubectl get svc
NAME         TYPE        CLUSTER-IP      EXTERNAL-IP   PORT(S)    AGE
kubernetes   ClusterIP   10.96.0.1       <none>        443/TCP    5d14h
redis-svc    ClusterIP   10.105.31.201   <none>        6379/TCP   109s

>>>> kubectl get endpoints
NAME         ENDPOINTS             AGE
kubernetes   192.168.99.116:8443   5d14h
redis-svc    <none>                78s

如您所见,redis-svc的端点为none,这意味着该服务没有端点可连接。您在redis-svc中将选择器标签用作app: redis。但是吊舱中没有在服务中定义的选择器标签。将标签app: redis添加到吊舱模板即可。部署的完整工作yaml配置如下所示:

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  labels:
    io.kompose.service: redis
  name: redis
spec:
  replicas: 1
  strategy: {}
  template:
    metadata:
      labels:
        io.kompose.service: redis
        app: redis
    spec:
      containers:
      - image: redis:alpine
        name: redis
        resources: {}
        ports:
        - containerPort: 6379
      restartPolicy: Always
status: {}