记一次磁盘挂载导致mysql服务启动失败的问题
问题背景:
服务器某个目录(/data目录)磁盘空间已满,并且该目录下有个子目录还是mysql的数据存储目录(/data/mysql);采用额外新增一块数据盘,并将该数据盘挂载到/data目录下的方式解决磁盘空间不足的问题。
大致操作步骤如下:
① 停止mysql服务(由于涉及移动mysql数据存储目录的操作,因此必须停止mysql服务,否则mysql运行过程中探测到数据目录不存在,会做一些自动重建索引等操作,导致后续mysql读取不到原来的数据,之前就被这个坑过,最终得重新初始化mysql数据库进行解决)
② 将/data目录下的东西移动到一个临时目录/test进行备份
③ 保证/data目录为空之后,进行磁盘挂载
④ 磁盘挂载成功后,再将/test目录下备份的东西拷贝回/data目录(由于我这里使用cp,而不是mv,埋下了坑)
⑤ 重新启动mysql服务,发现启动失败
排错过程:
查看了mysql的日志发现是mysql启动的时候需要往数据存储目录/data/mysql写数据,但是没有权限。
(mysql的日志一般在 /var/log/mysqld.log
,也可以查看mysql的配置文件 /etc/my.cnf
)
出现该错误的原因就是mysql的数据存储目录,即/data/mysql目录的所有者和所属组是mysql用户,步骤②进行备份的时候,我将/data下的东西mv移动到/test目录,这步操作没有问题,/data目录进行磁盘挂载成功之后,步骤④我用cp命令将/test目录下的东西拷贝回来,这时候就出现问题了,由于是拷贝,所以mysql的数据存储目录所有者和所属组就变成了root,因为运行mysql服务进程的用户就是mysql用户,所以mysql用户才有权限读写作mysql的数据存储目录,root用户是没有写权限的。
解决方法就是将/data/mysql目录的所有者和所属组修改为mysql用户:chown -R mysql:mysql /data/mysql
另外,还需要注意一个点:
mysql第一次启动的时候会创建套接字文件:mysql.sock和mysql.sock.lock
套接字文件的路径可以在 /etc/my.cnf
中配置,默认是在/tmp目录下,mysql.sock和mysql.sock.lock这两个文件的所有者和所属组也必须是mysql用户,否则启动的时候会报错;正常来说,初次安装mysql,进行第一次启动的时候,系统自动创建mysql.sock和mysql.sock.lock,并且这两个文件的所有者和所属组就是mysql用户,如果后期因为各种原因,这两个文件被删除了,那么再次启动的时候,系统重新创建这两个文件,但是新建的这两个文件所有者和所属组默认就是root用户的;因此我们需要手动修改这两个文件的所有者和所属组为mysql用户
补充:
mysql还有一种启动方式,跳过授权认证,如果忘记了mysql的密码,可以通过这种方式进行登录,再去手动修改user表
./mysqld --skip-grant-tables --skip-networking --user=root &
–skip-grant-tables :跳过授权表(不需要密码就可以登录)
–skip-networking :跳过远程登录(只允许本地登录,防止在重置密码期间,用户通过远程登录数据库,篡改数据记录、修改授权表信息等操作)
以下总结关于磁盘挂载的几种情况:
操作磁盘相关命令:
查看磁盘使用信息(已挂载的磁盘才能看到):df -h
查看磁盘列表:fdisk -l
查看磁盘挂载信息(树形展示):lsblk
查看磁盘挂载信息(列表展示):lsblk -l
磁盘挂载到空目录:
格式化磁盘为ext4系统或者xfs系统:mkfs -t ext4/xfs /dev/vdb
挂载磁盘:mount /dev/vdb /data
写入文件(否则重启挂载会失效):echo "/dev/vdb /data ext4 defaults 1 1"
重新挂载磁盘的步骤:
① 取消原有挂载:umount /dev/vdb1
② 重新挂载:mount /dev/vdb1 /data
③ 修改/etc/fstab文件,实现开机自动挂载:vim /etc/fstab,把/dev/vdb1原先挂载的目录改成/data
④ 重启系统
备注:网上也有的方法是直接修改/etc/fstab文件,再执行mount -a命令重新加载,不需要重启系统
但是经过测试之后发现这种方式会导致磁盘挂载到两个目录,一个是原来的目录,一个是新的目录,两个目录的内容是一致的,必须重启系统才能恢复正常
磁盘挂载到非空目录的步骤
场景:有时候我们的某个目录磁盘空间满了,这时候就需要加数据盘,然后将数据盘和该目录进行挂载
① 将非空目录的数据拷贝到其它目录进行备份,保证要进行磁盘挂载的目录是空的
② 特别需要注意:如果非空的这个目录是某些服务的数据存储目录,例如mysql、reids,那么执行步骤①前需要先停止mysql、redis服务,否则会出现问题
③ 进行磁盘挂载、并写入/etc/fstab文件
④ 挂载成功后再将原来备份的数据重新拷贝回该目录即可
(这里需要特别注意:备份原来目录的文件时,最好使用mv命令进行移动,最终挂载完成后再转移到原来的目录,也用mv命令;如果这两步操作其中之一使用了cp命令进行拷贝,可能会出现问题)
记一次磁盘挂载导致mysql服务启动失败的问题相关推荐
- ipv6禁用导致rpcbind服务启动失败实例
ipv6禁用导致rpcbind服务启动失败实例 昨天在做服务器磁盘分区扩容的时候出现过一个服务启动的问题,在此记录. 情景再现:前天晚上申请做磁盘扩容,得到批准后,昨天早上5点开始做停机调整维护,历经 ...
- 解决PHPStudy8.1.1 mySQL服务启动失败 数据库工具报错卡死
项目场景: 最近在学PHP,学到mySQL的时候我掏出了我积满灰尘的PHPStudy,但是版本太低了,就去下了个新版: 问题描述: 然后就是mySQL服务无法启动,老倒霉蛋了,一点都不惊讶甚至觉得就该 ...
- mysql star item 失败_解决CentOS7下MySQL服务启动失败的问题.md
--- title: 解决CentOs7下MySQL服务启动失败的问题 date: 2021-01-06 15:21:31 tags: MySQL --- 老夫前几天才在虚拟机的CentOS安装好My ...
- mysql安装服务和安装中常见问题install/Remove of the Service Denied与net start mysql服务启动失败解决方法
mysql安装服务和安装中常见问题install/Remove of the Service Denied与net start mysql服务启动失败解决方法 参考文章: (1)mysql安装服务和安 ...
- linux系统mysql服务启动失败
查看mysql.sock文件,如忘记了文件位置,则查看/etc/my.cnf文件. 查看mysql.sock文件是否存在 若不存在 1.service mysqld stop (停止服务) 2.rm ...
- mysql服务启动失败(Aborting)
mysql服务启动失败(Aborting) 今天在mysql里写入数据时,发现中文无法使用,要更改默认字符集为utf-8才行,为了减少每次都更该字符的麻烦,于是在mysql的配置文件my.ini里找到 ...
- 记kali的mysql服务启动失败,并解决错误记录
新安装的kali系统,想用docker环境走lamp服务,结果搞了好久都没办法正常,没办法,只有使用系统配置lamp服务,结果发现mysql无法启动,只能一步一步解决! hya@hopiron-365 ...
- mysql服务启动失败 Starting MySQL. ERROR! The server quit without updating PID file
[问题描述] 使用 service mysqld start 启动mysql服务失败,提示 Starting MySQL. ERROR! The server quit without updatin ...
- Windows更新后MySQL服务启动失败问题总结
来自2022年4月26日更新 今天启动电脑打开 Navicat 后,数据库少了好几个,然后去查了 此电脑 > 管理 > 服务,发现数据库服务程序启动的是 MySQL80 服务,将服务切换回 ...
最新文章
- php div图片局部刷新,前端jquery 后端 thinkphp 实现局部刷新
- python线程池阻塞队列_福利又来啦!python多线程进阶篇
- Jmeter响应结果unicode转成中文显示
- 谁是卧底的Android应用 (原型源码)
- Python3 条件控制
- 【Linux网络编程】组播
- Mysql数据库的简单备份与还原_史上最简单的MySQL数据备份与还原教程
- oracle中dbms_DBMS中的实例和架构
- phpunit+selenium环境搭建
- java生成Excel文件,下载
- java获取access token_【Java示例】如何获取AccessToken
- 未经授权的ADB Android设备
- Git 报错:error: The requested URL returned error: 401 Unauthorized while accessing
- 实现类似于百度的自动补全搜索
- Mtk touch panel驱动/TP驱动详解
- 自考《软件工程》总结笔记
- Result Maps collection does not contain value for错误提示
- 特殊符号大全复制_特殊符号大全爱好者工具讲解
- AI 考古比胡八一更高效
- 手机拍照反差对焦、相位对焦和激光对焦系统解析