假设一个平面 Amazon S3 存储桶中有 200,000 个图像。
桶看起来像这样:
000000-1.jpg
000000-2.jpg
000000-3.jpg
000000-4.jpg
000001-1.jpg
000001-2.jpg
000002-1.jpg
...
ZZZZZZ-9.jpg
ZZZZZZ-10.jpg
(6 位哈希值,后跟计数,后跟扩展名)
如果我需要匹配 000001-*.jpg
的所有文件,最有效的方法是什么?
在 PHP 中我会使用 rglob($path,'{000001-*.jpg}',GLOB_BRACE)
获取一组匹配项,但我认为这不能远程工作。
我可以获取存储桶中所有文件的列表,然后在数组中查找匹配项,但这似乎是一个昂贵的请求。
你有什么建议?
最佳答案
Amazon 提供了一种直接使用 S3 API 执行此操作的方法。
在调用列出 S3 对象时,您可以使用 prefix
选项,以仅返回以前缀开头的对象。例如,使用适用于 PHP 的 AWS 开发工具包:
// Instantiate the class
$s3 = new AmazonS3();
$response = $s3->list_objects('my-bucket', array(
'prefix' => '000001-'
));
// Success?
var_dump($response->isOK());
var_dump(count($response->body->Contents))
您可能还会发现 delimiter
选项很有用 - 您可以使用它来获取所有唯一的 6 位哈希值的列表。
关于php - 如何有效获取匹配的 Amazon S3 文件列表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10606034/