0

我有一个 try/catch 方法,如下所示。当互联网连接断开时,try 中的代码阻塞,不进入 catch,应用程序停止响应。当互联网连接恢复时,问题就消失了,一切正常。

这是我的代码的一部分:

using (var fileStream = System.IO.File.OpenRead(strLocatie))
{
    try
    {
        blobSAS.UploadFromStream(fileStream);
    }
    catch
    {
    }
}

我可以设置一个超时,以便当 try 块花费超过 1000 毫秒时,代码会自动进入 catch 吗?

整体方法:

public void uploadImages(string strLocatie, string naamBestand, string directoryname)
{
    try
    {
        string dag = DateTime.Now.Day.ToString();
        if (dag.Length == 1)
        {
            string temp = dag;
            dag = "0" + temp;
        }
        string maand = DateTime.Now.Month.ToString();
        if (maand.Length == 1)
        {
            string temp = maand;
            maand = "0" + temp;
        }
        if (signature == null)
        {
            getKey();
        }
        string datum = dag + "-" + maand + "-" + DateTime.Now.Year.ToString();
        CloudBlobClient blobClient = new CloudBlobClient(sUrl, new StorageCredentialsSharedAccessSignature(signature));
        CloudBlobContainer blobContainer = blobClient.GetContainerReference(container1);
        blobContainer.GetDirectoryReference(sUrl + container1);
        CloudBlockBlob blobSAS = new CloudBlockBlob(sUrl + container1 + "/" + directoryname + "/" + datum + "/" + naamBestand,
                        new StorageCredentialsSharedAccessSignature(signature));
        using (var fileStream = System.IO.File.OpenRead(strLocatie))
        {
            try
            {
                blobSAS.UploadFromStream(fileStream);
            }
            catch
            {
            }
        }
        File.Delete(strLocatie);
    }
    catch
    {
    }

}

如果互联网连接已经断开,在启动应用程序之前,catch 工作完美......

4

4 回答 4

2

您可以在 blobClient 上设置超时

 var storageAccount = CloudStorageAccount.Parse("DefaultEndpointsProtocol=https;AccountName=<YOURACCOUNTNAME>;AccountKey=<YOURACCOUNTKEY>");
_blobClient = storageAccount.CreateCloudBlobClient();
_blobClient.Timeout = new System.TimeSpan(1,0,0);

然后,您还可以设置似乎将副本分布在多个线程中的并行设置。如果你有大带宽,你可以增加下面的线程数,因为 Azure 接受以任何到达顺序分解成块的 blob。

_blobClient.ParallelOperationThreadCount = 2;
于 2013-02-05T11:25:13.607 回答
1

您可以在与 关联的上为请求指定超时。默认值为 90 秒。CloudBlobClientCloudBlockBlob

CloudBlockBlob 提供了ServiceClient访问 CloudBlobClient 实例的属性

但我不确定这是否能解决您的问题。

您也可以尝试使用BackgroundWorker将您的流上传到云端,以便您的应用程序负责并在后台上传数据。

CloudBlockBlob 类也提供方法BeginUploadFromStreamEndUploadFromStream来异步上传数据。

于 2013-02-05T11:25:28.190 回答
1

您必须设置 CloudBlockBlob 的 blobrequestoptions。在这里您可以设置超时。但是,最好在后台工作人员中上传文件。这样,您的应用程序始终是响应式的。

blobrequestoptions

于 2013-02-05T11:25:39.763 回答
1

从重载调用到 s中有一个timeout 属性BlobRequestOptionUploadFromStream

是否可以指定超时,例如:

BlobRequestOptions blobRequestOptions = new BlobRequestOptions();
blobRequestOptions.Timeout = TimeSpan.FromSeconds(20.0)
blobSAS.UploadFromStream(fileStream, blobRequestOptions);
于 2013-02-05T11:26:13.570 回答