【BUG】Docker启动MySQL报错

个人主页金鳞踏雨

个人简介:大家好,我是金鳞,一个初出茅庐的Java小白

目前状况:22届普通本科毕业生,几经波折了,现在任职于一家国内大型知名日化公司,从事Java开发工作

我的博客:这里是CSDN,是我学习技术,总结知识的地方。希望和各位大佬交流,共同进步 ~

问题描述

这一段时间,学习了黑马的一个的SpringCloud项目——学成在线。我将项目中需要的组件都放在了我的一台虚拟机上,用docker的方式。

但是发现,每次启动的时候MySQL容器经常失败,报错如下:

Error response from daemon: driver failed programming external connectivity on endpoint mysql (868f20f1e4165e72ae2275dec7bee377572098cfcff3177b413d9f32a4b4928e): Error starting userland proxy: listen tcp4 0.0.0.0:3306: bind: address already in use
Error: failed to start containers: 0c4e5bdc6f7e

大概是端口占用......

解决办法

实际上解决这个问题也很容易

一、暴力

找到占用3306端口的进程,然后kill即可

我们先使用命令,找到所有进程的端口

netstat -tanlp

然后直接使用 kill 命令

# 1837 -- 进程号
kill 1837

再重新启动mysql即可

# 0c4e5bdc6f7e -- 通过docker ps -a 查看到的容器的ID
docker start 0c4e5bdc6f7e

但是,这样子做,对于我来说还是有点治标不治本! 因为如果这样子处理的话,相当于每次启动vm的时候,都要重复一遍上述的工作。

因为,我的docker没有自启动,而这个 mariadb(我也不知道是怎么来的~~~可能是之前的机子有禅道,禅道用的数据库就是mariadb)在启动VM的时候就启动了,3306端口先被占用了。

二、卸载mariadb

由于我的端口占用是禅道引起的,所以我直接卸载禅道即可!

# 停止服务
/opt/zbox/zbox stop

cd /opt

rm -rf /zbox

停止服务,删除zbox目录即可卸载。

三、重新指定这个MySQL的端口

可以把之前的mysql容器删除了,再重新创建一个新的,如下: 

docker run --name mysql \
  --restart=always \
  -e MYSQL_ROOT_PASSWORD=888888 \
  -v /home/lcxz8686/DockerContainerProperties/mysql/data:/var/lib/mysql \
  -v /home/lcxz8686/DockerContainerProperties/mysql/conf:/etc/mysql/conf.d \
  -p 3309:3306 \
  -d \
  mysql:8.0.30

如果不想删除,可以这样子做:

先进入容器内部

docker exec -it mysql /bin/bash

将容器里面的 /etc/mysql/my.cnf  文件复制出来修改(原因是docker容器内部大多数不支持vim命令,下载安装比较麻烦!!!)如果里面没有my.cnf就在 CentOS 上面创建一个,编写好,再怼回去。

# 容器复制命令 -- 需要退出容器
docker cp mysql:/etc/mysql/my.cnf /etc/mysql 

修改完了再cp回去

docker cp my.cnf mysql:/etc/mysql/ 

再重启该容器即可!!! 

文章到这里就结束了,如果有什么疑问的地方,可以在评论区指出~

希望能和大佬们一起努力,诸君顶峰相见

再次感谢各位小伙伴儿们的支持!!!

猜你喜欢

转载自blog.csdn.net/weixin_43715214/article/details/132386007