登录
首页 >  Golang >  Go问答

连接到本地host的TCP端口5432时被拒绝

来源:stackoverflow

时间:2024-03-05 19:27:24 336浏览 收藏

哈喽!大家好,很高兴又见面了,我是golang学习网的一名作者,今天由我给大家带来一篇《连接到本地host的TCP端口5432时被拒绝》,本文主要会讲到等等知识点,希望大家一起学习进步,也欢迎大家关注、点赞、收藏、转发! 下面就一起来看看吧!

问题内容

我正在尝试使用 gorm 连接到由以下 docker 配置创建的数据库:

services:
  app:
    build: 
      context: .
      # correct the path to your dockerfile
      dockerfile: dockerfile
    ports:
      - "127.0.0.1:8080:8080"
    volumes:
      - .:/app
    networks:
      - backend
    depends_on:
      - db
  
  db:
    container_name: simple_api_db_user
    restart: always
    image: postgres:latest
    environment:
      postgres_user: mateen
      postgres_password: password
      postgres_db: simple_api_db_user
    volumes:
      - db_data:/var/lib/postgresql/data
    networks:
      - backend
    ports:
      - "127.0.0.1:5430:5430"
  
volumes:
  db_data:

networks:
  backend:
    driver: bridge

这是我在 golang 中的 postgres 连接的代码:

func newpostgresconnection() (*gorm.db, error) {
    psqlconfig, err := dbconfigs.newpostgresqlconfig()
    if err != nil {
        return nil, err
    }

    db, err := sql.open("postgres", psqlconfig.dsn())
    if err != nil {
        log.println("db connection error : ", err.error())
        return nil, err
    }

    if err := db.ping(); err != nil {
        log.println("db ping error: ", err.error())
        return nil, err
    }

    gdb, err := gorm.open(postgres.open(psqlconfig.dsn()), &gorm.config{})
    if err != nil {
        return nil, err
    }

    err = migrate(gdb)
    if err != nil {
        return nil, err
    }

    return gdb, nil
}

这是我打印出来的配置 dsn: &{主机=simple_api_db_user 用户=mateen 密码=密码 dbname=simple_api_db_user 端口=5430 sslmode=禁用时区=utc}

运行我的应用程序时出现以下错误:

simple-api-user-app-1  | 2023/05/10 14:05:16 db ping error:  dial tcp 172.31.0.2:5430: connect: connection refused
simple-api-user-app-1  | 2023/05/10 14:05:16 dial tcp 172.31.0.2:5430: connect: connection refused

这是我的 dockerfile,尽管我认为它可能无关紧要:

# builder
from golang:latest

workdir /app

copy go.mod go.sum ./

run go mod download

run go install github.com/cosmtrek/air@latest

copy . .

cmd [ "air" ]

expose 8080

ps:当我尝试在 dbeaver 中连接到 postgres 端口 5430 时,出现以下错误:

The connection attempt failed.
  EOFException
  java.io.EOFException

编辑:已更改


正确答案


postgres 容器正在侦听 5432。因此 ports 选项应设置为 5430:5432。这会将主机上的端口 5430 映射到 docker 容器上的 5432

以上就是《连接到本地host的TCP端口5432时被拒绝》的详细内容,更多关于的资料请关注golang学习网公众号!

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