登录
首页 >  Golang >  Go问答

连接到 PostgreSQL 失败(使用 Docker 用户凭据验证失败)

来源:stackoverflow

时间:2024-03-09 09:03:27 211浏览 收藏

怎么入门Golang编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《连接到 PostgreSQL 失败(使用 Docker 用户凭据验证失败)》,涉及到,有需要的可以收藏一下

问题内容

我试图运行 docker compose 来设置 nginx、golang 服务器和 postgresql。问题是我无法连接到数据库:

最初,我尝试使用以下指令连接到 postgres:

db, err = gorm.open("postgres", "host=db port=5432 user=sigbrian password=example sslmode=disable")

使用这个 docker-compose 文件:

version: '3.2'

# volumes:
  # database_data:
    # driver: local

services:
  db:
    image: postgres
    restart: always
    environment:
      - postgres_db:sigdb
      - postgres_user:sigbrian
      - postgres_password:example
    ports:
      - '5432:5432'
    # volumes:
      # - database_data:/var/lib/postgresql/data
  golang-app:
    build:
      context: .
      dockerfile: dockerfile
    # command: ["./wait-for-it.sh", "db:5432"]
    # ports:
    #   - '80:8888'
    expose:
      - '8080'
    depends_on:
      - "db"
    links:
      - "db"
  nginx-proxy-and-webserver:
    image: nginx:1.15.5-alpine
    ports:
      - '80:80'
    volumes:
      - ./nginx.conf:/etc/nginx/nginx.conf
      - ./static:/var/www/sig/static
    depends_on:
      - "golang-app"
    links:
      - "golang-app"

但是当我从文件中注释 postgres 用户、数据库和密码环境变量,并尝试以这种方式建立连接时:

db, err = gorm.Open("postgres", "host=db port=5432 user=postgres sslmode=disable")

仍然抛出同样的错误。我感谢任何帮助。


解决方案


我和你一样使用 docker compose 与 postgres 和 golang,这是我使用的 docker-compose.yml 文件

version: '2'
services:
  redis:
    image: redis:latest
    command: --appendonly yes

  postgres:
    image: postgres:latest
    environment:
      - POSTGRES_USER=amine
      - POSTGRES_PASSWORD=amine
      - POSTGRES_DB=0000

  app:
    image: ahilaly/amine.in:v0.1.3
    command: -wait
    ports:
      - 7000:7000

    depends_on:
      - postgres
      - redis

    links:
      - postgres:postgres
      - redis:redis

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>