admin管理员组文章数量:1572720
问题描述
ubuntu虚拟机下安装docker,用docker安装mysql。docker search、docker pull和docker run都正常,而且用docker ps查看也是up的状态。进入docker,用mysql -u root -p来登录mysql,报错
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2)
原因分析
当时,创建容器的命令为
docker run -id -p 3309:3306 --name mysql-test5 -v $PWD/conf:/etc/mysql/conf.d -v $PWD/logs:/logs -v $PWD/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7 /bin/bash
解决方法
在创建容器时,后边不要加“/bin/bash”解释器,即
docker run -id -p 3309:3306 --name mysql-test5 -v $PWD/conf:/etc/mysql/conf.d -v $PWD/logs:/logs -v $PWD/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7
从仓库的示例也可以看出,没有“/bin/bash”
后面的/bin/bash的作用是表示载入容器后运行bash ,docker中必须要保持一个进程的运行,要不然整个容器启动后就会马上kill itself,这个/bin/bash就表示启动容器后启动bash。
........整整一下午,就看了这么个东西,呃 ~~~~
参考文章
本文标签: mysqlServerLocalDockerconnect
版权声明:本文标题:【docker】Can‘t connect to local MySQL server through socket ‘varrunmysqldmysqld.sock‘ (2) 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://www.elefans.com/dongtai/1725805958a1044031.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论