嘗試使用官方 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時多次更改了mysuperduperlongpwstring
,並相應地更改了我的Go PW,但每次都以相同的失敗告終。
請問問題出在哪裡,如何排查? 如何使用官方 postgres docker 重設密碼?
在Docker 容器中,設定您顯示的內容並從空卷開始,「postgres」將是超級用戶,因此您不會收到有關它需要成為超級用戶的錯誤。
我對此部分看到的唯一合理的解釋是,要么您沒有在您認為的地方運行psql,要么您沒有從空卷開始,因此您的docker run
命令只是啟動了一個現有資料庫,因此您的「-e POSTGRES*」配置全部被忽略。因此,無論怎樣,您要么沒有連接到您認為的樣子,要么它沒有按照您想像的方式配置。
以上是如何將密碼與官方 postgres docker 映像一起使用?的詳細內容。更多資訊請關注PHP中文網其他相關文章!