ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

解决new Thread().Start导致高并发CPU 100%的问题

2022-01-20 20:04:25  阅读:132  来源: 互联网

标签:Thread 100% ThreadPool Start 线程 Debug new Logger


 

背景

之前接手一个项目的时候,发现到处是

new Thread(()=>{
//do something
}).Start();

  



这么做的目的,无非是为了减少页面等待时间提高用户体验,把一些浪费时间的操作放到新线程中在后台运行。

问题

但是这样带来的问题是大量的创建线程,非常影响项目的性能,尤其是在一些大并发量访问的时候,经常导致后果是cpu 100%。

当然,如果你的项目到处是这样写的,然后,没挂,至少说明这个方法没几个人再用。

解决方法

于是下意识的想着给项目优化下, 第一想法是走队列,但是发现项目压根没有使用队列,很多操作还停留在 有个任务表,有任务的时候,往里面加内容,然后有个定时任务,每分钟执行一次,定时的去消费任务;

于是想着怎么先最少的改动,先把问题解决,后面的事情在做考虑。

其实问题的本质是new 太多Thread了,那么最简单的方法就是限制数量。

于是 ThreadPool.QueueUserWorkItem就登场了。

对于线程队列 ThreadPool.QueueUserWorkItem 很多人应该都不陌生,下边看微软的解释:

将方法排入队列以便执行,并指定包含该方法所用数据的对象。此方法在有线程池线程变得可用时执行。

方法如下

 
  protected static Logger Logger = LogManager.GetCurrentClassLogger();
        public ActionResult Index()
        {
          //  Logger.Debug("执行了  开始 ");
            ThreadPool.QueueUserWorkItem(new WaitCallback(InsertNewsInfoExt), "param");
         //   Logger.Debug("执行了  结束 ");
            return View();
        }
        private void InsertNewsInfoExt(object info)
        {
         //   Logger.Debug("执行了  InsertNewsInfoExt  开始");
            Thread.Sleep(1000*200);
            Logger.Debug("执行了  InsertNewsInfoExt 结束 ");
            new Thread(t =>
            {
                try
                {
                    Logger.Debug("执行了  Thread ");
                 
                }
                catch (Exception ex)
                {
                    Logger.Error(ex.Message);
                }

            }).Start();

        }

 

 

根据msdn描述:线程池的默认大小为每个可用处理器有 25 个线程。使用 SetMaxThreads 方法可以更改线程池中的线程数

  //工作者线程最大数目,I/O线程的最大数目
            ThreadPool.SetMaxThreads(1000, 1000);   
            //启动工作者线程
           ThreadPool.QueueUserWorkItem(new WaitCallback(InsertNewsInfoExt), "param");

 

 

相关参数

GetAvailableThreads 剩余空闲线程数

GetMaxThreads 最多可用线程数,所有大于此数目的请求将保持排队状态,直到线程池线程变为可用

GetMinThreads 检索线程池在新请求预测中维护的空闲线程数。

QueueUserWorkItem 启动线程池里得一个线程(队列的方式,如线程池暂时没空闲线程,则进入队列排队)

SetMaxThreads 设置线程池中的最大线程数

SetMinThreads 设置线程池最少需要保留的线程数

这样就解决了无限制 new Thread 的问题,实现了最少改动。

 

 

 

 

UP技术控 江东子弟多才俊,卷土重来未可知。——唐·杜牧 481篇原创内容 公众号

 

标签:Thread,100%,ThreadPool,Start,线程,Debug,new,Logger
来源: https://www.cnblogs.com/lyl6796910/p/15827788.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有