Kubernetes NAT 流服务器 - 连接被拒绝

Posted

技术标签:

【中文标题】Kubernetes NAT 流服务器 - 连接被拒绝【英文标题】:Kubernetes NAT Streaming Server - Connection refused 【发布时间】:2020-11-08 16:24:42 【问题描述】:

我正在使用 NATS 开发一个微服务 Web 应用程序(React 和 Node),并在 GCP Kubernetes 集群上运行它。

我无法连接到 NAT 流媒体服务器 pod。端口 4222 和 8222 已打开。我收到 connection denied 错误。

错误:

Using ts-node version 8.10.2, typescript version 3.9.7
NatsError: Could not connect to server: Error: connect ECONNREFUSED 10.32.13.69:4222
    at Socket.<anonymous> (/app/node_modules/nats/lib/nats.js:801:26)
    at Socket.emit (events.js:314:20)
    at emitErrorNT (internal/streams/destroy.js:100:8)
    at emitErrorCloseNT (internal/streams/destroy.js:68:3)
    at processTicksAndRejections (internal/process/task_queues.js:80:21) 
  code: 'CONN_ERR',
  chainedError: Error: connect ECONNREFUSED 10.32.13.69:4222
      at TCPConnectWrap.afterConnect [as oncomplete] (net.js:1144:16) 
    errno: -111,
    code: 'ECONNREFUSED',
    syscall: 'connect',
    address: '10.32.13.69',
    port: 4222
  

NAT 流服务器的 Pod + 服务文件

apiVersion: apps/v1
kind: Deployment 
metadata: 
    name: nats-depl
spec:
    replicas: 1
    selector: 
        matchLabels: 
            app: nats
    template:
        metadata: 
            labels: 
                app: nats
        spec:
            containers: 
                - name: nats 
                  image: nats-streaming:0.17.0 
                  ## args provides arguments to the primary
                  ## cmd executed when container starts 
                  args: [
                    '--port', '4222',
                    '--http_port', '8222',
                    '--hb_interval', '5s',      
                    '--hb_timeout', '5s',       
                    '--hb_fail_count', '2',     
                    '--stan_debug', 
                    '--cluster_id', 'ticketing'
                  ]

服务配置:

---
apiVersion: v1
kind: Service 
metadata:
    name: nats-srv 
spec: 
    type: ClusterIP
    selector: 
        apps: nats 
    ports: 
        - name: client 
          protocol: TCP 
          port: 4222 
          targetPort: 4222 
        - name: monitoring 
          protocol: TCP 
          port: 8222 
          targetPort: 8222 

$ kubectl 描述服务 nats-srv

$ kubectl describe service nats-srv
Name:              nats-srv
Namespace:         default
Labels:            app.kubernetes.io/managed-by=skaffold-v1.11.0
                   skaffold.dev/builder=google-cloud-build
                   skaffold.dev/cleanup=true
                   skaffold.dev/deployer=kubectl
                   skaffold.dev/run-id=59070209-9ab7-47cd-ab0f-cdd91797b1a7
                   skaffold.dev/tag-policy=git-commit
                   skaffold.dev/tail=true
Annotations:       kubectl.kubernetes.io/last-applied-configuration:
                     "apiVersion":"v1","kind":"Service","metadata":"annotations":,"labels":"app.kubernetes.io/managed-by":"skaffold-v1.11.0","skaffold.dev...
Selector:          apps=nats
Type:              ClusterIP
IP:                10.32.13.69
Port:              client  4222/TCP
TargetPort:        4222/TCP
Endpoints:         <none>
Port:              monitoring  8222/TCP
TargetPort:        8222/TCP
Endpoints:         <none>
Session Affinity:  None
Events:            <none>

【问题讨论】:

编辑问题以添加kubectl describe svc nats-srv的输出 【参考方案1】:

服务有选择器apps: nats,但部署有标签app: nats。它们必须相同。这就是服务中的Endpoints 没有 Pod IP 的原因,因此您会得到connection refused。修改服务如下

---
apiVersion: v1
kind: Service 
metadata:
    name: nats-srv 
spec: 
    type: ClusterIP
    selector: 
        app: nats 
    ports: 
        - name: client 
          protocol: TCP 
          port: 4222 
          targetPort: 4222 
        - name: monitoring 
          protocol: TCP 
          port: 8222 
          targetPort: 8222

【讨论】:

以上是关于Kubernetes NAT 流服务器 - 连接被拒绝的主要内容,如果未能解决你的问题,请参考以下文章

kubernetes之Docker网络详解

Kubernetes 负载均衡器服务器连接被拒绝:默认 80 端口正在工作

11.4 跨pod网络

NAT

Kubernetes 端口转发 - 连接被拒绝

Kubernetes 中工作节点上的连接被拒绝错误