【问题标题】:Docker-compose api and database configurationDocker-compose api和数据库配置
【发布时间】:2020-02-19 23:46:41
【问题描述】:

我在将 Api 与在容器中运行的 MySQL 数据库连接时遇到问题。我有 Golang Api 的 Dockerfile:

FROM golang:latest
 WORKDIR /app
 COPY go.mod go.sum ./
RUN go mod download
 COPY . .
WORKDIR /app/bin
 EXPOSE 8080
 RUN go run ./../cmd/web/

我通常使用 database/sql 连接应用程序中的数据库:

dsn = "user1:pass@tcp(wpmysql:3306)/wp?parseTime=true"
db, err := sql.Open("mysql", dsn)

我的 docker-compose.yml:

version: '3'
services:
  db:
    image: mysql:5.7
    container_name: ${MYSQL_CONTAINER_NAME}
    ports: 
        - 3306:3306
    command: --init-file /usr/src/app/init.sql
    volumes:
        - ./init.sql:/usr/src/app/init.sql
    environment:
        - MYSQL_USER=${MYSQL_USER}
        - MYSQL_PASSWORD=${MYSQL_PASS}
        - MYSQL_DATABASE=${MYSQL_DB}
        - MYSQL_ROOT_PASSWORD=${DB_PASSWORD}
    networks:
        - fullstack
  web:
    container_name: wpapi
    build: .
    ports:
        - 8080:8080
    restart: on-failure
    volumes:
        - .:/usr/src/app/
    depends_on:
        - db
    networks:
        - fullstack

networks:
    fullstack:
        driver: bridge

与docker-compose.yml在同一目录下的是文件.env:

DB_PASSWORD=pass
MYSQL_PORT=3306
MYSQL_USER=user1
MYSQL_PASS=pass
MYSQL_DB=wp
MYSQL_CONTAINER_NAME=wpmysql

通话后表扬:

$ docker-compose up -d db
$ docker-compose build web

我收到错误ERROR main.go:46: dial tcp: lookup wpmysql on 37.8.214.2:53: no such host。容器列表如下:

CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                               NAMES
9fbaf67df5bf        2778fcda2046        "/bin/sh -c 'go run …"   14 seconds ago      Up 13 seconds       8080/tcp                            mystifying_shannon
7f6c76cc9c4f        mysql:5.7           "docker-entrypoint.s…"   40 minutes ago      Up About a minute   0.0.0.0:3306->3306/tcp, 33060/tcp   wpmysql

此外,当我尝试通过dsn = "user1:pass@tcp(localhost:3306)/wp?parseTime=true"dsn = "root:pass@tcp(localhost:3306)/wp?parseTime=true" 连接应用程序时,我收到另一个错误: dial tcp 127.0.0.1:3306: connect: connection refused 虽然我可以使用 rootuser1 凭据进入容器 (docker exec -it wpmysql bash -l) 和 sign in

【问题讨论】:

    标签: mysql docker docker-compose docker-networking


    【解决方案1】:

    在您的 docker 文件中,您有:

    RUN go run ./../cmd/web/

    这将尝试在构建过程中构建并运行您的可执行文件。网络fullstack 目前不可用。我想你可能打算使用:

    CMD go run ../cmd/web/

    这会将您启动(即docker-compose up)容器时运行的默认命令设置为go run ../cmd/web/。更好的是:

    RUN go build ../cmd/web/
    CMD ../cmd/web/web
    

    这将构建您的应用程序作为构建容器过程的一部分,然后将生成的可执行文件设置为默认命令。这样做的好处是编译错误会在您构建镜像时变得明显(这意味着不是每次启动容器时都构建应用程序)。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-09-06
      • 2021-01-08
      • 2021-01-30
      • 2020-06-28
      • 1970-01-01
      相关资源
      最近更新 更多