我正在开发一个 azure 应用程序,它需要在某个时候上传(下载)大量小 blob 到单个容器(超过 1k blob,每个小于 1 Mb)。为了加快这个过程,我想使用多个线程来上传(下载)blob。
这是我用于上传单个 blob 的例程:
CloudStorageAccount storageAccount = CloudStorageAccount.Parse(ConnectionString);
CloudBlobClient blobClient = storageAccount.CreateCloudBlobClient();
CloudBlobContainer blobContainer =
blobClient.GetContainerReference(ContainerName);
blobContainer.CreateIfNotExist();
CloudBlob blob = blobContainer.GetBlobReference(Id);
blob.UploadByteArray(Data);
对于上面代码中使用的每种类型,MSDN 的说明如下:
此类型的任何公共静态(在 Visual Basic 中为共享)成员都是
线程安全。不保证任何实例成员都是线程
安全的。
这是否意味着我需要在每个线程中执行以下代码?或者也许我只能执行一次并在不同线程之间共享 CloudBlobContainer 的单个实例?
CloudStorageAccount storageAccount = CloudStorageAccount.Parse(ConnectionString);
CloudBlobClient blobClient = storageAccount.CreateCloudBlobClient();
CloudBlobContainer blobContainer =
blobClient.GetContainerReference(ContainerName);
我真的很高兴在不同的线程中使用 CloudBlobContainer 的单个实例,否则它会严重减慢整个上传(下载)过程。
只要您不尝试对容器本身执行更新,您应该可以共享单个 blob 容器引用(即使如此,我认为在大多数情况下(例如 List)仍然可以)。事实上,如果您确定容器引用存在,您甚至不需要它:
client.GetContainerReference("foo").GetBlobReference("bar");
client.GetBlobReference("foo/bar"); //same
正如您所看到的,获取容器引用的唯一原因是您想对容器本身执行操作(列表、删除等)。如果将 blob 引用保留在单独的线程中,那就没问题了。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)