云计算百科
云计算领域专业知识百科平台

解决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就可以看到内容了

赞(0)
未经允许不得转载:网硕互联帮助中心 » 解决docker安装MySQL报错端口被占用问题
分享到: 更多 (0)

评论 抢沙发

评论前必须登录!