当前位置:   article > 正文

【已解决】Docker启动MySQL容器失败:STATUS:‘ Exited (1) 2 minutes ago ‘,远程连接MySQL连不上问题

exited (1) 2 minutes ago

先查看正在运行的容器

  1. # 查看正在运行的容器
  2. docker ps
  3. # 查看所有的docker容器
  4. docker ps -a

这个时候如果显示的是up状态,那就是启动成功了。

状态为exited,所以没有启动成功。

问题所在

好像是权限的问题

docker run时额外加上参数 --privileged问题解决,

官网的解释是给容器额外的权限,看来还是权限不足的问题引起的 

解决问题

1、先停止MySQL服务

docker stop mysql

2、移除镜像

先把镜像移除掉
  1. //移除一个镜像(出现问题可以移除出现启动)
  2. docker rm 8ba572fde8a4(CONTAINER ID)

3、重新启动mysql容器(创建镜像实例)

指定版本

  1. sudo docker run -p 3306:3306 --name mysql --restart=always --privileged=true \
  2. -v /mydata/mysql/log:/var/log/mysql \
  3. -v /mydata/mysql/data:/var/lib/mysql \
  4. -v /mydata/mysql/conf:/etc/mysql \
  5. -e MYSQL_ROOT_PASSWORD=root \
  6. -d mysql:5.7

启动最新版本

  1. docker run -p 3306:3306 --name mysql --restart=always --privileged=true \
  2. -v /usr/local/mysql/log:/var/log/mysql \
  3. -v /usr/local/mysql/data:/var/lib/mysql \
  4. -v /usr/local/mysql/conf:/etc/mysql \
  5. -v /etc/localtime:/etc/localtime:ro \
  6. -e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest

命令含义:容器=完整Linux

  1. docker run:在docker中启动一个容器实例
  2. -p 3306:3306:指定宿主机端口与容器端口映射关系,容器与主机映射端口为,主机3306,容器3306
  3. --name mysql:容器运行后的名称,创建的容器名称
  4. --restart=always:总是跟随docker启动
  5. --privileged=true:获取宿主机root权限
  6. -v /mysqldata/mysql/log:/var/log/mysql:映射日志目录,将容器/var/log/mysql目录下的数据,备份到主机的 /mysqldata/mysql/log目录下
  7. -v /mysqldata/mysql/data:/var/lib/mysql:映射数据目录,将容器/var/lib/mysql目录下的数据,备份到主机的 /mysqldata/mysql/data目录下
  8. -v /mysqldata/mysql/conf:/etc/mysql:映射配置目录,将容器/etc/mysql目录下的数据,备份到主机的 mysqldata/mysql/conf目录下
  9. -v /etc/localtime:/etc/localtime:ro:让容器的时钟与宿主机时钟同步,避免时区的问题,ro是read only的意思,就是只读。
  10. -e MYSQL_ROOT_PASSWORD=123456:指定mysql环境变量,root用户的密码为123456
  11. -d mysql:latest:后台运行mysql容器,版本是latest(最新版)。

 # 再次查看正在运行的容器
docker ps

启动成功了 

4、测试连接

连接虚拟机地址,密码是启动MySQL时设置的密码

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/511560
推荐阅读
相关标签
  

闽ICP备14008679号