无法连接到mysql docker图像连接被拒绝

问题描述 投票:1回答:1

我刚刚更换了我的旧公司计算机换了新计算机(MACOS),下载项目,现在我试图连接到mysql docker图像,但我总是得到

拨打tcp 127.0.0.1:3306:connect:连接被拒绝

在我的旧电脑中,一切正常,但现在我遇到了这个问题。

我的码头组成(不显示所有内容):

version: "3"
services:
  mysql:
    image: mysql:5.6
    ports:
      - "3306:3306"
    volumes:
      - mysql-data:/var/lib/mysql
      - ./docker-entrypoint-initdb.d:/docker-entrypoint-initdb.d
    environment:
      MYSQL_ROOT_PASSWORD: a
      LANG: C.UTF-8
  adminer:
    image: adminer
    ports:
      - 8082:8080
  nginx:
    build: ../docker-shared/nginx
    ports:
      - 443:443
    volumes:
      - "./nginx_proxy_settings.conf:/etc/nginx/conf.d/nginx_proxy_settings.conf"
volumes:
  mysql-data:

因此,如果我做一个docker-compose up一切正常,你可以检查Adminer正在使用数据的下一个图像:enter image description here

enter image description here enter image description here

这是我连接mysql的Golang代码:

func main() {

    dbConfig := mysql.NewConfig()
    dbConfig.User = "root"
    dbConfig.Passwd = "a"
    dbConfig.Addr = "mysql"
    dbConfig.DBName = "company_prod"

    db, err := sql.Open("mysql", dbConfig.FormatDSN())
    if err != nil {
        panic(err)
    }
    defer db.Close()
}

你知道我做错了吗?

谢谢

mysql docker go docker-compose
1个回答
1
投票

问题是你的go代码无法解析mysql地址,因为它没有部署在compose文件中。

要解决这个问题,您有两个解决方案:

  1. 通过Docker化代码将您的应用程序添加到docker-compose文件中(如果尚未完成),那么它应该能够连接到您的mysql容器。
  2. 公开你的mysql容器的端口,并将你的go代码中使用的地址从mysql更改为localhost:3306(我看到你编辑了你的compose并且端口是公开的,所以你只需要更改代码中的地址)

对于第一个解决方案,您可以将一个简单的Go应用程序构建到Docker镜像中,如下所示:

# Build stage
FROM golang:alpine AS build-env

COPY . /go/src/your/project/path
WORKDIR /go/src/your/project/path

RUN apk update && \
    apk upgrade && \
    <install your deps here if needed>

# Install dep if needed
ENV DEP_VERSION="0.4.1"
RUN curl -L -s https://github.com/golang/dep/releases/download/v${DEP_VERSION}/dep-linux-amd64 -o $GOPATH/bin/dep
RUN chmod +x $GOPATH/bin/dep
RUN dep ensure

# Build your app
RUN go build -o myapp

# Final stage
FROM alpine

WORKDIR /app/myapp
COPY --from=build-env /go/src/your/project/path /app/myapp
ENTRYPOINT ["/app/myapp/myapp"]

然后将其添加到您的撰写文件:

version: "3"
services:
  mysql:
    image: mysql:5.6
    ports:
      - "3306:3306"
    volumes:
      - mysql-data:/var/lib/mysql
      - ./docker-entrypoint-initdb.d:/docker-entrypoint-initdb.d
    environment:
      MYSQL_ROOT_PASSWORD: a
      LANG: C.UTF-8
  adminer:
    image: adminer
    ports:
      - 8082:8080
  myapp:
    build: .
    depends_on:
      - mysql
  nginx:
    build: ../docker-shared/nginx
    ports:
      - 443:443
    volumes:
      - "./nginx_proxy_settings.conf:/etc/nginx/conf.d/nginx_proxy_settings.conf"
volumes:
  mysql-data:

并将端口和传输添加到应用程序的代码中:

func main() {

    dbConfig := mysql.NewConfig()
    dbConfig.User = "root"
    dbConfig.Passwd = "a"
    dbConfig.Addr = "mysql:3306"
    dbConfig.DBName = "websays_prod"
    dbConfig.Net = "tcp"

    db, err := sql.Open("mysql", dbConfig.FormatDSN())
    if err != nil {
        panic(err)
    }
    defer db.Close()
}

如果您不希望将应用程序停靠,那么第二种解决方案就是将代码更改为:

func main() {

    dbConfig := mysql.NewConfig()
    dbConfig.User = "root"
    dbConfig.Passwd = "a"
    dbConfig.Addr = "localhost:3306"
    dbConfig.DBName = "websays_prod"
    dbConfig.Net = "tcp"

    db, err := sql.Open("mysql", dbConfig.FormatDSN())
    if err != nil {
        panic(err)
    }
    defer db.Close()
}
© www.soinside.com 2019 - 2024. All rights reserved.