问题背景:
服务器某个目录(/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服务启动失败的问题相关推荐

  1. ipv6禁用导致rpcbind服务启动失败实例

    ipv6禁用导致rpcbind服务启动失败实例 昨天在做服务器磁盘分区扩容的时候出现过一个服务启动的问题,在此记录. 情景再现:前天晚上申请做磁盘扩容,得到批准后,昨天早上5点开始做停机调整维护,历经 ...

  2. 解决PHPStudy8.1.1 mySQL服务启动失败 数据库工具报错卡死

    项目场景: 最近在学PHP,学到mySQL的时候我掏出了我积满灰尘的PHPStudy,但是版本太低了,就去下了个新版: 问题描述: 然后就是mySQL服务无法启动,老倒霉蛋了,一点都不惊讶甚至觉得就该 ...

  3. mysql star item 失败_解决CentOS7下MySQL服务启动失败的问题.md

    --- title: 解决CentOs7下MySQL服务启动失败的问题 date: 2021-01-06 15:21:31 tags: MySQL --- 老夫前几天才在虚拟机的CentOS安装好My ...

  4. mysql安装服务和安装中常见问题install/Remove of the Service Denied与net start mysql服务启动失败解决方法

    mysql安装服务和安装中常见问题install/Remove of the Service Denied与net start mysql服务启动失败解决方法 参考文章: (1)mysql安装服务和安 ...

  5. linux系统mysql服务启动失败

    查看mysql.sock文件,如忘记了文件位置,则查看/etc/my.cnf文件. 查看mysql.sock文件是否存在 若不存在 1.service mysqld stop (停止服务) 2.rm ...

  6. mysql服务启动失败(Aborting)

    mysql服务启动失败(Aborting) 今天在mysql里写入数据时,发现中文无法使用,要更改默认字符集为utf-8才行,为了减少每次都更该字符的麻烦,于是在mysql的配置文件my.ini里找到 ...

  7. 记kali的mysql服务启动失败,并解决错误记录

    新安装的kali系统,想用docker环境走lamp服务,结果搞了好久都没办法正常,没办法,只有使用系统配置lamp服务,结果发现mysql无法启动,只能一步一步解决! hya@hopiron-365 ...

  8. mysql服务启动失败 Starting MySQL. ERROR! The server quit without updating PID file

    [问题描述] 使用 service mysqld start 启动mysql服务失败,提示 Starting MySQL. ERROR! The server quit without updatin ...

  9. Windows更新后MySQL服务启动失败问题总结

    来自2022年4月26日更新 今天启动电脑打开 Navicat 后,数据库少了好几个,然后去查了 此电脑 > 管理 > 服务,发现数据库服务程序启动的是 MySQL80 服务,将服务切换回 ...

最新文章

  1. php div图片局部刷新,前端jquery 后端 thinkphp 实现局部刷新
  2. python线程池阻塞队列_福利又来啦!python多线程进阶篇
  3. Jmeter响应结果unicode转成中文显示
  4. 谁是卧底的Android应用 (原型源码)
  5. Python3 条件控制
  6. 【Linux网络编程】组播
  7. Mysql数据库的简单备份与还原_史上最简单的MySQL数据备份与还原教程
  8. oracle中dbms_DBMS中的实例和架构
  9. phpunit+selenium环境搭建
  10. java生成Excel文件,下载
  11. java获取access token_【Java示例】如何获取AccessToken
  12. 未经授权的ADB Android设备
  13. Git 报错:error: The requested URL returned error: 401 Unauthorized while accessing
  14. 实现类似于百度的自动补全搜索
  15. Mtk touch panel驱动/TP驱动详解
  16. 自考《软件工程》总结笔记
  17. Result Maps collection does not contain value for错误提示
  18. 特殊符号大全复制_特殊符号大全爱好者工具讲解
  19. AI 考古比胡八一更高效
  20. 手机拍照反差对焦、相位对焦和激光对焦系统解析

热门文章

  1. Java图标对应的文件类型
  2. 文件上传,出现400 的错误问题
  3. 单通道图片转换为3通道图片,实现灰度图上添加彩色标注
  4. 数据科学与大数据技术专业 —— 云计算●虚拟化 课程 期末复习卷及其简答(2)
  5. 开发小程序以及后台管理系统攥淘宝佣金
  6. 使用thop库对yolo等深度学习模型的FLOPS进行计算
  7. 信号与槽是如何实现的_Nature | 破解Wnt信号高效远距离传递之谜
  8. 为什么说社群团购时代来临了?
  9. 三子棋小游戏(超详细)
  10. HTML5网页设计成品_中华传统文化网页题材_诗词网页4页_web课程设计网页制作