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 ↩︎

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/27568.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《青少年编程与数学》课程方案:3、课程形式

《青少年编程与数学》课程方案:3、课程形式 一、这门课程是一门学习课程,不是教学课程二、这门课程是一门独立的课程,不是多门课程三、这门课程有一条主要的线索是计算四、这门课程需要重视输出、强调可见性五、这门课程需要灵活运用&#xf…

C/C++函数指针、C#委托是什么?

函数指针 #include<stdio.h>//声明函数指针 typedef int(*Calc)(int a, int b); int Add(int a, int b) {return a b; } int Sub(int a, int b) {return a - b; }int main() {Calc funcPoint1 &Add;Calc funcPoint2 &Sub;int x 120;int y 140;int z 0;z …

Docker 部署 RocketMQ

0. 拉取镜像 docker pull apache/rocketmq:5.2.0 docker pull styletang/rocketmq-console-ng1. 创建容器共享网络 docker network create rocketmq2. 启动NameServer # 启动 NameServer docker run -d --name rmqnamesrv -p 9876:9876 --network rocketmq apache/rocketmq:…

【YashanDB知识库】PHP使用OCI接口使用数据库绑定参数功能异常

【问题分类】驱动使用 【关键字】OCI、驱动使用、PHP 【问题描述】 PHP使用OCI8连接yashan数据库&#xff0c;使用绑定参数获取数据时&#xff0c;出现报错 如果使用PDO_OCI接口连接数据库&#xff0c;未弹出异常&#xff0c;但是无法正确获取数据 【问题原因分析】 开启O…

实例方法与静态方法

实例方法&#xff08;非静态方法&#xff09; 定义&#xff1a;实例方法是与类的实例&#xff08;对象&#xff09;相关联的方法。它们可以访问类的实例变量&#xff08;非静态变量&#xff09;&#xff0c;也可以访问类的静态变量和方法。 访问&#xff1a;实例方法必须通过类…

wangEditor富文本编辑器的调用开发实录(v5版本、多个编辑器、php后端上传视频阿里云OSS、编辑HTML回显)

wangEditor富文本编辑器的调用开发实录(v5版本、获取HTML内容、上传图片、隐藏上传视频)wangEditor富文本编辑器的调用开发实录2(V5版本自定义粘贴&#xff0c;去除复制word或网页html冗余样式代码的解决方案) wangEditor富文本编辑器的调用开发实录 一、多个编辑器1.构建HTML容…

张艺兴step新专开启自由驾驶新纪元

张艺兴《Step》新专&#xff0c;开启自由驾驶新纪元&#xff01;当音乐与驾驶相遇&#xff0c;会碰撞出怎样的火花&#xff1f;当实力派艺人张艺兴遇上全新英文专辑《Step》&#xff0c;便为我们解锁了一种前所未有的出行体验&#xff01;这不仅仅是一张音乐专辑&#xff0c;更…

Pandas AI:最棒的大模型数据分析神器!

暑期实习基本结束了&#xff0c;校招即将开启。 不同以往的是&#xff0c;当前职场环境已不再是那个双向奔赴时代了。求职者在变多&#xff0c;HC 在变少&#xff0c;岗位要求还更高了。 最近&#xff0c;我们又陆续整理了很多大厂的面试题&#xff0c;帮助一些球友解惑答疑&…

MySQL中为什么要有隐式内连接和显式内连接

在MySQL多表联合查询中&#xff0c;区分隐式内连接&#xff08;Implicit Inner Join&#xff09;和显式内连接&#xff08;Explicit Inner Join&#xff09;的主要原因在于它们的语法风格、可读性、可维护性以及应用场景的差异。以下是对这两种连接方式的主要区别的详细分析&am…

Java Opencv识别图片上的虫子

最近有个需求&#xff0c;希望识别图片上的虫子&#xff0c;对于java来说&#xff0c;图像识别不是很好做。在网上也搜索了很多&#xff0c;很多的代码都是不完整&#xff0c;或者下载下载报错&#xff0c;有的写的很长看不懂。所以自己试着用java的opencv写了一段代码。发现识…

2024年计算机相关专业是否适合选择

2024年&#xff0c;计算机相关专业还值得选择吗&#xff1f; 随着2024年高考落幕&#xff0c;数百万高三学生又将面临人生中的重要抉择&#xff1a;选择大学专业。在这个关键节点&#xff0c;计算机相关专业是否仍是“万金油”的选择&#xff1f;在过去很长一段时间里&#xf…

Django+Vue.js怎么实现搜索功能

一.前言 类似这样的搜索功能 二.前端代码 <div class"form-container"><div class"form-group"><label for"departure-city">出发城市</label><select v-model"departureCity" id"departure-city&q…

把Vue项目从Window系统迁移到Mac系统的方案

不能启动vue ui 直接运行&#xff0c;会报错如下&#xff1a; failed to load config from /Users/xiaochen/IdeaProjects/ChatViewer-frontend/vite.config.tserror when starting dev server: Error: You installed esbuild for another platform than the one youre curre…

C++:STL容器-->set

使用set容器时需要导入头文件&#xff1a;#include <set> set和multiset区别&#xff1a; set不允许容器中有重复的元素 multiset允许容器中有重复的元素 1. 构造函数 set<T> st; set s(const &st); void printSet(set<int>& s) {for (set<int>…

程序性能优化——接口性能优化总结和思考

程序性能优化——接口性能优化总结和思考 一、背景介绍二、 思路方案三、过程四、总结五、升华 一、背景介绍 接口的优化 排查到的问题&#xff1a;循环中查询数据库&#xff0c;4300次查询数据库总共耗时在4分钟左右。 优化结果&#xff1a;4分钟到2秒 二、 思路方案 宏观的…

QT高阶-QSS样式表用法大全

文章目录 使用全局样式设置字体样式的作用域修改全局控件指示器的样式动态刷新控件的样式QSS样式的优先级调节控件的边框线QT6样式用法差异添加控件的背景图QSS注意事项Qt Style Sheet(QSS)是Qt的一种强大功能,类似于CSS用于网页设计。通过QSS,你可以定义Qt应用程序中的控件的…

RichSinkFunction 在 Flink IoT 项目中的应用实战

一、引言 随着物联网&#xff08;IoT&#xff09;技术的快速发展&#xff0c;实时数据处理和分析的需求日益增长。Apache Flink 作为一款高性能的流处理框架&#xff0c;广泛应用于 IoT 项目中。在 Flink 中&#xff0c;RichSinkFunction 是一种特殊的函数&#xff0c;它允许用…

嵌入式操作系统_5.存储管理

1.存储管理 存储管理是嵌入式操作系统的基本功能之一。其管理的对象是主存&#xff0c;也称内存。它的主要功能包括分配和回收主存空间、提高主存利用率、扩充主存、对主存信息实现有效保护。存储器管理的目的就是提供一个有价值的内存抽象&#xff0c;其目标包括&#xff1a;…

Integer溢出问题

0. 背景 在刷 LeetCode 时&#xff0c;代码的执行结果与预期出现了偏差&#xff0c;原因是 Int 值超过了允许范围 [ − 2 31 , 2 31 − 1 ] [-2^{31},2^{31}-1 ] [−231,231−1]。工作中从来没有遇到过这种情况&#xff0c;之前的认知是如果 Int 中存储的值超过了允许范围也许…

【FreeRTOS】ARM架构汇编实例

目录 ARM架构简明教程1. ARM架构电脑的组成1.2 RISC1.2 提出问题1.3 CPU内部寄存器1.4 汇编指令 2. C函数的反汇编 学习视频 【FreeRTOS入门与工程实践 --由浅入深带你学习FreeRTOS&#xff08;FreeRTOS教程 基于STM32&#xff0c;以实际项目为导向&#xff09;】 https://www.…