Gorm 应用程序无法连接到 Mac 上 docker 容器中的 PostgreSQL,忽略 DSN

Gorm 应用程序无法连接到 Mac 上 docker 容器中的 PostgreSQL,忽略 DSN

php小编小新最近遇到了一个问题,就是在Mac上使用Gorm应用程序连接docker容器中的PostgreSQL时出现了连接问题。具体表现为忽略了DSN。DSN是数据源名称的缩写,用于指定数据库连接的信息。这个问题让我烦恼不已,因为无法连接到数据库将导致应用程序无法正常运行。接下来,我将分享我遇到的问题以及解决方法,希望对大家有所帮助。

问题内容

我尝试创建一个简单的 go rest api。我使用 gorm 库进行数据库处理,但它无法连接到容器中的数据库。我觉得这可能是 apple 芯片上 docker 的问题,但不确定。我有另一个项目,它使用基本相同的设置,但数据库连接完全没有问题。

基本上,连接参数似乎在运行时完全改变,忽略了 dsn 字符串

这是 docker-compose.yml:

  1. version: '3'services: db: image: 'postgres:latest' container_name: bazos-watcher-db ports: - '5420:5432' volumes: - dbdata:/var/lib/postgresql/data - ./scripts/init.sql:/docker-entrypoint-initdb.d/init.sql env_file: - 'docker.env' restart: alwaysvolumes: dbdata:

登录后复制

这是进行数据库连接的部分:

  1. dsn := "bazos:kokos@tcp(localhost:5420)/bazos?charset=utf8mb4&parsetime=true&loc=local"dbopen, err := gorm.open(postgres.open(dsn), &gorm.config{})

登录后复制

dsn 参数与 docker.env 中配置的参数匹配。 pgadmin 建立连接没有问题。

这是我收到的错误,由于某种原因连接参数似乎完全改变了:

  1. [error] failed to initialize database, got error failed to connect to `host=/private/tmp user=tassilo database=`: dial error (dial unix /private/tmp/.s.PGSQL.5432: connect: no such file or directory)2023/03/15 17:20:59 failed to connect to `host=/private/tmp user=tassilo database=`: dial error (dial unix /private/tmp/.s.PGSQL.5432: connect: no such file or directory)exit status 1

登录后复制

我尝试更改 dsn 字符串的最后部分并删除并重新创建容器,但仍然没有成功。

解决方法

我天真地假设 dsn 字符串的格式与 mysql 的格式相同。相反,它应该看起来像这样:

  1. dsn := "host=localhost user=gorm password=gorm dbname=gorm port=9920 sslmode=disable TimeZone=Asia/Shanghai"

登录后复制

以上就是Gorm 应用程序无法连接到 Mac 上 docker 容器中的 PostgreSQL,忽略 DSN的详细内容,更多请关注【创想鸟】其它相关文章!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
编程技术

Ent 查询中的嵌套聚合

2025-3-4 21:37:34

编程技术

使用反射将字节复制到结构体字段中

2025-3-4 21:38:08

0 条回复 A文章作者 M管理员
欢迎您,新朋友,感谢参与互动!
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
私信列表
搜索