一个docker容器中跑着java应用,是一个定时任务,每天拉取远端文件包存到本机,命名为:decrypt-20181020
就在这一天,任务失败,java提示异常: java.io.FileNotFoundException: /tmp/decrypt-20181020 Input/output error
Cause by: ... com.pollyduan.job.GetFileService:54
找到对应行的代码:
FileOutputStream out = new FileOutputStream(targetFile);
- 一般情况下,new 一个 OutputStream 是无论如何不应该报错的,毕竟还没有开始任何读取或写入操作。
很怪异,前一天和后一天都正常。
在 bash中进入tmp目录:
touch decrypt-20181020 touch: cannot touch `decrypt-20181020': Input/output error
- 其他文件名没问题
- 硬盘空间充足
查看设备故障诊断日志:
# dmesg ... [72458282.116220] EXT4-fs error (device dm-6): htree_dirblock_to_tree:914: inode #2097766: block 8397500: comm bash: bad entry in directory: rec_len is smaller than minimal - offset=0(335872), inode=0, rec_len=0, name_len=0
搜索到Stack Overflow,看到有说重启可解决。由于业务在跑着,没有尝试,回头试过再更新。
目前,修改临时文件名暂时解决。
继续阅读与本文标签相同的文章
上一篇 :
三句话捋清楚java垃圾收集器
下一篇 :
Maven 项目中依赖的搜索顺序
-
pyecharts的V1.5绘画优美地图<一>
2026-05-16栏目: 教程
-
UNREFERENCED_PARAMETER的作用
2026-05-16栏目: 教程
-
用python写一个简单的贪吃蛇游戏
2026-05-16栏目: 教程
-
程序员的软技能之项目管理
2026-05-16栏目: 教程
-
Spring Boot 项目的 API 接口防刷
2026-05-16栏目: 教程
