PHP - 读取目录与从数据库中获取

标签 php database memory directory glob

我的主要原因是对不同的选择发表意见。我在与视频关联的目录中有文件/缩略图,当我必须获取它们时,我使用 glob() 函数 glob(DIRECTORY./file_name*.jpg);并返回视频的所有 JPG 文件的数组。

glob 函数本身非常快,但我仍然担心使用情况,因为在每个页面上可能有 20 到 50 个视频,所以会有 20 到 50 个 glob 调用,我应该继续使用它还是开始将数据放入数据库以获取从那里列出文件而不是 glob(); ?

如果有更好的选择,请告诉我。

谢谢。

最佳答案

与通常的性能问题一样,结果可能会有很大差异,所以答案是:速度越快,对的效果就越好。

开始的地方是测量你现在做的事情需要多少时间。完成此操作后,问问自己:速度够快吗?可能是这样,虽然它可能不是最快的做事方式,但它仍然很快,速度不是问题。

处理页面的时间中有多少是花在获取文件 glob 上的? 1%? 10%? 50%?这个百分比越高,就越值得考虑改变你做事的方式。

此外,网站的整体性能如何?如果您将每个页面的加载速度提高一倍,人们会注意到吗?如果不是,那么可能真的不值得进行性能调整,即使您看到了明显的调整位置。

如果您认为自己可以做得更好,请使用您的数据库实现该功能并衡量它是否更快。同样,这样做的结果可能变化很大。例如,如果您的 数据库负载很重,从数据库获取结果的速度可能会慢得多。如果你有一个几乎不被使用的强大的数据库,它可能会非常快。只有测试才能告诉您真相。

我要补充一点,您现在做事的方式看起来更简单且更易于维护,因为它会根据磁盘上的实际文件查找文件名。如果您尝试使用数据库,您将不得不担心将数据库中的文件名列表与文件系统中的文件列表同步。

但是,需要注意的一件事是,当您拥有一个包含大量文件的目录时,许多文件系统的性能会更差。如果遇到这种情况,请考虑将文件拆分到多个子目录中。一种流行的方法是创建名称为 a-z 的目录,然后将所有以“a”开头的文件放在“a”目录中,将所有以“b”开头的文件放在“b”目录中,等等。但是,这可能只是一旦您拥有数以万计的文件就很重要,即便如此,它也取决于特定的文件系统及其运行的硬件。

(根据评论编辑:)

由于您在谈论预先计算结果并将其存储在数据库中,我建议比将内容放入数据库更好的方法是使用像 http://memcached.org/这样的缓存服务器。您可以将其视为一种混合方法:您仍然按照现在的方式做事,但是每次您想要结果时,您首先检查缓存以查看它是否包含该结果;如果是,则使用缓存的结果,否则计算新的 glob。这避免了保持数据库和文件系统同步的问题,因为旧的缓存条目可能会过期并被正确的新条目替换。

关于PHP - 读取目录与从数据库中获取,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12216095/

相关文章:

Golang Alloc 和 HeapAlloc vs pprof 大的差异

java - 查找分配给进程的虚拟内存量

algorithm - 提出用于处理矩阵形式的巨型数据的数据结构(将其视为 excel 表)

php - SLIM 框架路由身份验证 v2 与 v3

php - $document_root 上的 nginx 和尾部斜杠?

mysql - Mysql如何将不同的表复制到不同的数据库?

sql - SQL Server 中的可延迟约束

php - 无法使用 codeigniter 的 upload() 函数上传图片

php - 插入行时,Codeigniter affected_rows 总是返回 0

mysql - 在sqlite中合并多个表