今天,搭建新购的阿里云ECS环境(ubuntu 16.04 LTS),须要将mysql的数据保存在新挂载的磁盘上(已挂载到/mnt下),先停掉mysql服务,而后查看mysql并数据保存的位置:
java
vi /etc/mysql/mysql.conf.d/mysqld.cnf
发现datadir=/var/lib/mysql, 这也就是数据所在目录,因而将它修改成datadir=/mnt/mysql, 而后保存, 最后将mysql保存的数据的拷贝到/mnt下:mysql
cp -r /var/lib/mysql /mnt chown -R mysql:mysql /mnt/mysql
完成拷贝后,本觉得一切就绪,开启mysql服务:sql
systemctl start mysql
可是却发现启动失败,因而再去看看mysql的错误日志:ubuntu
tail -f -n100 /var/log/mysql/error.log
发现错误信息以下:
[Warning] Can't create test file /mnt/mysql/iZwz9c03srb2lq9l374if5Z.lower-testapp
细想一下,mysql的配置应该没问题了啊。检查一下apparmor的配置:阿里云
vi /etc/apparmor.d/usr.sbin.mysqld
发现其中有以下配置:rest
# 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, /var/lib/mysql/** rwk, /mnt/mysql/ r, /mnt/mysql/** rwk,
保存。重启apparmor服务:code
service apparmor restart
而后再次启动mysql服务:get
systemctl start mysql
服务终于启动成功了。。。
个人博客: javafan.cn