一、前言
一般情况下,当我们在线上环境需要进行源码安装mysql时,经常会遇到安装过后的mysql无法启动,启动失败
报错原因:无法更新PID文件。如下所示:
二、今天就来彻底总结下产生该问题的原因
原因一般分为以下几种:
1、在之前已经安装过mysql,而且该服务并未关闭。(或者源码安装之前直接卸载mysql,但是没有关闭服务)
这也是我亲身经历。。
可通过systemctl stop mysqld 停掉服务
systemctl stop mysqld
2、数据初始化失败。
在进行数据初始化时,先配置mysql的配置文件 /etc/my.cnf
注:指定对应的basedir【mysql存放位置】
,datadir【mysql数据存放目录】
,socket【mysql的socket文件生成位置】
,log-error【log日志位置】
,pid-file【生成mysql的pid文件】
,–user=mysql 【这里最好利用mysql用户启动】
然后进行数据初始化
cd /usr/local/mysql/bin
sudo ./mysqld --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --pid-file=/usr/local/mysql/mysql.pid --log-error=/usr/local/mysql/log/error.log --port=3307
然后源码启动mysql
/etc/init.d/mysqld start
启动成功,问题解决~
3、数据目录错误
一般数据目录错误指的是在/etc/my.cnf 中 配置的目录不存在,或者对应的路径有问题
需要指定对应目录都存在即可!
4、数据目录权限问题
1、经常出现问题的是mysql的数据存放目录data权限出现问题,没有进行权限更改
如果没有进行权限更改,执行如下命令:
cd /usr/local/mysql
sudo chown -R mysql.mysql .
2、查看3306端口是否被占用,如果被占用,杀掉进程,释放3306端口,因为套接口文件socket不能被重复使用,然后再重启mysql服务。
netstat -antup | grep 3306
sudo kill xxx