记一次磁盘挂载导致mysql服务启动失败的问题
服务器某个目录(/data目录)磁盘空间已满,并且该目录下有个子目录还是mysql的数据存储目录(/data/mysql);采用额外新增一块数据盘,并将该数据盘挂载到/data目录下的方式解决磁盘空间不足的问题
问题背景:
服务器某个目录(/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命令进行拷贝,可能会出现问题)
更多推荐
所有评论(0)