MySQL篇之解决源码安装mysql无法更新PID文件问题

一、前言
一般情况下,当我们在线上环境需要进行源码安装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
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值