在 Kubernetes 中连接 PostgreSQL 失败

如何解决在 Kubernetes 中连接 PostgreSQL 失败

我正在使用 Kubernetes。我有两个豆荚。

一个 Pod 中,它运行着一个服务器。这是尝试连接另一个 pod 中的 Postgresql 服务的部分代码

import (
    "context"
    "github.com/jackc/pgx/v4/pgxpool"
    "github.com/rs/zerolog/log"
)

databaseURL := "postgres://admin:passw0rd@my-database-service.hm:40072/my_db"
pg,err := pgxpool.Connect(context.Background(),databaseURL)
if err != nil {
    log.Error().Err(err).Msg("conn.Close")
    return nil
}

目前,上面的代码给出了错误

{"level":"error","error":"无法连接到host=my-database-service.hm user=admin database=my_db:拨号错误(拨号tcp 10.43.140.140:40072:连接:连接被拒绝)","time":1627849943,"message":"conn.Close"}

但是,ssh 进入服务器 pod 后,我可以通过 psql 成功连接 Postgresql pod。

/usr/src/app # psql --host=my-database-service.hm --port=40072 --dbname=my_db --username=admin --password
Password: 
psql (13.3)
Type "help" for help.

my_db=# 

我尝试重新启动我的服务器 pod 以确保它在 Postgresql 数据库准备好后运行,但仍然出现相同的错误

任何进一步调试的建议都会有所帮助。谢谢!


更新

我实际上在使用 Linkerd。可能与

有关

https://linkerd.io/2.10/features/protocol-detection/

我尝试将 Postgresql 更改为认端口 5432,但仍有问题。如果找到解决方案会更新。

解决方法

经过一些实验,我可以确认我的问题与 Linkerd 无关。

我认为我的 PostgreSQL containerPort/targetPort 仍然使用默认的 5432。它由网络内部的 ClusterIP 通过端口 40072 公开,这就是为什么我在 Linkerd 中不需要 mark the port as opaque

原来添加os.Exit(1)后,

pg,err := pgxpool.Connect(context.Background(),databaseURL)
if err != nil {
    log.Error().Err(err).Msg("conn.Close")
    os.Exit(1) // <- this helps
}

我的 Kubernetes 将帮助重新启动服务器 pod,因为它最初无法等待 PostgreSQL 准备就绪。

重启几次后,server pod现在可以很好的连接PostgreSQL了。

我想如果我提前手动重启更多次,也可能会有所帮助。但是这样让Kubernetes帮助重启绝对不可靠。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?