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命令改变临时文件夹;
bash 复制代码
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](#1),Linux内核安全模块AppArmor可能限制MySQL写入新的临时目录。AppArmor配置文件定义程序的文件访问权限,而mysqld的配置文件可能不允许写入指定的新临时目录。
  2. 要解决此问题,需要更新mysqldAppArmor配置文件,以允许MySQL写入新的临时目录。
bash 复制代码
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 小时前
Linux 权限管理:用户组 + 特殊权限 + ACL 解析
linux·运维·计算机·学习笔记·权限管理
2501_907136823 小时前
离线工具箱 内含53个小工具
linux·服务器·网络
时空潮汐3 小时前
神卓N600 NAS身份核验功能深度解析
linux·运维·网络·神卓nas·神卓n600 pro·家庭轻nas
哈哈浩丶4 小时前
安卓系统全流程启动
android·linux·驱动开发
小李独爱秋4 小时前
模拟面试:用自己的话解释一下lvs的工作原理
linux·运维·面试·职场和发展·操作系统·lvs
一路往蓝-Anbo4 小时前
第 7 章:内存地图 (Memory Map) 深度设计——DDR 与 SRAM
linux·stm32·单片机·嵌入式硬件·网络协议
BHXDML4 小时前
VMware Workstation Pro 安装详细教程(超详细图文讲解)
linux·虚拟机
一路往蓝-Anbo5 小时前
第 8 章:M33 领航——引导 A35 加载 U-Boot 与 Linux 内核
linux·运维·服务器·stm32·单片机·嵌入式硬件·网络协议
一路往蓝-Anbo6 小时前
第 6 章:GPIO 与外部中断——M33 掌控下的 LED 与按键响应
linux·stm32·单片机·嵌入式硬件
青衫码上行6 小时前
高频 SQL 50题(基础版)| 查询 + 连接
数据库·sql·学习·mysql