如何正确连接mysql docker容器和go?
我今天开始学习docker,有了big blocker。 我想做的是使用GoSQL驱动程序/mysql打开mysql连接 我可以使用sequel pro与localhost:3306连接mysql容器 但是,它似乎不适用于go sql驱动程序/mysql如何正确连接mysql docker容器和go?,go,docker,Go,Docker,我今天开始学习docker,有了big blocker。 我想做的是使用GoSQL驱动程序/mysql打开mysql连接 我可以使用sequel pro与localhost:3306连接mysql容器 但是,它似乎不适用于go sql驱动程序/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 这是我的容器的网络信息 "N
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新手您的连接错误,请使用
db, err := sql.Open("mysql", "root:welcome@tcp(127.0.0.1:3306)/test")
请注意,在“@”之后删除“/”
自述文件说有效的连接路径如下
[username[:password]@][protocol[(address)]]/dbname
如果你知道你可以连接到数据库
127.0.0.1:3306
,为什么不试试这个地址呢?我已经用localhost:3306db试过了,err:=sql.Open(“mysql”,“root:welcome@/tcp(127.0.0.1:3306)/test”)如果“sequel pro”可以连接到localhost:3306
,Go驱动程序没有理由不能。这两个过程的区别是什么?这就是为什么我发布了这个问题。。。它应该工作,但它不是。围棋的错误是什么?你是如何运行“sequel pro”使其连接的?为容器发布的端口是什么?