首頁  >  文章  >  後端開發  >  Gorm 應用程式無法連接到 Mac 上 docker 容器中的 PostgreSQL,忽略 DSN

Gorm 應用程式無法連接到 Mac 上 docker 容器中的 PostgreSQL,忽略 DSN

王林
王林轉載
2024-02-09 09:12:10932瀏覽

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

php小編小新最近遇到了一個問題,就是在Mac上使用Gorm應用程式連接docker容器中的PostgreSQL時出現了連線問題。具體表現為忽略了DSN。 DSN是資料來源名稱的縮寫,用於指定資料庫連接的資訊。這個問題讓我煩惱不已,因為無法連接到資料庫將導致應用程式無法正常運作。接下來,我將分享我遇到的問題以及解決方法,希望對大家有幫助。

問題內容

我嘗試建立一個簡單的 go rest api。我使用 gorm 庫進行資料庫處理,但它無法連接到容器中的資料庫。我覺得這可能是 apple 晶片上 docker 的問題,但不確定。我有另一個項目,它使用基本上相同的設置,但資料庫連接完全沒有問題。

基本上,連接參數似乎在運行時完全改變,忽略了 dsn 字串

這是 docker-compose.yml

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: always

volumes:
  dbdata:

這是進行資料庫連線的部分:

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 建立連線沒有問題。

這是我收到的錯誤,由於某種原因連接參數似乎完全改變了:

[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 的格式相同。相反,它應該看起來像這樣:

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

以上是Gorm 應用程式無法連接到 Mac 上 docker 容器中的 PostgreSQL,忽略 DSN的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:stackoverflow.com。如有侵權,請聯絡admin@php.cn刪除