簡體   English   中英

WebClient在任務中計划時超時

[英]WebClient Timing out when Scheduled in Task

大家好,這是我第一次嘗試在4.0中使用任務庫,因此,如果您發現其他問題,除了我的問題不正確之外,請告訴我。

我的問題是,當我安排一堆在內部使用Web客戶端發出請求的任務時,前幾個任務可以順利通過,但是一段時間后,我的Web客戶端開始引發異常。 好像它創建了webclient一樣,然后加入Task並等待線程將其拾取,但是到那時達到超時時間才是我的假設。

這是代碼:

var TmsThread = Task.Factory.StartNew(()=> UpdateTmsNullPackages(),TaskCreationOptions.LongRunning);

在Windows應用程序的Form1_Load中運行。 這就是它所說的

public void UpdateTmsNullPackages()
    {
        Parallel.ForEach(TmsNullPackages, Package =>
        {
            try
            {
                Task<string> task = Task.Factory.StartNew(() => Package.GetPackageTmsId(), TaskCreationOptions.AttachedToParent);
                task.ContinueWith(t =>
                    {
                        if (!String.IsNullOrEmpty(t.Result))
                        {
                            Package.TMSID = t.Result;
                            NowTmsIdFoundPackages.Add(Package);
                        }
                    });
            }
            catch(Exception ex){}
        });
    }

依次運行

 public static string GetPackageTmsId(this TwcPackage Package)
    {
        string TMSID = null;
        if (!(String.IsNullOrEmpty(Package.movie_Provider)) && !(String.IsNullOrEmpty(Package.movie_Product)) && !(String.IsNullOrEmpty(Package.movie_Provider_ID)) && !(String.IsNullOrEmpty(Package.movie_Asset_ID)))
        {
            try
            {
                using (WebClient client = new WebClient())
                {
                    client.Credentials = new NetworkCredential(TMSID_Recheck.Properties.Settings.Default.WebRequestUser, TMSID_Recheck.Properties.Settings.Default.WebRequestProdUserPassWord);
                    XmlDocument xmlDoc = new XmlDocument();
                    string URLToBeRequested = TMSID_Recheck.Properties.Settings.Default.RequestProdBaseURL + TMSID_Recheck.Properties.Settings.Default.RequestAPIVersion + "/" + TMSID_Recheck.Properties.Settings.Default.RequestAPIProgramServiceCall + TMSID_Recheck.Properties.Settings.Default.RequestAPIProgramAssociationServiceCall + Package.movie_Provider + ':' + Package.movie_Product + ':' + Package.movie_Provider_ID + "::" + Package.movie_Asset_ID;
                    try
                    {
                        xmlDoc.LoadXml(client.DownloadString(URLToBeRequested));
                        XmlNodeList Program = xmlDoc.DocumentElement.SelectNodes("program");
                        if (Program.Count > 0) TMSID = Program[0].Attributes["TMSId"].Value.ToString();
                    }
                    catch (WebException ex)
                    {
                        if (ex.Status != WebExceptionStatus.Timeout)
                        {
                            if (((HttpWebResponse)ex.Response).StatusCode != HttpStatusCode.NotFound) {  }
                        }
                        else {  }
                    }
                }
            }
            catch (Exception ix) {  }
        }
        return TMSID;
    }

在數百個任務后調用downloadstring時,會引發超時異常,從而發生問題。

在執行數百個任務后調用downloadstring時會發生此問題

在那段時間內完成了多少任務?

看來您只是在排隊太多請求。 您的系統和遠程服務器可能已經制定了限制並發連接數的策略。

解決方案(和快速診斷測試)是在ForEach中使用MaxDegreeOfParallelism。

這是一個類似的問題,有一些好的答案。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM