如何正确连接mysql docker容器与go?

时间:2016-11-21 19:38:26

标签: go docker

我今天开始学习码头工作并且有很大的拦截器。 我想要做的是使用go-sql-driver / mysql打开mysql连接。

我可以使用sequel pro与localhost连接mysql容器:3306
但是,似乎无法使用go-sql-driver / mysql

db, err := sql.Open("mysql", "root:welcome@/tcp(127.0.0.1:3306)/test")

//尝试了172.17.0.1:3306和172.17.0.2:3306

这是我的容器的网络信息

"Networks": {
            "bridge": {
                "IPAMConfig": null,
                "Links": null,
                "Aliases": null,
                "NetworkID": "47b2a5c798522f5eb6688c4540b4017335eb174528d510b9f1d35d125313017c",
                "EndpointID": "ca2256684928e4184efd36f880cd70d3809d79db5b30c10ab37c66ccbbbba610",
                "Gateway": "172.17.0.1",
                "IPAddress": "172.17.0.2",
                "IPPrefixLen": 16,
                "IPv6Gateway": "",
                "GlobalIPv6Address": "",
                "GlobalIPv6PrefixLen": 0,
                "MacAddress": "02:42:ac:11:00:02"
            }
        }

由于我是vm

的新手,我不确定应该提供哪些信息才能得到正确答案

1 个答案:

答案 0 :(得分:3)

您的连接错误,请使用

db, err := sql.Open("mysql", "root:welcome@tcp(127.0.0.1:3306)/test")

请注意" /"在" @"

之后删除

README表示有效的连接路径类似于

[username[:password]@][protocol[(address)]]/dbname