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
}
目前,上面的代码给出了错误
{“级别”:“错误”,“错误”:“连接失败
host=my-database-service.hm user=admin database=my_db
:拨号错误(拨号 tcp 10.43.140.140:40072:连接:连接被拒绝)”,“时间”:1627849943,“消息”:“连接。关”}
但是,在我 ssh 进入服务器 pod 后,我可以通过psql
.
/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 中将该端口标记为不透明的原因。
事实证明,添加后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 最初无法等待 PostgreSQL 准备好时,我的 Kubernetes 将帮助重新启动服务器 pod。
重启几次后,server pod 现在可以很好地连接 PostgreSQL。
我认为如果我提前手动重新启动更多次,它也可能会有所帮助。但绝对不可靠,像这种让 Kubernetes 帮助重启的方式。
推荐阅读
- css - 使用 stroke-dashoffset 的 SVG 动画在 IE 中不显示
- android - 如何修复致命异常:AsyncTask #1
- amazon-web-services - 如何更改 DynamoDb 中列的数据类型?
- swift - 从一个 NSViewController 移动到另一个 NSViewController
- javascript - if ... function.start - 如果 ... function.end
- html - 如何相对于跨度定位div?
- autodesk-forge - Autodesk API Forge 身份验证承载
- mysql - 在 MySQL 中使用窗口函数的错误代码 1064
- corda - Corda 教程的合约测试 ledget 方法错误
- c# - Creating delegates by calling delegate constructor