• 记一次磁盘挂载导致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 &
    
    • 1

    –skip-grant-tables :跳过授权表(不需要密码就可以登录)
    –skip-networking :跳过远程登录(只允许本地登录,防止在重置密码期间,用户通过远程登录数据库,篡改数据记录、修改授权表信息等操作)

    以下总结关于磁盘挂载的几种情况:

    操作磁盘相关命令:

    查看磁盘使用信息(已挂载的磁盘才能看到):df -h
    查看磁盘列表:fdisk -l
    查看磁盘挂载信息(树形展示):lsblk
    查看磁盘挂载信息(列表展示):lsblk -l
    
    • 1
    • 2
    • 3
    • 4

    磁盘挂载到空目录:

    格式化磁盘为ext4系统或者xfs系统:mkfs -t ext4/xfs /dev/vdb
    挂载磁盘:mount /dev/vdb /data
    写入文件(否则重启挂载会失效):echo "/dev/vdb /data ext4 defaults 1 1" 
    
    • 1
    • 2
    • 3

    重新挂载磁盘的步骤:

    ① 取消原有挂载:umount /dev/vdb1
    ② 重新挂载:mount /dev/vdb1 /data
    ③ 修改/etc/fstab文件,实现开机自动挂载:vim /etc/fstab,把/dev/vdb1原先挂载的目录改成/data
    ④ 重启系统
    备注:网上也有的方法是直接修改/etc/fstab文件,再执行mount -a命令重新加载,不需要重启系统
    但是经过测试之后发现这种方式会导致磁盘挂载到两个目录,一个是原来的目录,一个是新的目录,两个目录的内容是一致的,必须重启系统才能恢复正常
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    磁盘挂载到非空目录的步骤

    场景:有时候我们的某个目录磁盘空间满了,这时候就需要加数据盘,然后将数据盘和该目录进行挂载
    ① 将非空目录的数据拷贝到其它目录进行备份,保证要进行磁盘挂载的目录是空的
    ② 特别需要注意:如果非空的这个目录是某些服务的数据存储目录,例如mysql、reids,那么执行步骤①前需要先停止mysql、redis服务,否则会出现问题
    ③ 进行磁盘挂载、并写入/etc/fstab文件
    ④ 挂载成功后再将原来备份的数据重新拷贝回该目录即可
    (这里需要特别注意:备份原来目录的文件时,最好使用mv命令进行移动,最终挂载完成后再转移到原来的目录,也用mv命令;如果这两步操作其中之一使用了cp命令进行拷贝,可能会出现问题)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
  • 相关阅读:
    汉罗塔汉洛塔c++,看不懂ni打我
    【洛谷】P3377 【模板】左偏树(可并堆)
    【推荐】javaweb JAVA JSP网上教务管理系统(学生网上教务评教jsp教务在线课程评教管理系统
    AVL双旋转思路分析与图解
    景联文科技数据采集低价策略帮助AI企业降低模型训练成本
    大数据-玩转数据-Flume
    benchmark性能测试
    进击!BERT句向量表征
    通过Oracle Enterprise Manager管理单实例数据库
    java基于微信小程序的在线外卖订餐系统 uniapp
  • 原文地址:https://blog.csdn.net/can_chen/article/details/127888982