最近做接口对接,因需求变化需要用到异步推送信息,就利用委托做了异步。

程序运行过程中时不时出现“正在终止线程”的错误信息,导致两边订单信息不一致,代码如下:

       byte[] byteData = Encoding.UTF8.GetBytes(parameters);
HttpWebResponse response=null;
Stream myResponseStream = null;
Stream myRequestStream = null;try
{
var request=(HttpWebRequest) WebRequest.Create(Url);
request.Proxy = null;//不使用代理
request.Method = "POST";
request.ContentType = "application/x-www-form-urlencoded";
request.ContentLength = byteData.Length; using (myRequestStream = request.GetRequestStream())
{
myRequestStream.Write(byteData, , byteData.Length);
} response = (HttpWebResponse) request.GetResponse();
myResponseStream = response.GetResponseStream();
//将响应流转成xml对象
XmlDocument doc = new XmlDocument();
if (myResponseStream != null)
doc.Load(myResponseStream);
//返回xml对象
return doc;
}
catch (Exception ex)
{
LogHelper.CreateLog("post信息时出错!信息:" + ex.Message, orderid, httpContext);
return null;
}
finally
{
if (myResponseStream != null)
{
myResponseStream.Close();
myResponseStream.Dispose();
}
if (response != null)
{
response.Close();
response.Dispose();
}
if (myRequestStream != null)
{
myRequestStream.Close();
myRequestStream.Dispose();
}
}

网上寻找解决方案,基本上都是Response.Redirect导致的错误。我的代码上面并没有这些玩意儿。。。

实在是无法组织语言了,归根到底的原因就是C#中使用多线程使用HttpWebRequest时,默认的连接数只有2。

然后有时候因为对方服务器的原因导致访问超时,如果没有做超时处理的话,request对象就不会被释放,后面便导致一系列的问题。

解决方法之一就是在调用HttpWebRequest对象之前将连接数改大。

System.Net.ServicePointManager.DefaultConnectionLimit = 24

解决后代码:

            byte[] byteData = Encoding.UTF8.GetBytes(parameters);
HttpWebResponse response=null;
Stream myResponseStream = null;
Stream myRequestStream = null;
System.Net.ServicePointManager.DefaultConnectionLimit = ;
try
{
var request=(HttpWebRequest) WebRequest.Create(Url);
request.Proxy = null;//不使用代理
request.KeepAlive = false;//不建立持久性连接
request.Method = "POST";
request.ContentType = "application/x-www-form-urlencoded";
request.ContentLength = byteData.Length; using (myRequestStream = request.GetRequestStream())
{
myRequestStream.Write(byteData, , byteData.Length);
} response = (HttpWebResponse) request.GetResponse();
myResponseStream = response.GetResponseStream();
//将响应流转成xml对象
XmlDocument doc = new XmlDocument();
if (myResponseStream != null)
doc.Load(myResponseStream);
//返回xml对象
return doc;
}
catch (Exception ex)
{
LogHelper.CreateLog("post信息时出错!信息:" + ex.Message, orderid, httpContext);
return null;
}
finally
{
if (myResponseStream != null)
{
myResponseStream.Close();
myResponseStream.Dispose();
}
if (response != null)
{
response.Close();
response.Dispose();
}
if (myRequestStream != null)
{
myRequestStream.Close();
myRequestStream.Dispose();
}
}

这个个数,有相关说法是CPU的数量*2,具体有待考证,不过已经解决了我的问题。

其他解决方式参考连接:

http://www.cnblogs.com/eaglet/archive/2012/05/18/2507179.html

http://www.cnblogs.com/1971ruru/archive/2012/04/11/2442589.html

http://blog.sina.com.cn/s/blog_3eea4f680100s48d.html

C# 在异步中使用HttpWebRequest出现的“正在终止线程”错误的解决方案的更多相关文章

  1. iOS中CollectionView由于多次点击造成错误的解决方案

    iOS中CollectionCiew由于多次点击,会给程序造成错误. 这个时候,我们可以用过手势类来进行判断和过滤. 但是,有一个快捷的解决方法,那就是给用户响应增加延时操作. 具体代码如下: [co ...

  2. asp.net中调用COM组件发布IIS时常见错误 80070005解决方案

    很多人在.net开发Web站点中引用了COM组件,调试时一切正常,但一发布到IIS下就提示如下错误: 检索 COM 类工厂中 CLSID 为 {} 的组件时失败,原因是出现以下错误: 80070005 ...

  3. 关于js语法(运算中出现无限大的问题)本身的错误的解决方案

    错误原因: 一是 JavaScript 浮点数计算的 Bug, 另一个是和计算机最终转换成二进制计算有关系 解决方案: 第一种就是利用JavaScript 的toFixed(n) 方法,直接获取N 位 ...

  4. ASP.NET sync over async(异步中同步,什么鬼?)

    async/await 是我们在 ASP.NET 应用程序中,写异步代码最常用的两个关键字,使用它俩,我们不需要考虑太多背后的东西,比如异步的原理等等,如果你的 ASP.NET 应用程序是异步到底的, ...

  5. VB.NET中网络编程的另一种方案----system.net中的HttpWebRequest类的使用

    VB.NET中网络编程的另一种方案---- system.net中的HttpWebRequest类的使用 在VB.net中进行网络编程,除了我之前写的随笔中的使用WinHttp组件进行编程,还有另一种 ...

  6. C#中使用 HttpWebRequest 向网站提交数据

    HttpWebRequest 是 .NET 基类库中的一个类,在命名空间 System.Net 里,用来使用户通过 HTTP 协议和服务器交互. HttpWebRequest 对 HTTP 协议进行了 ...

  7. 翻译 异步I/O不会创建新的线程

    异步I/O不会创建新的线程 本文翻译自 Stephen Cleary 的 [There is No Thread] 原文地址 https://blog.stephencleary.com/2013/1 ...

  8. Kafka producer异步发送在某些情况会阻塞主线程,使用时候慎重

    最近发现一个Kafka producer异步发送在某些情况会阻塞主线程,后来在排查解决问题过程中发现这可以算是Kafka的一个说明不恰当的地方. 问题说明 在很多场景下我们会使用异步方式来发送Kafk ...

  9. nodejs中使用worker_threads来创建新的线程

    目录 简介 worker_threads isMainThread MessageChannel parentPort和MessagePort markAsUntransferable SHARE_E ...

随机推荐

  1. [ZigBee] 11、ZigBee之睡眠定时器二

    1.前言 上一节讲了Zigbee的睡眠定时器利用外部按键使系统从休眠态唤醒到工作态,其核心在于: 61 void SysPowerMode(uchar mode) 62 { 63 if(mode &g ...

  2. .NET在线培训 | C#在线培训 | .NET培训 | 最课程培训

    最课程(www.zuikc.com) 软件开发培训,在线软件培训的创新者!我们的创新在于: 1:一次购买,终身服务.每个最课程学员都会分配一位专职教师及一位监管教师,点对点跟进课程进度,直到您学会课程 ...

  3. bitmap算法

    概述 所谓bitmap就是用一个bit位来标记某个元素对应的value,而key即是这个元素.由于采用bit为单位来存储数据,因此在可以大大的节省存储空间 算法思想 32位机器上,一个整形,比如int ...

  4. 虚拟化平台cloudstack(8)——从UI开始

    UI ucloudstack采用的是前后端分离的架构,就是说前端可以选择使用web.swing甚至其它的界面,都可以. 我们来看cloudstack的UI信息吧,所有的cloudstack的UI都在{ ...

  5. redis源码系列-数据结构(adlist/ziplist/dict)

    该系列基于redis-2.8.18,主要记录自己的理解或者想法.redis以自己支持存储的数据结构丰富吸引了大批人,把memcached比了下去.本文就从简单基本的数据结构入手. 双向链表-adlis ...

  6. sql的OUTER APPLY

    今天写一个查询sql,其中涉及到一个银行卡绑定表(表名:BankBind),我要将这个表的开户行字段的值进行分割出省份.支行, 这个开户行字段存储的值如“广东省广东省分行江门市分行恩平市支行”.“招商 ...

  7. JQuery向导插件Step——第一个阉割版插件

    如果使用过JQuery Steps的朋友一定会发现这个插件有一个缺点,就是页面在第一次进入的时候,会进行一次很明显的DOM重绘--页面会闪一下. 尤其是前端代码比较庞大的时候,效果更为明显. 为了解决 ...

  8. Thinking in java中关于Exception的一道面试题.

    今天看到Thinking in Java中一个关于Exception的例子:最后看到有一篇总结的比较好的文章, 这里拿来记录下, 文章地址是:http://blog.csdn.net/salerzha ...

  9. Atitit Gaussian Blur 高斯模糊 的原理and实现and 用途

    Atitit Gaussian Blur 高斯模糊 的原理and实现and 用途 1.1. 高斯模糊 的原理(周边像素的平均值+正态分布的权重1 1.2. 高斯模糊 的用途(磨皮,毛玻璃效果,背景虚化 ...

  10. Atitit mtp ptp rndis midi协议的不同区别

    Atitit mtp ptp rndis midi协议的不同区别 1. PTP:1 2. MTP:1 3. Mtp 与usb区别2 4. 不过和UMS相比,MTP也有不足之处:3 5.  MTP协议介 ...