今天突然收到报警短信,说是/磁盘空间使用超过阀值。经查看,发现是有很多异常的SQL,执行不了,导致一直在处理,产生了临时占用了/tmp磁盘空间。
由于操作系统的/tmp空间有限,需要进行参数修改,将tmpdir的值路径进行修改。
mysql> show variables like 'tmpdir';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| tmpdir | /tmp |
+---------------+-------+
1 row in set (0.00 sec)
mysql> set global tmpdir = '/Data/app/mysql5.6.25/mysqltmp';
ERROR 1238 (HY000): Variable 'tmpdir' is a read only variable
只能通过配置文件进行修改了。
重启mysql
mysql> show variables like 'tmpdir';
+---------------+--------------------------------+
| Variable_name | Value |
+---------------+--------------------------------+
| tmpdir | /mysql5.6/var/tmp |
+---------------+--------------------------------+
1 row in set (0.00 sec)
问一下:但是生产环境不能重启服务,这要怎么搞呢?