mysql5.7报错端口占用,服务起不来
首先说说我的解决步骤吧
1 lsof -i :3306
2 重启mysql服务,如果还是起不来,那就kill掉pid号,这样要是kill不掉就加上 -9
3 修改/etc/my.cnf的配置文件,修改端口,并看看log_error字段指的文件在哪里,tailf mysql-error文件。再重新启动
4 启动成功之后,就把原来的端口给改回来吧
5 顺便把在网上找的相关问题解答贴出来
1.可能是/usr/local/mysql/data/rekfan.pid文件没有写的权限 解决方法 :给予权限,执行 “chown -R mysql:mysql /var/data” “chmod -R 755 /usr/local/mysql/data” 然后重新启动mysqld! 2.可能进程里已经存在mysql进程 解决方法:用命令“ps -ef|grep mysqld”查看是否有mysqld进程,如果有使用“kill -9 进程号”杀死,然后重新启动mysqld! 3.可能是第二次在机器上安装mysql,有残余数据影响了服务的启动。 解决方法:去mysql的数据目录/data看看,如果存在mysql-bin.index,就赶快把它删除掉吧,它就是罪魁祸首了。本人就是使用第三条方法解决的 ! 4.mysql在启动时没有指定配置文件时会使用/etc/my.cnf配置文件,请打开这个文件查看在[mysqld]节下有没有指定数据目录(datadir)。 解决方法:请在[mysqld]下设置这一行:datadir = /usr/local/mysql/data 5.skip-federated字段问题 解决方法:检查一下/etc/my.cnf文件中有没有没被注释掉的skip-federated字段,如果有就立即注释掉吧。 6.错误日志目录不存在 解决方法:使用“chown” “chmod”命令赋予mysql所有者及权限 7.selinux惹的祸,如果是centos系统,默认会开启selinux 解决方法:关闭它,打开/etc/selinux/config,把SELINUX=enforcing改为SELINUX=disabled后存盘退出重启机器试试。 但是没有解决,最后直接给/usr/local/mysql/data 目录 chmod 777 -R /usr/local/myql/data 问题解决 应该是 权限问题,不能生成localhost.localdomain.pid 文件