postgresql - 将 docker 服务连接到 docker 数据库容器时出现 Postgres ENOTFOUND 错误

标签 postgresql docker docker-compose dockerfile

我无法让我的容器(服务)之一通过 docker 连接到 postgres 数据库容器。它似乎在提示使用错误的数据库......(我正在使用带有'pg'和'pg-promise'库的node.js。)。

我的 postgres 连接信息

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/

关于postgresql - 将 docker 服务连接到 docker 数据库容器时出现 Postgres ENOTFOUND 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57815266/

相关文章:

docker - 从 Docker 容器将 PySpark 连接到 Kafka

docker - 将容器的主机IP映射到虚拟主机的最佳方法是什么?

docker - Spring Cloud Dataflow 的 docker-compose up 错误 - "DATAFLOW_VERSION is not set!"

dns - Docker pull 无法在 127.0.1.1 :53 (cannot unmarshal DNS message) 上查找 index.docker.io

java - PostgresSqlException 与 activiti 源代码

sql-server - 以某种方式在 Sql Server 和 PostgreSQL 上执行 `where booleanvalue=false`?

java - PermGen 空间内存泄漏

ubuntu - 如何清理/var/lib/docker/vfs 目录

docker - 使用 ansible 部署最新的 docker 容器

sql - 返回对应值变化的账户的所有历史账户记录