Ubuntu修改MySQL的tmpdir参数失败的解决方法

问题

  1. 在查询大表时,MySQL提示ERROR 3 (HY000): Error writing file '/tmp/MYfd=268' (OS errno 28 - No space,应该是临时文件夹/tmp没有足够的空间;
  2. 想修改文件夹/etc/mysql/my.cnf中的参数tmpdir命令改变临时文件夹;
sudo nano /etc/mysql/my.cnf
# 以下是my.cnf文件中新增的内容
[mysqld]
tmpdir = /path_to_new_tmp
# 以上是my.cnf文件中新增的内容

sudo chown -R root:root /path_to_new_tmp
sudo chmod -R 1777 /path_to_new_tmp
  1. 但修改后重启MySQL服务时提示Job for mysql.service failed because the control process exited with error code. See "systemctl status mysql.service" and "journalctl -xeu mysql.service" for details.查看log文件也没发现相关提示;
  2. 经过测试(删除修改后的tmpdir参数即可启动MySQL服务成功),推测应该是新的临时文件夹出现了问题,但是权限也给了,为啥呢?

解决方法

  1. 搜索得知1,Linux内核安全模块AppArmor可能限制MySQL写入新的临时目录。AppArmor配置文件定义程序的文件访问权限,而mysqld的配置文件可能不允许写入指定的新临时目录。
  2. 要解决此问题,需要更新mysqldAppArmor配置文件,以允许MySQL写入新的临时目录。
sudo vim /etc/apparmor.d/usr.sbin.mysqld
# 以下是usr.sbin.mysqld文件中新增的内容,以允许对新临时目录进行读写访问
# Allow data dir access
  /path_to_new_tmp/ r,
  /path_to_new_tmp/** rwk,
# 以上是usr.sbin.mysqld文件中新增的内容

sudo /etc/init.d/apparmor reload
sudo /etc/init.d/mysql restart
sudo systemctl restart mysql
# 检查tmpdir变量是否修改成功
mysql -u root -p[password] -e "SHOW VARIABLES LIKE 'tmpdir';"

  1. https://stackoverflow.com/questions/18944653/mysql-wont-start-after-changing-temp-dir-on-ubuntu-12-04 ↩︎

相关推荐

  1. Ubuntu修改MySQLtmpdir参数失败解决方法

    2024-06-16 07:38:04       64 阅读
  2. ubuntu20.04执行sudo apt-get update失败解决方法

    2024-06-16 07:38:04       40 阅读
  3. 解决Ubuntu18.04 上安装 ffmpeg 失败方法

    2024-06-16 07:38:04       166 阅读
  4. 如何解决Ubuntu系统域名解析失败问题

    2024-06-16 07:38:04       33 阅读
  5. springMvcAop解析修改参数

    2024-06-16 07:38:04       52 阅读
  6. MySQL忘记root密码和修改root密码解决方法

    2024-06-16 07:38:04       51 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-16 07:38:04       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-16 07:38:04       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-16 07:38:04       82 阅读
  4. Python语言-面向对象

    2024-06-16 07:38:04       91 阅读

热门阅读

  1. 两个矩阵差异分析

    2024-06-16 07:38:04       28 阅读
  2. Django ORM非空判断、以及通用写法

    2024-06-16 07:38:04       35 阅读
  3. 数据库面试

    2024-06-16 07:38:04       31 阅读
  4. MySQL的高可用方案:深入Galera Cluster和ProxySQL

    2024-06-16 07:38:04       75 阅读
  5. c++ 单例模式

    2024-06-16 07:38:04       23 阅读
  6. Elasticsearch机器学习初探:智能数据洞察

    2024-06-16 07:38:04       33 阅读
  7. 可以免费发外链的论坛有哪些?

    2024-06-16 07:38:04       33 阅读
  8. 012_redhat安装activemq

    2024-06-16 07:38:04       32 阅读