微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

linux – 处理大量临时小文件

我有一个Web服务器,可以保存缓存文件并保存7天.文件名是md5哈希值,即正好是32个十六进制字符长,并保存在如下所示的树结构中:
00/
  00/
    00000ae9355e59a3d8a314a5470753d8
    .
    .
00/
  01/

你明白了.

我的问题是删除文件需要很长时间.我每天都有一个cron工作

find cache/ -mtime +7 -type f -delete

这需要半天以上才能完成.我担心可伸缩性及其对服务器性能的影响.此外,缓存目录现在是我系统中的一个黑洞,偶尔捕获无辜的du或发现.

LRU缓存的标准解决方案是某种堆.有没有办法将其扩展到文件系统级别?
是否有其他方法以一种易于管理的方式实现这一点?

以下是我考虑的想法:

>创建7个顶级目录,每周一个目录,每天清空一个目录.这会将缓存文件的查找时间增加7倍,使文件被覆盖时非常复杂,而且我不确定它对删除间的作用.
>将文件保存为MysqL表中的blob,其中包含名称和日期的索引.这似乎很有希望,但在实践中它总是比FS慢得多.也许我做得不对.

有任何想法吗?

解决方法

存储文件时,请创建指向按日期而不是按名称组织的第二个目录结构的符号链接.

使用“名称”结构检索文件,使用“日期”结构删除它们.

原文地址:https://www.jb51.cc/linux/394694.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐