问题:

        在众多对象云存储产品中,为了保证单次请求的效率,往往会做分批次调用来保障响应效率,因此在一次请求中无法实现获取全部文件信息。

例如:

 实际桶中拥有1200+文件

        由此可见,腾讯云对象存储服务单次list只返回1000个,若超过1000个文件,那么在获取数据时就会不准确。

解决方法: 

        腾讯云为我们开发者提供了getNextMarker()方法,通过这个方法返回的信息用于下次查询使用,可以理解为批次码,第一批次、第二批次......。当getNextMarker()返回为空时表示已经list到文件列表末尾处,由此可得到存储桶全部文件信息。

顺便附上获取全部文件的代码示例: 

	/**
	 * 删除存储桶
	 * @param cosClient
	 * @param bucketName
	 */
	public static void removeBucket(COSClient cosClient, String bucketName) {
    	//判断桶名是否包含appid
    	if (!bucketName.contains("-1314059671")) {
			//不包含则需要带上
    		bucketName = bucketName + "-1314059671";
		}
		//获取全部文件
		List<COSObjectSummary> objects = new ArrayList<COSObjectSummary>();
		ListObjectsRequest request = new ListObjectsRequest();
        request.setBucketName(bucketName);
		boolean b = true;
		while (b) {
			ObjectListing listObjects = cosClient.listObjects(request);
			List<COSObjectSummary> list = listObjects.getObjectSummaries();
			objects.addAll(list);
			if (!StringUtil.isEmpty(listObjects.getNextMarker())) {
				request.setMarker(listObjects.getNextMarker());
			}else {
				b = false;
			}
		}
		for (COSObjectSummary cos: objects) {
			cosClient.deleteObject(bucketName, cos.getKey());
		}
		cosClient.deleteBucket(bucketName);
	}

若是需要获取某个文件夹下的全部文件,可在request中增加request.setPrefix(folder);即可。

其他云存储产品大都支持getNextMarker()方法,可根据实际开发需求灵活运用。

温馨提示:minio支持一次性获取全部信息、华为云默认1000、阿里云默认100,皆可通过request.setMaxKeys(1000);调整单次获取上限 ,但都不能单次超过1000个。

Logo

DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。

更多推荐