首頁  >  文章  >  後端開發  >  如何將密碼與官方 postgres docker 映像一起使用?

如何將密碼與官方 postgres docker 映像一起使用?

WBOY
WBOY轉載
2024-02-05 21:45:121220瀏覽

如何将密码与官方 postgres docker 镜像一起使用?

問題內容

嘗試使用官方 postgres docker 映像:

docker run --rm -d \
        --name my-postgres \
        --network my-network \
        -e POSTGRES_USER=postgres \
        -e POSTGRES_PASSWORD=mysuperduperlongpwstring \
        -e POSTGRES_DB=postgres \
        -v /path/to/postgres/data/:/var/lib/postgresql/data
        postgres

但是,當使用 Go 建立 postgres 連線時,

        psqlInfo := fmt.Sprintf(
                "host=%s port=%s user=%s password=%s dbname=%s sslmode=%s",
                os.Getenv("DB_HOST"),
                os.Getenv("DB_PORT"),
                os.Getenv("DB_USER"),
                os.Getenv("DB_PASSWORD"),
                os.Getenv("DB_NAME"),
                os.Getenv("DB_SSL_MODE"),
        )
        db, err := sql.Open("postgres", psqlInfo)
        if err != nil {
                panic(err)
        }

我總是以

結束

panic: pq: 使用者「postgres」的密碼驗證失敗

我沒有任何其他方法來驗證 mysuperduperlongpwstring:

  • 嘗試使用 psql -U postgres -d postgres --password 從 docker 容器內連接資料庫,並提供任何內容作為密碼就可以了。
  • 嘗試從 docker 容器內更改密碼,將會得到

錯誤:必須是超級使用者才能更改複製角色或更改複製屬性

也就是說,基本上以下答案不再對我有用:

  • 如何更改 Postgresql docker 映像密碼
  • 如何更改 PostgreSQL 使用者密碼?

由於缺乏資源,我在啟動docker時多次更改了mysuperduperlongpwstring,並相應地更改了我的Go PW,但每次都以相同的失敗告終。

請問問題出在哪裡,如何排查? 如何使用官方 postgres docker 重設密碼?


正確答案


在Docker 容器中,設定您顯示的內容並從空卷開始,「postgres」將是超級用戶,因此您不會收到有關它需要成為超級用戶的錯誤。

我對此部分看到的唯一合理的解釋是,要么您沒有在您認為的地方運行psql,要么您沒有從空卷開始,因此您的docker run 命令只是啟動了一個現有資料庫,因此您的「-e POSTGRES*」配置全部被忽略。因此,無論怎樣,您要么沒有連接到您認為的樣子,要么它沒有按照您想像的方式配置。

以上是如何將密碼與官方 postgres docker 映像一起使用?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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