解决修改mysql的data_dir所引发的错误问题
程序员文章站
2022-06-14 15:19:19
今天,搭建新购的阿里云ecs环境(ubuntu 16.04 lts),需要将mysql的数据保存在新挂载的磁盘上(已挂载到/mnt下),先停掉mysql服务,然后查看mys...
今天,搭建新购的阿里云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/mysql /mnt chown -r mysql:mysql /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, /var/lib/mysql/** rwk, /mnt/mysql/ r, /mnt/mysql/** rwk,
保存。重启apparmor服务:
service apparmor restart
然后再次启动mysql服务:
systemctl start mysql
服务终于启动成功了。。。
以上所述是小编给大家介绍的解决修改mysql的data_dir所引发的错误问题,希望对大家有所帮助
上一篇: 浅析JSONP之解决ajax跨域问题
下一篇: 双层ajax嵌套(可多层)用法实例
推荐阅读
-
解决Node.js mysql客户端不支持认证协议引发的问题
-
解决MYSQL连接端口被占引入文件路径错误的问题
-
解决修改mysql的data_dir所引发的错误问题
-
linux安装mysql5.7.22配置文件my.cnf配置细节及修改密码时出现的问题解决
-
mysql修改密码、找不到mysql数据库、mysql1045等问题的解决办法
-
mysql修改数据库默认路径无法启动问题的解决
-
mysql一对多关联查询分页错误问题的解决方法
-
解决不能修改 Mysql 慢查询 long_query_time 值的问题
-
一次Linux修改MySQL配置不生效的问题解决
-
Mysql 服务 1067 错误 的解决方法:修改mysql可执行文件路径