Postgres ENOT发现将docker服务连接到docker数据库容器时出错



我无法让我的一个容器(服务(通过 docker 连接到 postgres 数据库容器。它似乎在抱怨使用错误的数据库...(我正在使用node.js与"pg"和"pg-promise"库。

我的帖子连接信息

const pg = require('pg');
const pgp = require('pg-promise')();
var config = {
user: 'root',
password: 'myPassword',
database: 'myDb',
host: 'database',
port: 5432
};
const db = pgp(config);

docker 尝试连接到数据库时出错

{ Error: getaddrinfo ENOTFOUND database database:5432
at errnoException (dns.js:28:10)
at GetAddrInfoReqWrap.onlookup [as oncomplete] (dns.js:76:26)
code: 'ENOTFOUND',
errno: 'ENOTFOUND',
syscall: 'getaddrinfo',
hostname: 'database',
host: 'database',
port: 5432 }

我知道默认情况下容器与服务名称具有相同的主机名,但这不起作用(我的服务名称是"数据库"(。我错过了什么?

docker-compose.yml

version: '3'
services:
myapp:
build: My-App/
depends_on:
- 'database'
ports:
- '5000:5000'
database:
image: postgres:11.5

所以我最终找到了答案,所以我想我会分享:

Docker无法自动连接到Postgres的原因是Postgres仍在初始化(并且在启动时没有收到连接请求(。

我发现的一个解决方案是人为地延迟 Docker 的连接尝试(基本上等到 Postgres 准备好后再尝试连接(。

编辑:Docker-compose 版本 3 现在有关于如何控制哪些容器首先启动的文档:https://docs.docker.com/compose/startup-order/

最新更新