记一次tmp目录被写满导致服务器崩溃的产线事故

记一次tmp目录被写满导致服务器崩溃的产线事故,第1张

记一次tmp目录被写满导致服务器崩溃的产线事故

今天在产线报警群报出了我们某个服务失去响应的情况,打开跳板机登录发现果然登录不上了。

开始排查问题,这个问题已经不是第一次了,时间也很固定,每天9点多开始,初步定位是定时任务引起,看xxl-job面板,发现确实有两个定时任务是9点开始执行的。经过与运维沟通,确定是tmp目录(我们只有3.6G写满导致),开始检查代码,发现的确有很多指定了/tmp目录的代码,而且定时任务产生的文件非常大且多,最终导致服务器失去了响应。

在我们开发过程中,我们应该尽量少用tmp目录,在开发过程中我们指定其他位置。

当我们用

File file = File.createTempFile("1111", "txt");创建临时文件时,文件一般放在java.io.tmpdir指定的位置,如果量很大,就会导致tmp目录占满,最终导致服务器失去响应。

因为tmp目录比较小,我们可以改成其他位置,我们可以采用如下两种方式:

System.setProperty("java.io.tmpdir", "/opt/work");

或者:

java -Djava.io.tmpdir=/path/to/tmpdir 

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5574186.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-14
下一篇 2022-12-14

发表评论

登录后才能评论

评论列表(0条)

保存