微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

修改mysql的data_dir所引发错误解决方法

感兴趣的小伙伴,下面一起跟随编程之家 jb51.cc的小编两巴掌来看看吧!

今天,搭建新购的阿里云ECS环境(ubuntu 16.04 LTS),需要将MysqL的数据保存在新挂载的磁盘上(已挂载到/mnt下),先停掉MysqL服务,然后查看MysqL并数据保存的位置:

vi /etc/MysqL/MysqL.conf.d/MysqLd.cnf

发现datadir=/var/lib/MysqL,这也就是数据所在目录,于是将它修改为datadir=/mnt/MysqL, 然后保存,最后将MysqL保存的数据的拷贝到/mnt下:

cp -r /var/lib/my/mnt
chown -R MysqL:my/mnt/MysqL

完成拷贝后,本以为一切就绪,开启MysqL服务:

systemctl start MysqL

但是却发现启动失败,于是再去看看MysqL错误日志:

tail -f -n100 /var/log/MysqL/error.log

发现错误信息如下:

[Warning] Can't create test file /mnt/MysqL/iZwz9c03srb2lq9l374if5Z.lower-test

细想一下,MysqL的配置应该没问题了啊。检查一下apparmor的配置:

vi /etc/apparmor.d/usr.sbin.MysqLd

发现其中有如下配置:

# Allow data dir access
/var/lib/MysqL/ r,/var/lib/MysqL/** rwk,

坑爹啊,刚刚将MysqL配置文件的datadir的/var/lib/MysqL已经改了,但是却仍然被这儿限制了,于是,将它修改为:

 # Allow data dir access
  /var/lib/MysqL/ r,/mnt/MysqL/ r,/mnt/MysqL/** rwk,

保存。重启apparmor服务:

service apparmor restart

然后再次启动MysqL服务:

systemctl start MysqL

服务终于启动成功了。。。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐