我一直在嘗試使用 docker-compose 將我的 go 應(yīng)用程序連接到 postgresql db。這是我用于 Web 服務(wù)器的 DockerfileFROM golang:latestRUN mkdir /appCOPY . /appWORKDIR /appRUN go mod downloadEXPOSE 5000CMD ["go","run","main.go"]這是我的 docker-compose.yml 文件version: '3'services: db: image: postgres:latest restart: always network_mode: bridge environment: POSTGRES_USER: factly POSTGRES_PASSWORD: qwertyui POSTGRES_DB: factly ports: - "5432:5432" server: build: . depends_on: - db ports: - "5000:5000"但我無(wú)法連接到 postgresql 數(shù)據(jù)庫(kù),因?yàn)樗o出了來(lái)自Go serverStarting factly_db_1 ... Starting factly_db_1 ... doneRecreating factly_server_1 ... Recreating factly_server_1 ... doneAttaching to factly_db_1, factly_server_1db_1 | db_1 | PostgreSQL Database directory appears to contain a database; Skipping initializationdb_1 | db_1 | 2020-08-19 06:11:17.151 UTC [1] LOG: starting PostgreSQL 12.4 (Debian 12.4-1.pgdg100+1) on x86_64-pc-linux-gnu, compiled by gcc (Debian 8.3.0-6) 8.3.0, 64-bitdb_1 | 2020-08-19 06:11:17.151 UTC [1] LOG: listening on IPv4 address "0.0.0.0", port 5432db_1 | 2020-08-19 06:11:17.152 UTC [1] LOG: listening on IPv6 address "::", port 5432db_1 | 2020-08-19 06:11:17.266 UTC [1] LOG: listening on Unix socket "/var/run/postgresql/.s.PGSQL.5432"db_1 | 2020-08-19 06:11:17.906 UTC [26] LOG: database system was shut down at 2020-08-19 05:56:39 UTCdb_1 | 2020-08-19 06:11:18.213 UTC [1] LOG: database system is ready to accept connectionsserver_1 | host=127.0.0.1 port=5432 user=factly password=qwertyui dbname=factly sslmode=disableserver_1 | 2020/08/19 06:11:21 dial tcp 127.0.0.1:5432: connect: connection refusedserver_1 | exit status 1factly_server_1 exited with code 1我嘗試只運(yùn)行 postgres 容器并將其與運(yùn)行良好的 Go 應(yīng)用程序連接,但在容器內(nèi)運(yùn)行 Go 應(yīng)用程序會(huì)產(chǎn)生相同的錯(cuò)誤(這讓我覺(jué)得 Go Web 服務(wù)器容器無(wú)法連接到它的網(wǎng)絡(luò)之外) . 我該如何糾正?
1 回答

慕田峪4524236
TA貢獻(xiàn)1875條經(jīng)驗(yàn) 獲得超5個(gè)贊
我想問(wèn)題是你試圖127.0.0.1
從 go 程序連接,而不是使用數(shù)據(jù)庫(kù)容器的主機(jī)名db
。
- 1 回答
- 0 關(guān)注
- 144 瀏覽
添加回答
舉報(bào)
0/150
提交
取消