zoukankan      html  css  js  c++  java
  • 解决修改mysql的data_dir所引发的错误

    今天,搭建新购的阿里云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
    

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

    我的博客: javafan.cn

  • 相关阅读:
    java内存管理之内存模型
    HTTP协议
    12 数值的整数次方
    11 二进制中1的个数+二进制补充知识点
    10 矩形覆盖
    9 变态跳台阶
    8 跳台阶
    7斐波那契数列
    6旋转数组的最小数字
    5用两个栈实现队列
  • 原文地址:https://www.cnblogs.com/dongying/p/6650149.html
Copyright © 2011-2022 走看看