docker安装MySQL报错端口被占用问题解决办法
安装MySQL的时候一直显示报错
![]()
这个是宿主机 3306 端口被占用,导致 mysql 容器启动失败。
解决步骤:
1.查看占用进程
netstat -tulpn | grep :3306
如果显示未找到命令就说明系统缺少 netstat 工具,它属于 net-tools 包, 需要进行安装
yum install -y net-tools
安装完成之后就可以进行查看了
netstat -tulpn | grep :3306
然后就可以看到占用的进程
2.查看占用的进程

从 netstat 输出能看到,mysqld 进程(PID 9420 )占用了 3306 和 33060 端口,导致 Docker 中 mysql 容器启动失败(端口冲突 )
3.查看mysqld 服务状态
先确认当前宿主机上的 MySQL 服务是否有正在进行的重要业务, 判断是否可以停掉进程
查看服务状态
systemctl status mysqld
停止服务
systemctl stop mysqld
然后再查看端口释放的情况
netstat -tulpn | grep :3306
如果出现下面这种情况:

说明系统里 mysqld 服务未以标准 systemd 服务形式配置(可能是手动编译安装、服务名不同 )
可以绕过 systemd 服务,直接杀进程释放端口
操作:
ps -ef | grep mysqld kill -9 <进程ID> # 替换为实际 PID

我这里就是kill -9 9420 9251
然后再查看端口释放的情况
netstat -tulpn | grep :3306
然后就可以发现进程已经没了
4.重启

然后docker ps就可以看到内容了
总结
到此这篇关于docker安装MySQL报错端口被占用问题解决办法的文章就介绍到这了,更多相关docker安装MySQL报错端口被占用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Mysql实现合并多个分组(GROUP_CONCAT及其平替函数)
MySQL 中提供了多种合并字符串的函数和操作方法,包括 GROUP_CONCAT、CONCAT_WS 和 CONCAT 等,本文介绍了 MySQL 中 GROUP_CONCAT 函数以及 CONCAT_WS、CONCAT 函数并通过示例代码演示了它们的用法,感兴趣的可以了解一下2023-10-10
windows下MySQL5.6版本安装及配置过程附有截图和详细说明
这篇文章主要介绍了windows下MySQL5.6版本安装及配置过程附有截图和详细说明,需要的朋友可以参考下2013-06-06


最新评论