【docker】Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘ (2)

问题描述

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。 

........整整一下午,就看了这么个东西,呃 ~~~~

参考文章

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值