无法连接到在我的Mac上运行的mysql

时间:2018-07-18 22:14:02

标签: mysql docker go

我正在使用golang应用程序,将其包装在docker容器中以连接到在我的本地主机(而不是容器)上运行的mysql db。她是我尝试过的: Docker文件

FROM artifactory.cloud.com//golang:1.10-alpine3.7

RUN mkdir -p /go/src/github.kdc.mafsafdfsacys.com/perfGo/
WORKDIR /go/src/github.kdc.mafsafdfsacys.com/perfGo
COPY ./ $WORKDIR
RUN apk update && apk upgrade
RUN go build

RUN chmod +x ./entrypoint.sh
RUN ls
RUN chmod +x ./perfGo
ENTRYPOINT ["./entrypoint.sh"]

perfGo.go

package main

import (
    "database/sql"
    _ "github.com/go-sql-driver/mysql"
)

func main() {
    db, err := sql.Open("mysql", "root:@tcp(localhost:3306)/testdb")
    checkErr(err)
    _,dbErr := db.Exec("USE testdb")
    if err != nil {
        panic(dbErr)
    }

    // insert
    _, inErr := db.Query("INSERT INTO books VALUES('rewyrewryewwrewyt','dsfdsfs','fdsfasaf','55')")

    defer db.Close()
    // if there is an error inserting, handle it
    if inErr != nil {
        panic(inErr.Error())
    }

}

func checkErr(err error) {
    if err != nil {
        panic(err)
    }
}

entrypoint.sh

!/ usr / bin / env bash

./ perfGo

正在使用的命令是

docker build .

用于运行容器的命令: docker run -p 3306:3306 -ti

我看到的错误是

panic: dial tcp 127.0.0.1:3306: connect: connection refused

goroutine 1 [running]:
main.main()
    /go/src/github.kdc.capitalone.com/midnight-tokens/perfGo/perf.go:22 +0x1d4

如果我在没有容器的情况下运行二进制文件,则它在我的mac上运行得很好,但是当我尝试将其作为docker容器的一部分运行时,它无法连接

1 个答案:

答案 0 :(得分:1)

如果应用程序在容器中运行,并且数据库在主机上,则来自容器的数据库地址显然不是print ("{:.2f}".format(len(query_scores)/len(query_name)))(即容器的环回设备)。

如果您使用的是Docker For Mac,则可以使用:

localhost代替"docker.for.mac.localhost:3306"