解决修改mysql的data_dir所引发的错误问题
今天,搭建新购的阿里云ECS环境(ubuntu16.04LTS),需要将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/mysql/mnt chown-Rmysql:mysql/mnt/mysql
完成拷贝后,本以为一切就绪,开启mysql服务:
systemctlstartmysql
但是却发现启动失败,于是再去看看mysql的错误日志:
tail-f-n100/var/log/mysql/error.log
发现错误信息如下:
[Warning]Can'tcreatetestfile/mnt/mysql/iZwz9c03srb2lq9l374if5Z.lower-test
细想一下,mysql的配置应该没问题了啊。检查一下apparmor的配置:
vi/etc/apparmor.d/usr.sbin.mysqld
发现其中有如下配置:
#Allowdatadiraccess /var/lib/mysql/r, /var/lib/mysql/**rwk,
坑爹啊,刚刚将mysql配置文件的datadir的/var/lib/mysql已经改了,但是却仍然被这儿限制了,于是,将它修改为:
#Allowdatadiraccess /var/lib/mysql/r, /var/lib/mysql/**rwk, /mnt/mysql/r, /mnt/mysql/**rwk,
保存。重启apparmor服务:
serviceapparmorrestart
然后再次启动mysql服务:
systemctlstartmysql
服务终于启动成功了。。。
以上所述是小编给大家介绍的解决修改mysql的data_dir所引发的错误问题,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的,在此也非常感谢大家对毛票票网站的支持!