国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

珍貴的線程資源,JDK VS Tomcat

開發 前端
線程池維護多個線程,等待監督管理者分配可并發執行的任務。這種做法,一方面避免了處理任務時創建銷毀線程開銷的代價,另一方面避免了線程數量膨脹導致的過分調度問題,保證了對內核的充分利用。

哈嘍,大家好,我是了不起。

高考結束了,依然祝高考學子們取得好成績,然后報考計算機專業,然后快點畢業,來接收哥哥姐姐們留下的代碼文明。。。。

接到某城舉報,某迪泄露高考題目。

圖片

最近生產環境各種問題,幾百臺設備停擺,真的是亞歷山大。接手了別人的代碼,只能硬著頭皮改了,一不留神就恰班到10點多了。

今天還是說一下線程池的兩個思考。

池子

我們常用的線程池,

1. JDK的ThreadPoolExecutor.

2. CompletableFutures 默認使用了ForkJoinPool.commonPool()。

CompletableFuture.supplyAsync(()->{ return "hello word";});

3. 還有Tomcat中的線程池

org.apache.tomcat.util.threads.TaskQueue  

org.apache.tomcat.util.threads.ThreadPoolExecutor

線程池維護多個線程,等待監督管理者分配可并發執行的任務。這種做法,一方面避免了處理任務時創建銷毀線程開銷的代價,另一方面避免了線程數量膨脹導致的過分調度問題,保證了對內核的充分利用。

JDK 線程池

public ThreadPoolExecutor(
    int corePoolSize, //核心線程數
    int maximumPoolSize,//最大線程數
    long keepAliveTime, //大于核心線程數量的線程存活時間,如果沒有新任務就會關閉
    TimeUnit unit, // 時間單位
    BlockingQueue<Runnable> workQueue, //線程等待隊列
    ThreadFactory threadFactory,//創建線程的工廠
    RejectedExecutionHandler handler//拒絕策略
) {

JDK線程池執行任務:

  1. 提交任務給線程池后,線程池會檢查線程池中正在運行的線程數量,如果線程數量小于核心線程,則創建一個新的線程來處理任務。
  2. 如果線程池中線程數量達到和corePoolSize的大小,則將線程放入等待隊列BlockingQueue中。
  3. 如果提交任務時連等待隊列都已經滿了的話,線程池會繼續創建新的線程來處理任務,直到線程池數量達到maximumPoolSize。
  4. 如果線程數量達到了最大容量,則會執行拒絕策略。

這里需要注意直接使用LinkedBlockingQueue阻塞隊列作為線程池會存在一個問題,當workcount > corePool時優先進入隊列排隊, 當請求并發過多時會導致請求緩慢,隊列太長可能會出現內存溢出(先排隊再漲線程池)

Tomcat線程池

下面時Tomcat線程池的構造方法

public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue, ThreadFactory threadFactory, RejectedExecutionHandler handler) {
    this.ctl = new AtomicInteger(ctlOf(-536870912, 0));
    this.mainLock = new ReentrantLock();
    this.workers = new HashSet();
    this.termination = this.mainLock.newCondition();
    this.submittedCount = new AtomicInteger(0);
    this.lastContextStoppedTime = new AtomicLong(0L);
    this.lastTimeThreadKilledItself = new AtomicLong(0L);
    this.threadRenewalDelay = 1000L;
    if (corePoolSize >= 0 && maximumPoolSize > 0 && maximumPoolSize >= corePoolSize && keepAliveTime >= 0L) {
        if (workQueue != null && threadFactory != null && handler != null) {
            this.corePoolSize = corePoolSize;
            this.maximumPoolSize = maximumPoolSize;
            this.workQueue = workQueue;
            this.keepAliveTime = unit.toNanos(keepAliveTime);
            this.threadFactory = threadFactory;
            this.handler = handler;
            this.prestartAllCoreThreads();
        } else {
            throw new NullPointerException();
        }
    } else {
        throw new IllegalArgumentException();
    }
}

Tomcat主要針對web接口請求,不能因為LinkedBlockingQueue的排隊導致接口出現大量延遲和緩慢, 從而使用了tomcat的TaskQueue,TaskQueue繼承了JDK的LinkedBlockingQueue 并擴展了JDK線程池的功能。

主要有一下幾點優化:

  • Tomcat的ThreadPoolExecutor使用的TaskQueue,是無界的LinkedBlockingQueue,但是通過taskQueue的offer方法覆蓋了LinkedBlockingQueue的offer方法,修改了線程池增長規則,使得線程池能在任務較多的情況下增長線程池數量。(先漲線程池再排隊。)
  • Tomcat的ThreadPoolExecutor改寫了execute方法,當任務被reject時,捕獲異常,會強制入隊
public void execute(Runnable command, long timeout, TimeUnit unit) {
    this.submittedCount.incrementAndGet();

    try {
        this.executeInternal(command);
    } catch (RejectedExecutionException var9) {
        if (!(this.getQueue() instanceof TaskQueue)) {
            this.submittedCount.decrementAndGet();
            throw var9;
        }

        TaskQueue queue = (TaskQueue)this.getQueue();

        try {
            if (!queue.force(command, timeout, unit)) {
                this.submittedCount.decrementAndGet();
                throw new RejectedExecutionException(sm.getString("threadPoolExecutor.queueFull"));
            }
        } catch (InterruptedException var8) {
            this.submittedCount.decrementAndGet();
            throw new RejectedExecutionException(var8);
        }
    }

}

那個線程池適合

我們看看AI如何回復

圖片

了不起認為大多數情況下使用JDK的線程池就夠用了,如果覺得線程數據處理不過來,需要多一點線程直接增加核心線程數量設置就可以了。針對資源比較緊張,對線程使用代價比較高時可以考慮。

tomcat對線程池做過優化,也必然是有一定的考量,對于線程資源的使用頻率比較高的情況下可以使用。

了不起之前也有對應的不同的例子來說明不同點。這里再放出來讓大家體會一下!

JDK線程池,線程資源較珍貴

  • 有一家工廠建立,開始的時候只有10個工人,然后工廠的活越來越多,招聘新的工人肯定不是最好的策略,所以多出來的活暫時只能等著,進行排隊。(這個例子中工廠的活多了,立馬去招人肯定是不可能,只能先排單)
  • 后面工廠的業務越來越多,任務擠壓過多,原來的工人干活已經不能滿足業務需求了。為了最大化效益,招聘新的工人勢在必行,于是就招聘了新的工人,所有的工人一起來干活,加快效率。
  • 當工廠的工人數量達到飽和之后,仍然不停的新增業務,此時工廠已經飽和,沒有辦法再繼續接單。那么只能采取別的方案(拒絕策略),找別的工廠干,或者新建工廠。
  • 當后面業務量比較小的時候,新招的工人就會慢慢的裁剪(線程一段時間不使用就會關掉!)。

Tomcat線程池,線程資源使用比較頻繁

  • 某學校有一個食堂,大廳里面日常至少擺100把椅子(min-spare)供學生們吃飯。
  • 然而當同時吃飯的同學大于100人的時候,食堂會增加一些椅子(創建線程),并且這些椅子也不會立馬收回去,一段時間沒有人使用才會收回。
  • 但是食堂里面最多可以擺500把椅子(maxThreads)。然后超過500人吃飯同時吃飯的話,其他人就只能在大廳里面排隊等別人吃完。食堂大廳里面可以容納1000人進行排隊等候(maxConnections)。
  • 當食堂大廳1000人都排滿了,那么就只能到食堂外面排隊了,外面排隊最多一直能排200人(acceptCount)。這個時候如果再有人過來要吃飯,而且還排不上隊,就會等到不耐煩(time out),也會有人來告訴后來的同學,別來了人都滿了,上其他地方吃飯去吧。(reject)
責任編輯:武曉燕 來源: Java技術指北
相關推薦

2021-08-20 08:22:12

Tomcat原生線程池

2010-11-10 08:57:51

Opera互聯網瀏覽器

2009-07-09 14:02:58

Tomcat JDK

2009-11-24 09:26:49

LinuxJDKTomcat

2010-04-01 09:12:46

CentOS系統

2013-08-23 13:50:44

創業創業文化

2009-07-09 13:15:20

JDK1.6.0 To

2009-07-16 16:47:22

jdk的配置Tomcat的配置eclipse與MyE

2010-01-21 11:25:44

linux多線程線程資源

2020-05-20 11:17:29

緩存服務器地址

2019-09-19 14:55:01

物理CPU線程邏輯CPU

2009-07-07 15:41:56

myeclipse配置Tomcat安裝tomcat插件

2009-07-07 15:45:17

JSP環境搭建

2009-06-03 16:33:53

安裝jdk tomcaeclipse配置

2023-02-07 20:17:21

JDK19虛擬線程

2023-11-01 07:24:16

JDK19線程

2009-07-03 11:36:47

JSP教程

2009-07-10 16:31:01

Ubuntu下安裝JD安裝Tomcat

2023-09-09 13:12:14

DARPA自動駕駛汽車

2018-04-27 10:35:08

Tomcat連接數線程池
點贊
收藏

51CTO技術棧公眾號

大陆成人av片| 亚洲精品福利视频网站| 国产精品欧美激情| 99热播精品免费| 欧美性生交大片免费| 免费人成短视频在线观看网站| gogogo免费视频观看亚洲一| 中文网丁香综合网| 麻豆国产精品一区二区三区| 蜜桃狠狠色伊人亚洲综合网站| 欧美高清视频手机在在线| 日本高清+成人网在线观看| 亚洲专区**| 欧美精品生活片| 看亚洲a级一级毛片| 免费99精品国产自在在线| 欧美午夜三级| 欧美丰满片xxx777| 国产成人澳门| 国产精品电影久久久久电影网| 九九视频精品全部免费播放| 热久久这里只有精品| 久草在线成人| 成人av在线网址| 亚洲高清自拍| 亚洲.欧美.日本.国产综合在线 | 97av视频在线观看| 久久免费看少妇高潮| 国产裸体舞一区二区三区| 国产欧美精品区一区二区三区| 免费看国产曰批40分钟| 欧美激情一区二区三区不卡| 1069男同网址| 色综合久久九月婷婷色综合| 幼a在线观看| 亚洲国产99精品国自产| 九色成人搞黄网站| 久久久久久香蕉网| 国产探花一区二区| 黄色小网站91| 顶级嫩模精品视频在线看| 黄大色黄女片18第一次| 欧美日韩美女视频| aaa在线播放视频| 欧美国产极速在线| 亚洲深深色噜噜狠狠爱网站| 亚洲精品在线视频观看| 久久久久一区二区三区四区| 中文字幕高清在线观看| 日韩免费在线观看| 95精品视频| 999视频在线免费观看| 国产一区二区三区高清播放| av免费高清观看| 日韩一级成人av| 久久精品一级| 国产精品自拍首页| 成人精品视频一区二区三区尤物| 99热在线网站| 日韩精品在线免费| 少妇精品久久久一区二区三区| 欧美日韩国产综合在线| 中文字幕乱码亚洲精品一区| 四虎久久免费| 欧美激情免费视频| 国产日韩欧美三区| 99精品视频播放| 欧美私模裸体表演在线观看| 婷婷激情成人| 久久99九九| 亚洲欧美在线另类| 啊啊啊久久久| 国产日韩欧美在线观看| 国产成a人无v码亚洲福利| 亚洲成人福利| 欧美zozozo| 第一会所sis001亚洲| 色一情一乱一乱一区91| 欧美日韩一区二区免费视频| 成人黄色免费观看| 久久久久综合一区二区三区| 亚洲视频免费看| 成人午夜在线| 日本午夜精品一区二区三区| 亚洲综合激情小说| 免费一级欧美在线观看视频| 精品中文字幕一区| 亚洲午夜一二三区视频| 伊人久久大香| 午夜精品电影在线观看| 欧美丝袜美女中出在线| 91麻豆精品国产91久久久久推荐资源 | 日韩av一区二| 中文在线а天堂av| 色综合老司机第九色激情| 久久久久国产一区二区| 美女被人操视频在线观看| 欧美成人免费全部观看天天性色| 国产精品外国| 久久电影视频| 国产成人久久久| 国产欧美一区在线| 日韩经典一区| 综合一区中文字幕| 日韩一区二区麻豆国产| 欧美视频久久| h精品动漫在线观看| 9.1国产丝袜在线观看| 91影院在线观看| 3d欧美精品动漫xxxx无尽| 亚洲mv在线看| 日韩欧美一级在线播放| 在线观看的日韩av| 性感av在线播放| 国产精自产拍久久久久久| 欧美激情一二三区| 色悠久久久久综合先锋影音下载| 麻豆映画在线观看| 日韩av在线导航| 男人的天堂亚洲一区| 羞羞的网站在线观看| 精品欧美一区二区在线观看视频| 黄网动漫久久久| 国产一区二区亚洲| 毛片中文在线观看| 国产精品99导航| 亚洲欧美激情在线| 一区二区三区日本久久久| 成年人免费网站| 国产99在线|中文| 亚洲欧美另类小说视频| 美女少妇全过程你懂的久久| www.99av| 国产成人免费av| 精品久久久久久久久国产字幕 | 欧美区二区三区| 久久老女人爱爱| 北条麻妃一区二区三区在线观看 | 成人免费视频播放| 欧美黄色网络| 三级在线视频观看| 国产91网红主播在线观看| 亚洲成人av免费| 欧美~级网站不卡| 免费网站成人| 日本精品免费视频| 美女精品久久久| 夜夜精品视频一区二区| 亚洲老妇激情| 欧洲一区二区三区| 丁香六月激情婷婷| 欧美激情视频网站| 亚洲国产精品人人做人人爽| 在线成人www免费观看视频| 香蕉久久aⅴ一区二区三区| 日本a在线天堂| 97在线视频一区| 一本色道久久加勒比精品| 日本最新不卡在线| 成人精品视频在线观看| 日本激情免费| 国产偷国产偷亚洲高清97cao| 亚洲第一中文字幕在线观看| av综合在线播放| 亚洲精品国产setv| 国产午夜精品一区理论片| 一区二区三区在线观看www| 伦理中文字幕亚洲| 欧美性极品xxxx做受| 国产中文字幕一区| 久久97精品| 日本黄色片在线观看| 91视频 - 88av| 国产精品一区久久| 亚洲剧情一区二区| 亚洲精选视频免费看| 视频一区视频二区在线观看| 免费观看亚洲视频大全| 国产精品免费观看| 久久久999视频| 国产精品一二区| 亚洲天堂免费在线| 午夜视频在线观看一区二区| 国内精品伊人久久久久av一坑 | 美国毛片一区二区| 农村少妇一区二区三区四区五区 | 久久99精品久久久久久噜噜| 国产一区二区三区免费视频| 国产精品一区二区三区在线播放| 91九色对白| 91中文精品字幕在线视频| 色婷婷久久久久swag精品 | 亚洲第一福利一区| 国产精品欧美一区喷水| 欧美性aaa| 久久久人成影片一区二区三区观看| 91成人免费视频| 中文字幕久久一区| 黄色毛片av| 91在线视频|