2016-11-21 174 views
-2

我今天开始学习码头工,并且有很大的障碍。 我想要做的是使用go-sql-driver/mysql打开mysql连接。如何正确连接mysql docker容器与go?

我可以用续集临与本地主机连接mysql集装箱:3306
但是,似乎不走的-SQL驱动程序/ MySQL的

db, err := sql.Open("mysql", "root:[email protected]/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" 
      } 
     } 

我不知道该信息,我应该向得到正确的答WER因为我是新来的VM

+0

如果知道你可以在'127.0.0.1:3306'连接到数据库,为什么不试试这个地址? – JimB

+0

我已经尝试使用localhost:3306 db,err:= sql.Open(“mysql”,“root:welcome @/tcp(127.0.0.1:3306)/ test”) – user3882878

+0

如果“sequel pro”可以连接到'localhost :3306',Go的驾驶员没有理由不能这样做。这两个过程有什么区别? – JimB

回答

2

你的连接是错误的,使用

db, err := sql.Open("mysql", "root:[email protected](127.0.0.1:3306)/test") 

注意,“/”被“@”后取出

自述说,一个有效的连接路径就像

[username[:password]@][protocol[(address)]]/dbname 
相关问题