CentOS7中MariaDB修改datadir后无法启动的解决方法
程序员文章站
2023-10-30 11:40:58
发现问题
最近想把服务器的centos 6.8升级上centos7。但是失败了,重装了系统,重装以后挂载好数据盘后发现mariadb起不来了,查journal log,只...
发现问题
最近想把服务器的centos 6.8升级上centos7。但是失败了,重装了系统,重装以后挂载好数据盘后发现mariadb起不来了,查journal log,只有一行warning
can't create test file /var/lib/mysql/core.lower-test
解决方法
在网上查了一下,有两种方案
第一是说selinux导致的,但是ucloud的镜像默认就是关闭selinux的,所以不是这个问题
第二说是apparmor限制了进程的目录读写,但是那是ubuntu下默认安装的,centos下没有这个东西,所以也不是这个问题。
其他文件权限之类的都检查过了,而且是直接继承的旧磁盘数据,也不会出现问题。
这时我发现,如果直接用mysqld_safe
和mysqld
命令,跳过systemctl
启动进程,能够让mariadb正常起来,于是就去检查mariadb.service
发现其中有一行
protecthome=true
注释是
# prevent accessing /home, /root and /run/user
而我的datadir=/home/mysql
于是把它改成false,就能够正常启动服务了
总结
以上就是为大家总结的centos7系统中mariadb修改datadir后无法启动的解决办法,希望本文的内容对同样遇到这个问题的朋友们能有所帮助,如果有疑问大家可以留言交流。
上一篇: 辣酱炒茼蒿的做法,带你认识茼蒿
下一篇: linux 内存清理/释放命令总结