草庐IT

redis - 连接到 Kubernetes Redis 服务时出现 Connection Refused 错误

coder 2023-07-18 原文

我的集群上有一个 Redis 部署/服务实例:

Redis.yaml

---

apiVersion: v1
kind: Service
metadata:
  name: myapp-redis
  labels:
    name: myapp-redis
spec:
  ports:
  - port: 6379
    targetPort: 6379
  selector:
    name: myapp-redis

---

apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: myapp-redis
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 1Gi

---

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: myapp-redis
  labels:
    name: myapp-redis
spec:
  selector:
    matchLabels:
      name: myapp-redis
  strategy:
    type: Recreate
  replicas: 1
  template:
    metadata:
      labels:
        name: myapp-redis
    spec:
      containers:
      - name: myapp-redis
        image: registry/myapp-redis:0.0.0-alpha.13
        imagePullPolicy: Always
        ports:
        - containerPort: 6379
        volumeMounts:
        - name: myapp-redis
          mountPath: /etc/redis/
      imagePullSecrets:
      - name: regsecret
      volumes:
      - name: myapp-redis
        persistentVolumeClaim:
          claimName: myapp-redis

---

Redis 服务说明

我从 kubectl describe svc myapp-redis -n mw-dev 得到这个:

Name:              myapp-redis
Namespace:         mw-dev
Labels:            name=myapp-redis
Annotations:       kubectl.kubernetes.io/last-applied-configuration={"apiVersion":"v1","kind":"Service","metadata":{"annotations":{},"labels":{"name":"myapp-redis"},"name":"myapp-redis","namespace":"mw-dev"},"sp...
Selector:          name=myapp-redis
Type:              ClusterIP
IP:                10.3.0.137
Port:              <unset>  6379/TCP
TargetPort:        6379/TCP
Endpoints:         10.2.2.173:6379
Session Affinity:  None
Events:            <none>

检查redis是否启动并运行

确保数据库已启动并正在运行,我可以使用 kubectl exec -it myapp-redis-[..] sh -n mw-dev 在 pod 中打开一个 shell 并 ping 数据库使用 redis-cli -a test ping。如果这样做,我会收到一个 PONG,因此似乎密码 (test) 已解析并且数据库已启动。

将 python 应用程序连接到 redis 服务时出现问题

但是,如果我尝试将运行 Python 应用程序的 pod 连接到 redis 数据库,我会收到来自 Python 应用程序的连接被拒绝错误。

kubectl 记录 myapp-backend-596... -n mw-dev

[...]
  File "/usr/local/lib/python3.6/site-packages/aioredis/stream.py", line 19, in open_connection
    lambda: protocol, host, port, **kwds)
  File "uvloop/loop.pyx", line 1733, in create_connection
  File "uvloop/loop.pyx", line 1712, in uvloop.loop.Loop.create_connection
ConnectionRefusedError: [Errno 111] Connection refused

这是 Python 应用程序的配置:

后端.yaml

---

apiVersion: v1
kind: Service
metadata:
  name: myapp-backend
  labels:
    name: myapp-backend
spec:
  ports:
  - port: 8000
    targetPort: 8000
  selector:
    name: myapp-backend

---

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: myapp-backend
  labels:
    name: myapp-backend
spec:
  replicas: 1
  strategy:
    type: Recreate
  template:
    metadata:
      labels:
        name: myapp-backend
    spec:
      containers:
      - name: myapp-backend
        image: registry/myapp-backend:0.0.0-alpha.13
        imagePullPolicy: Always
        ports:
        - containerPort: 8000
        env:
        - name: REDIS_HOST
          value: 'myapp-redis'
        - name: REDIS_PASSWORD
          value: 'test'
      imagePullSecrets:
      - name: regsecret

---

Python 后端 pod 描述

这是我从 kubectl describe po myapp-backend-58... -n mw-dev 中得到的:

Name:           myapp-backend-585d...
Namespace:      mw-dev
Node:           worker-2/ip...
Start Time:     Sat, 03 Feb 2018 13:08:01 +0100
Labels:         name=myapp-backend
                pod-template-hash=myhash
Annotations:    kubernetes.io/created-by={"kind":"SerializedReference","apiVersion":"v1","reference":{"kind":"ReplicaSet","namespace":"mw-dev","name":"myapp-backend-58...","uid":"e13...
Status:         Running
IP:             10.2.2.180
Controlled By:  ReplicaSet/myapp-backend-58...
Containers:
  myapp-backend:
    Container ID:   docker://78cfc218d...
    Image:          registry/myapp-backend:0.0.0-alpha.13
    Image ID:       docker-pullable://registry/mw-dev/myapp-backend@sha256:785a...
    Port:           8000/TCP
    State:        registryg
      Reason:       CrashLoopBackOff
    Last State:     Terminated
      Reason:       Error
      Exit Code:    1
      Started:      Sat, 03 Feb 2018 13:55:07 +0100
      Finished:     Sat, 03 Feb 2018 13:55:08 +0100
    Ready:          False
    Restart Count:  14
    Environment:
      REDIS_HOST:      myapp-redis
      REDIS_PASSWORD:  test
    Mounts:
      /var/run/secrets/kubernetes.io/serviceaccount from default-token-7... (ro)
Conditions:
  Type           Status
  Initialized    True 
  Ready          False 
  PodScheduled   True 
Volumes:
  default-token-7cm7c:
    Type:        Secret (a volume populated by a Secret)
    SecretName:  default-token-7...
    Optional:    false
QoS Class:       BestEffort
Node-Selectors:  <none>
Tolerations:     node.alpha.kubernetes.io/notReady:NoExecute for 300s
                 node.alpha.kubernetes.io/unreachable:NoExecute for 300s
Events:
  Type     Reason                 Age                  From                          Message
  ----     ------                 ----                 ----                          -------
  Normal   Scheduled              50m                  default-scheduler             Successfully assigned myapp-backend-58... to worker-2
  Normal   SuccessfulMountVolume  50m                  kubelet, worker-2  MountVolume.SetUp succeeded for volume "default-token-7..."
  Warning  BackOff                50m (x4 over 50m)    kubelet, worker-2  Back-off restarting failed container
  Normal   Pulling                50m (x4 over 50m)    kubelet, worker-2  pulling image "registry/mw-dev/myapp-backend:0.0.0-alpha.13"
  Normal   Pulled                 50m (x4 over 50m)    kubelet, worker-2  Successfully pulled image "registry/mw-dev/myapp-backend:0.0.0-alpha.13"
  Normal   Created                50m (x4 over 50m)    kubelet, worker-2  Created container
  Normal   Started                50m (x4 over 50m)    kubelet, worker-2  Started container
  Warning  FailedSync             52s (x229 over 50m)  kubelet, worker-2  Error syncing pod

运行 pod

kubectl get pods --all-namespaces:

NAMESPACE     NAME                                                          READY     STATUS    RESTARTS   AGE
kube-system   cert-manager-cert-manager-59fff59c7b-vdnd7                    2/2       Running   4          3d
kube-system   digitalocean-cloud-controller-manager-6d6b675bfd-nxqq2        1/1       Running   0          3d
kube-system   digitalocean-provisioner-d4c79dfb4-mhb5d                      1/1       Running   0          3d
kube-system   heapster-56bf7c7896-9rv4z                                     1/1       Running   0          3d
kube-system   kube-apiserver-wp7b4                                          1/1       Running   5          10d
kube-system   kube-controller-manager-586c9b745b-gkqk4                      1/1       Running   2          10d
kube-system   kube-controller-manager-586c9b745b-pdhw7                      1/1       Running   1          10d
kube-system   kube-dns-7d74988c8b-z9zs2                                     3/3       Running   0          10d
kube-system   kube-flannel-5wlk6                                            2/2       Running   0          10d
kube-system   kube-flannel-khsvq                                            2/2       Running   0          10d
kube-system   kube-flannel-skt2m                                            2/2       Running   4          10d
kube-system   kube-proxy-cwqv8                                              1/1       Running   2          10d
kube-system   kube-proxy-mg8jx                                              1/1       Running   0          10d
kube-system   kube-proxy-vmw8g                                              1/1       Running   0          10d
kube-system   kube-scheduler-7686847675-5kkhn                               1/1       Running   1          10d
kube-system   kube-scheduler-7686847675-lkm98                               1/1       Running   2          10d
kube-system   kubernetes-dashboard-7658f8d76-svtzh                          1/1       Running   0          3d
kube-system   loadbalancer-nginx-ingress-controller-8649c7986b-jndzz        1/1       Running   3          3d
kube-system   loadbalancer-nginx-ingress-default-backend-6fb9444c64-bpz4g   1/1       Running   0          3d
kube-system   pod-checkpointer-kfcpp                                        1/1       Running   0          10d
kube-system   pod-checkpointer-kfcpp-spc1aitu1i-master-1                    1/1       Running   0          10d
kube-system   tiller-deploy-fb8d7b69c-6xrpn                                 1/1       Running   2          3d
mw-dev        myapp-backend-6c4b56d9b7-2mfbs                                1/1       Running   0          21m
mw-dev        myapp-frontend-7478fd456b-5ztvq                               1/1       Running   0          1d
mw-dev        myapp-redis-67d45d97d7-7wxtj                                  1/1       Running   0          1d

确保 Python 应用收到正确的环境变量值

Python 应用打印出它用于连接到数据库的值。查看 pod 日志,我可以看到这些值与 Backend.yaml 中给出的值相同(REDIS_HOST=myapp-redisREDIS_PASSWORD=test)。

它在 docker 本地运行

如果我在笔记本电脑上使用 docker 在本地运行 redis 容器和 python 应用程序容器,它们连接正常。

集群信息

集群使用 nginx-ingress Controller 向互联网公开服务。我不确定这是否重要,因为我需要在内部将 Python pod 连接到 redis 服务。

该集群由 1 个主节点、两个工作节点和一个用于 nginx-ingress Controller 的 LoadBlancer 组成,它们都在 DigitalOcean 上运行。

现在怎么办?

此时我不知道如何进一步调试问题。我已经在网上搜索了几个小时以找到解决方案,但运气不佳。任何建议将不胜感激!

最佳答案

connection refused错误是由redis配置引起的。

为了允许外部连接,我必须将 redis 主机从 localhost 更改为 0.0.0.0

redis.conf 中,我更改了这一行:

bind 127.0.0.1

为此:

bind 0.0.0.0

关于redis - 连接到 Kubernetes Redis 服务时出现 Connection Refused 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48597726/

有关redis - 连接到 Kubernetes Redis 服务时出现 Connection Refused 错误的更多相关文章

  1. ruby - 使用 ruby​​ 和 savon 的 SOAP 服务 - 2

    我正在尝试使用ruby​​和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我

  2. ruby - 具有身份验证的私有(private) Ruby Gem 服务器 - 2

    我想安装一个带有一些身份验证的私有(private)Rubygem服务器。我希望能够使用公共(public)Ubuntu服务器托管内部gem。我读到了http://docs.rubygems.org/read/chapter/18.但是那个没有身份验证-如我所见。然后我读到了https://github.com/cwninja/geminabox.但是当我使用基本身份验证(他们在他们的Wiki中有)时,它会提示从我的服务器获取源。所以。如何制作带有身份验证的私有(private)Rubygem服务器?这是不可能的吗?谢谢。编辑:Geminabox问题。我尝试“捆绑”以安装新的gem..

  3. ruby - ECONNRESET (Whois::ConnectionError) - 尝试在 Ruby 中查询 Whois 时出错 - 2

    我正在用Ruby编写一个简单的程序来检查域列表是否被占用。基本上它循环遍历列表,并使用以下函数进行检查。require'rubygems'require'whois'defcheck_domain(domain)c=Whois::Client.newc.query("google.com").available?end程序不断出错(即使我在google.com中进行硬编码),并打印以下消息。鉴于该程序非常简单,我已经没有什么想法了-有什么建议吗?/Library/Ruby/Gems/1.8/gems/whois-2.0.2/lib/whois/server/adapters/base.

  4. ruby-on-rails - Rails 常用字符串(用于通知和错误信息等) - 2

    大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje

  5. ruby - 在 64 位 Snow Leopard 上使用 rvm、postgres 9.0、ruby 1.9.2-p136 安装 pg gem 时出现问题 - 2

    我想为Heroku构建一个Rails3应用程序。他们使用Postgres作为他们的数据库,所以我通过MacPorts安装了postgres9.0。现在我需要一个postgresgem并且共识是出于性能原因你想要pggem。但是我对我得到的错误感到非常困惑当我尝试在rvm下通过geminstall安装pg时。我已经非常明确地指定了所有postgres目录的位置可以找到但仍然无法完成安装:$envARCHFLAGS='-archx86_64'geminstallpg--\--with-pg-config=/opt/local/var/db/postgresql90/defaultdb/po

  6. ruby - 续集在添加关联时访问many_to_many连接表 - 2

    我正在使用Sequel构建一个愿望list系统。我有一个wishlists和itemstable和一个items_wishlists连接表(该名称是续集选择的名称)。items_wishlists表还有一个用于facebookid的额外列(因此我可以存储opengraph操作),这是一个NOTNULL列。我还有Wishlist和Item具有续集many_to_many关联的模型已建立。Wishlist类也有:selectmany_to_many关联的选项设置为select:[:items.*,:items_wishlists__facebook_action_id].有没有一种方法可以

  7. ruby-on-rails - 启动 Rails 服务器时 ImageMagick 的警告 - 2

    最近,当我启动我的Rails服务器时,我收到了一长串警告。虽然它不影响我的应用程序,但我想知道如何解决这些警告。我的估计是imagemagick以某种方式被调用了两次?当我在警告前后检查我的git日志时。我想知道如何解决这个问题。-bcrypt-ruby(3.1.2)-better_errors(1.0.1)+bcrypt(3.1.7)+bcrypt-ruby(3.1.5)-bcrypt(>=3.1.3)+better_errors(1.1.0)bcrypt和imagemagick有关系吗?/Users/rbchris/.rbenv/versions/2.0.0-p247/lib/ru

  8. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  9. ruby-on-rails - 迷你测试错误 : "NameError: uninitialized constant" - 2

    我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test

  10. ruby - 无法在 60 秒内获得稳定的 Firefox 连接 (127.0.0.1 :7055) - 2

    我使用的是Firefox版本36.0.1和Selenium-Webdrivergem版本2.45.0。我能够创建Firefox实例,但无法使用脚本继续进行进一步的操作无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055)错误。有人能帮帮我吗? 最佳答案 我遇到了同样的问题。降级到firefoxv33后一切正常。您可以找到旧版本here 关于ruby-无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055),我们在StackOverflow上找到一个类

随机推荐