考试首页 | 考试用书 | 培训课程 | 模拟考场 | 考试论坛  
  当前位置:编程开发 > MYSQL > 文章内容
  

Mysql教程:解决修改mysql的data_dir所引发的错误问题

 [ 2017年8月31日 ] 【

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

  ?

1
vi /etc/mysql/mysql.conf.d/mysqld.cnf

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

  ?

1
2
cp -r /var/lib/mysql /mnt
chown -R mysql:mysql /mnt/mysql

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

  ?

1
systemctl start mysql

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

  ?

1
tail -f -n100 /var/log/mysql/error.log

  发现错误信息如下:

  ?

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

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

  ?

1
vi /etc/apparmor.d/usr.sbin.mysqld

  发现其中有如下配置:

  ?

1
2
3
# Allow data dir access
/var/lib/mysql/ r,
/var/lib/mysql/** rwk,

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

  ?

1
2
3
4
5
# Allow data dir access
/var/lib/mysql/ r,
/var/lib/mysql/** rwk,
/mnt/mysql/ r,
/mnt/mysql/** rwk,

  保存。重启apparmor服务:

  ?

1
service apparmor restart

  然后再次启动mysql服务:

  ?

1
systemctl start mysql

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

  以上所述是小编给大家介绍的解决修改mysql的data_dir所引发的错误问题,希望对大家有所帮助

本文纠错】【告诉好友】【打印此文】【返回顶部
将考试网添加到收藏夹 | 每次上网自动访问考试网 | 复制本页地址,传给QQ/MSN上的好友 | 申请链接 | 意见留言 TOP
关于本站  网站声明  广告服务  联系方式  站内导航  考试论坛
Copyright © 2007-2013 中华考试网(Examw.com) All Rights Reserved