Docker-compose Postgres连接被拒绝。

8
我正在使用Docker Compose运行Postgres数据库、pg-admin和GO。问题:我能够从pg-admin连接Postgres,但无法从GO建立连接。尝试过多种身份验证字符串的组合,但都无效。字符串格式与此处相同:https://github.com/karlkeefer/pngr,但容器名称不同,为“database”。错误连接URL如下:
backend_1         | 2021/08/08 14:24:40 DB connection: database://main:fugZwypczB94m0LP7CcH@postgres:5432/temp_db?sslmode=disable
backend_1         | 2021/08/08 14:24:40 Unalble to open DB connection: dial tcp 127.0.0.1:5432: connect: connection refused

(URI生成与此处相同https://github.com/karlkeefer/pngr)

Docker:

version: '3.8'
services:
  backend:
    restart: always
    build: 
      context: backend
      target: dev
    volumes:
      - ./backend:/root
    ports:
      - "5000:5000"
    env_file: .env
    depends_on: 
      - database
  database:
    build: database
    restart: always
    environment:
      POSTGRES_DB: ${POSTGRES_DB}
      POSTGRES_USER: ${POSTGRES_USER}
      POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
      PGDATA: /var/lib/postgresql/data
    volumes:
      - ./database/data:/var/lib/postgresql/data
      - ./logs/databse:/var/log/postgresql
      - ./database/migrations:/docker-entrypoint-initdb.d/migrations
    ports:
      - "5432:5432"
  database-admin:
    image: dpage/pgadmin4:5.5
    restart: always
    environment:
      PGADMIN_DEFAULT_EMAIL: ${PG_ADMIN_EMAIL}
      PGADMIN_DEFAULT_PASSWORD: ${PG_ADMIN_PASSWORD}
      PGADMIN_LISTEN_PORT: 80
    ports:
      - "8080:80"
    volumes:
      - ./database/admin:/var/lib/pgadmin
    links:
      - "database:pgsql-server"
    depends_on: 
      - database
volumes:
  database:
  database-admin:

环境:

POSTGRES_HOST=postgres
POSTGRES_PORT=5432
POSTGRES_DB=temp_db
POSTGRES_USER=main
POSTGRES_PASSWORD=fugZwypczB94m0LP7CcH
PG_ADMIN_EMAIL=admin@temp.com
PG_ADMIN_PASSWORD=ayzi2ta8f1TnX3vKQSN1
PG_ADMIN_PORT=80

GO 代码:

db, err = sqlx.Open("postgres", str)

str

func buildConnectionString() string {
    user := os.Getenv("POSTGRES_USER")
    pass := os.Getenv("POSTGRES_PASSWORD")
    if user == "" || pass == "" {
        log.Fatalln("You must include POSTGRES_USER and POSTGRES_PASSWORD environment variables")
    }
    host := os.Getenv("POSTGRES_HOST")
    port := os.Getenv("POSTGRES_PORT")
    dbname := os.Getenv("POSTGRES_DB")
    if host == "" || port == "" || dbname == "" {
        log.Fatalln("You must include POSTGRES_HOST, POSTGRES_PORT, and POSTGRES_DB environment variables")
    }

    str := fmt.Sprintf("database://%s:%s@%s:%s/%s?sslmode=disable", user, pass, host, port, dbname)

    log.Println("DB connection: " + str)

    return str
}

提前感谢!

1个回答

11

你将数据库主机名引用为postgresPOSTGRES_HOST=postgres),这没问题,但容器/服务名称是database

要么在你的compose.yaml中将名称从database更改为postgres,要么添加一个显式的hostname字段:

database:
  build: database
  restart: always
  hostname: postgres   # <- add this

您可能希望为多个容器服务添加专用网络,以便它们之间进行通信(或防止其他人进行)。要实现此目的,请在每个要使用特定网络的服务中添加以下内容,例如:

database:
  # ...

  networks:
    - mynet

backend:
  # ...

  networks:
    - mynet

在你的compose.yaml文件末尾定义网络。

networks:
  mynet:
    name: my-shared-db-network

嗨@colm.anseo,谢谢你的提示! - ilbets
刚刚尝试了一下,将URI更新为以postgres开头,它就成功了!谢谢!只是更改环境文件中的主机名为“database”并没有起作用,我认为这是设计上的问题?(真的很困惑) - ilbets

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接