【问题标题】:Connecting Golang and Postgres docker containers连接 Golang 和 Postgres docker 容器
【发布时间】:2021-05-07 08:37:05
【问题描述】:

我正在尝试在 localhost:8080 上运行一个使用 postgres 数据库的 golang 服务器。我尝试将数据库和服务器都容器化,但似乎无法将它们连接起来。

ma​​in.go

func (a *App) Initialize() {
    var db *gorm.DB
    var err error
    envErr := godotenv.Load(".env")
    if envErr != nil {
        log.Fatalf("Error loading .env file")
    }
    var dbString = fmt.Sprintf("port=5432 user=sample dbname=sampledb sslmode=disable password=password host=db")
    
    db, err = gorm.Open("postgres", dbString)
    if err != nil {
        fmt.Printf("failed to connect to databse\n",err)
    }
    a.DB=model.DBMigrate(db)
    a.Router = mux.NewRouter()
    a.setRoutes()
}

//Get : get wrapper
func (a *App) Get(path string, f func(w http.ResponseWriter, r *http.Request)) {
    a.Router.HandleFunc(path, f).Methods("GET")
}

//Post : post wrapper
func (a *App) Post(path string, f func(w http.ResponseWriter, r *http.Request)) {
    a.Router.HandleFunc(path, f).Methods("POST")
}

//Run : run on port
func (a *App) Run(port string) {
    handler := cors.Default().Handler(a.Router)
    log.Fatal(http.ListenAndServe(port, handler))
}

func (a *App) setRoutes() {
    a.Get("/", a.handleRequest(controller.Welcome))
    a.Get("/users", a.handleRequest(controller.GetUsers))
    a.Get("/user/{id}", a.handleRequest(controller.GetUser))
    a.Post("/login", a.handleRequest(controller.HandleLogin))
    a.Post("/users/add", a.handleRequest(controller.CreateUser))
    a.Post("/validate", a.handleRequest(controller.HandleValidation))
}

func main() {
    app := &App{}
    app.Initialize()
    app.Run(":8080")

}


服务器 Dockerfile

FROM golang:latest

RUN mkdir /app
WORKDIR /app/server

COPY go.mod .
COPY go.sum .
RUN go mod download
COPY . .

docker-compose.yml

version: '3.7'
services:
    db:
        image: postgres
        container_name: ep-db
        environment:
            - POSTGRES_PORT=${DB_PORT}
            - POSTGRES_USER=${DB_USERNAME}  
            - POSTGRES_PASSWORD=${DB_PASSWORD}
            - POSTGRES_DB=${DB_NAME}
            
        ports:
            - '5432:5432'
        volumes:
            - ./db:/var/lib/postgresql/data"
        networks:
            - internal
    server:
        container_name: ep-server
        build:
            context: ./server
            dockerfile: Dockerfile
        command: bash -c "go build && ./server -b 0.0.0.0:8080 --timeout 120"
        volumes:
            - './server:/app/server'
        expose:
            - 8080
        depends_on: 
            - db
        networks:
            - internal
        stdin_open: true
volumes:
    db:  
    server:
networks:
    internal:
      driver: bridge

当我在我的计算机上本地运行它时,我有一些 get 和 post 请求返回正确的值(例如 localhost:8080/users 会从数据库返回一个充满用户的 JSON)但是当我在服务器容器,我没有得到任何结果。我是 docker 新手,到目前为止我在做什么有问题吗?

【问题讨论】:

  • 你得到了什么?容器日志中是否有任何错误?您是否需要为您的 server 容器声明 ports:,以便可以从 Docker 外部访问它?
  • 尝试在 docker compose 中将主机名添加到您的数据库中,并使用该名称在代码中进行连接。
  • 您遇到什么错误?

标签: postgresql docker go docker-compose


【解决方案1】:

每个 docker 容器都有自己的 IP 地址。当您从应用程序连接到 postgres 数据库时,您使用的是localhost,它是应用程序的容器,而不是数据库。根据您的 docker-compose,您应该使用主机名 db(服务名称)连接到数据库。

【讨论】:

    【解决方案2】:

    按照@DavidMaze 的建议,您应该验证来自 服务器 容器的日志。还有,

    1. 首先确保ep-server正在运行(检查docker container ls的输出是否有ep-server的运行状态)李>
    2. 运行 docker logs ep-server 以查看错误(如果有)
    3. 如果日志中没有错误,则运行 docker exec -it ep-server bash 登录到您的容器并运行 telnet ep-db 5432验证您的 postgres 实例是否可以从 ep-server 访问

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2017-06-06
      • 2016-07-20
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2022-06-10
      • 2021-02-22
      • 2019-03-16
      相关资源
      最近更新 更多