{ return "hello word" ;}); 還有Tomcat中的線程池 org.apache.tomcat.util.threads.TaskQueue org.apache.tomcat.util.threads.ThreadPoolExecutor 線程池維護(hù)多個(gè)線程,等待監(jiān)督管理者分配可并發(fā)執(zhí)行的任務(wù)。這種做法,一方面避免了處理任務(wù)時(shí)創(chuàng)建銷毀線程開(kāi)銷的代價(jià),另一方面避免了線程數(shù)量膨脹導(dǎo)致的過(guò)分調(diào)度問(wèn)題,保證了對(duì)" />

91在线观看视频-91在线观看视频-91在线观看免费视频-91在线观看免费-欧美第二页-欧美第1页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

線程池的兩個(gè)思考

科技綠洲 ? 來(lái)源:Java技術(shù)指北 ? 作者:Java技術(shù)指北 ? 2023-09-30 11:21 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

今天還是說(shuō)一下線程池的兩個(gè)思考。

池子

我們常用的線程池,

  1. JDK的ThreadPoolExecutor.
  2. CompletableFutures 默認(rèn)使用了ForkJoinPool.commonPool()。
CompletableFuture.supplyAsync(()- >{ return "hello word";});
  1. 還有Tomcat中的線程池

org.apache.tomcat.util.threads.TaskQueue

org.apache.tomcat.util.threads.ThreadPoolExecutor

線程池維護(hù)多個(gè)線程,等待監(jiān)督管理者分配可并發(fā)執(zhí)行的任務(wù)。這種做法,一方面避免了處理任務(wù)時(shí)創(chuàng)建銷毀線程開(kāi)銷的代價(jià),另一方面避免了線程數(shù)量膨脹導(dǎo)致的過(guò)分調(diào)度問(wèn)題,保證了對(duì)內(nèi)核的充分利用。

JDK 線程池

public ThreadPoolExecutor(
    int corePoolSize, //核心線程數(shù)
    int maximumPoolSize,//最大線程數(shù)
    long keepAliveTime, //大于核心線程數(shù)量的線程存活時(shí)間,如果沒(méi)有新任務(wù)就會(huì)關(guān)閉
    TimeUnit unit, // 時(shí)間單位
    BlockingQueue< Runnable > workQueue, //線程等待隊(duì)列
    ThreadFactory threadFactory,//創(chuàng)建線程的工廠
    RejectedExecutionHandler handler//拒絕策略
) {

JDK線程池執(zhí)行任務(wù):

  1. 提交任務(wù)給線程池后,線程池會(huì)檢查線程池中正在運(yùn)行的線程數(shù)量,如果線程數(shù)量小于核心線程,則創(chuàng)建一個(gè)新的線程來(lái)處理任務(wù)。
  2. 如果線程池中線程數(shù)量達(dá)到和corePoolSize的大小,則將線程放入等待隊(duì)列BlockingQueue中。
  3. 如果提交任務(wù)時(shí)連等待隊(duì)列都已經(jīng)滿了的話,線程池會(huì)繼續(xù)創(chuàng)建新的線程來(lái)處理任務(wù),直到線程池?cái)?shù)量達(dá)到maximumPoolSize。
  4. 如果線程數(shù)量達(dá)到了最大容量,則會(huì)執(zhí)行拒絕策略。

這里需要注意直接使用LinkedBlockingQueue阻塞隊(duì)列作為線程池會(huì)存在一個(gè)問(wèn)題,當(dāng)workcount > corePool時(shí)優(yōu)先進(jìn)入隊(duì)列排隊(duì), 當(dāng)請(qǐng)求并發(fā)過(guò)多時(shí)會(huì)導(dǎo)致請(qǐng)求緩慢,隊(duì)列太長(zhǎng)可能會(huì)出現(xiàn)內(nèi)存溢出(先排隊(duì)再漲線程池)

Tomcat線程池

下面時(shí)Tomcat線程池的構(gòu)造方法

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主要針對(duì)web接口請(qǐng)求,不能因?yàn)長(zhǎng)inkedBlockingQueue的排隊(duì)導(dǎo)致接口出現(xiàn)大量延遲和緩慢, 從而使用了tomcat的TaskQueue,TaskQueue繼承了JDK的LinkedBlockingQueue 并擴(kuò)展了JDK線程池的功能。

主要有一下幾點(diǎn)優(yōu)化:

  • Tomcat的ThreadPoolExecutor使用的TaskQueue,是無(wú)界的LinkedBlockingQueue,但是通過(guò)taskQueue的offer方法覆蓋了LinkedBlockingQueue的offer方法,修改了線程池增長(zhǎng)規(guī)則,使得線程池能在任務(wù)較多的情況下增長(zhǎng)線程池?cái)?shù)量。(先漲線程池再排隊(duì)。)
  • Tomcat的ThreadPoolExecutor改寫了execute方法,當(dāng)任務(wù)被reject時(shí),捕獲異常,會(huì)強(qiáng)制入隊(duì)
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);
        }
    }

}

那個(gè)線程池適合

我們看看AI如何回復(fù)

圖片

了不起認(rèn)為大多數(shù)情況下使用JDK的線程池就夠用了,如果覺(jué)得線程數(shù)據(jù)處理不過(guò)來(lái),需要多一點(diǎn)線程直接增加核心線程數(shù)量設(shè)置就可以了。針對(duì)資源比較緊張,對(duì)線程使用代價(jià)比較高時(shí)可以考慮。

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

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 內(nèi)核
    +關(guān)注

    關(guān)注

    3

    文章

    1416

    瀏覽量

    41445
  • 接口
    +關(guān)注

    關(guān)注

    33

    文章

    9005

    瀏覽量

    153774
  • 線程池
    +關(guān)注

    關(guān)注

    0

    文章

    57

    瀏覽量

    7138
  • JDK
    JDK
    +關(guān)注

    關(guān)注

    0

    文章

    83

    瀏覽量

    16893
  • tomcat
    +關(guān)注

    關(guān)注

    0

    文章

    31

    瀏覽量

    5014
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    Java中的線程包括哪些

    java.util.concurrent 包來(lái)實(shí)現(xiàn)的,最主要的就是 ThreadPoolExecutor 類。 Executor: 代表線程的接口,有一個(gè) execute() 方法,給一個(gè)
    的頭像 發(fā)表于 10-11 15:33 ?1053次閱讀
    Java中的<b class='flag-5'>線程</b><b class='flag-5'>池</b>包括哪些

    java自帶的線程方法

    二、原理分析 從上面使用線程的例子來(lái)看,最主要就是步,構(gòu)造ThreadPoolExecutor對(duì)象,然后每來(lái)一個(gè)任務(wù),就調(diào)用ThreadPoolExecutor對(duì)象的execute
    發(fā)表于 09-27 11:06 ?0次下載

    兩個(gè)線程和互斥鎖如何形成死循環(huán)?

    兩個(gè)線程兩個(gè)互斥鎖如何形成死鎖?程序流程圖如下: 程序流程圖 如上圖所示: t0時(shí)刻,主線程創(chuàng)建子線程,并初始化互斥鎖mutex1、mut
    的頭像 發(fā)表于 01-02 16:47 ?1657次閱讀
    <b class='flag-5'>兩個(gè)</b><b class='flag-5'>線程</b>和互斥鎖如何形成死循環(huán)?

    兩個(gè)線程兩個(gè)互斥鎖如何形成死鎖

    兩個(gè)線程兩個(gè)互斥鎖如何形成死鎖? 程序流程圖如下: 程序流程圖 如上圖所示: t0時(shí)刻,主線程創(chuàng)建子線程,并初始化互斥鎖mutex1、mu
    的頭像 發(fā)表于 12-28 09:24 ?2499次閱讀
    <b class='flag-5'>兩個(gè)</b><b class='flag-5'>線程</b>,<b class='flag-5'>兩個(gè)</b>互斥鎖如何形成死鎖

    如何正確關(guān)閉線程

    前言本章分為兩個(gè)議題 如何正確關(guān)閉線程 shutdown 和 shutdownNow 的區(qū)別 項(xiàng)目環(huán)境jdk 1.8 github 地址:https://github.com
    的頭像 發(fā)表于 09-29 14:41 ?1w次閱讀

    在Python中用于終止線程兩個(gè)選項(xiàng)

    ? 我經(jīng)常被問(wèn)到如何殺死一個(gè)后臺(tái)線程,這個(gè)問(wèn)題的答案讓很多人不開(kāi)心: 線程是殺不死的。在本文中,我將向您展示? Python ?中用于終止線程兩個(gè)
    的頭像 發(fā)表于 11-17 10:02 ?4953次閱讀

    python創(chuàng)建線程種方法

    在使用多線程處理任務(wù)時(shí)也不是線程越多越好,由于在切換線程的時(shí)候,需要切換上下文環(huán)境,依然會(huì)造成cpu的大量開(kāi)銷。為解決這個(gè)問(wèn)題,線程的概念
    的頭像 發(fā)表于 03-16 16:15 ?6225次閱讀

    線程線程

    線程通常用于服務(wù)器應(yīng)用程序。 每個(gè)傳入請(qǐng)求都將分配給線程池中的一個(gè)線程,因此可以異步處理請(qǐng)求,而不會(huì)占用主
    的頭像 發(fā)表于 02-28 09:53 ?1116次閱讀
    多<b class='flag-5'>線程</b>之<b class='flag-5'>線程</b><b class='flag-5'>池</b>

    如何用C++實(shí)現(xiàn)一個(gè)線程呢?

    C++線程是一種多線程管理模型,把線程分成任務(wù)執(zhí)行和線程調(diào)度部分。
    發(fā)表于 06-08 14:53 ?2069次閱讀
    如何用C++實(shí)現(xiàn)一<b class='flag-5'>個(gè)</b><b class='flag-5'>線程</b><b class='flag-5'>池</b>呢?

    細(xì)數(shù)線程的10個(gè)

    JDK開(kāi)發(fā)者提供了線程的實(shí)現(xiàn)類,我們基于Executors組件,就可以快速創(chuàng)建一個(gè)線程
    的頭像 發(fā)表于 06-16 10:11 ?970次閱讀
    細(xì)數(shù)<b class='flag-5'>線程</b><b class='flag-5'>池</b>的10<b class='flag-5'>個(gè)</b>坑

    Spring 的線程應(yīng)用

    我們?cè)谌粘i_(kāi)發(fā)中,經(jīng)常跟多線程打交道,Spring 為我們提供了一個(gè)線程方便我們開(kāi)發(fā),它就是 ThreadPoolTaskExecutor ,接下來(lái)我們就來(lái)聊聊 Spring 的
    的頭像 發(fā)表于 10-13 10:47 ?830次閱讀
    Spring 的<b class='flag-5'>線程</b><b class='flag-5'>池</b>應(yīng)用

    線程基本概念與原理

    、17、20等的新特性,簡(jiǎn)化了多線程編程的實(shí)現(xiàn)。 提高性能與資源利用率 線程主要解決兩個(gè)問(wèn)題:線程創(chuàng)建與銷毀的開(kāi)銷以及
    的頭像 發(fā)表于 11-10 10:24 ?977次閱讀

    線程的基本概念

    ? 呃呃,我這么問(wèn)就很奇怪,因?yàn)?b class='flag-5'>線程是什么我都沒(méi)說(shuō),怎么會(huì)知道為什么會(huì)有線程呢?所以我打算帶大家去思考
    的頭像 發(fā)表于 11-10 16:37 ?776次閱讀
    <b class='flag-5'>線程</b><b class='flag-5'>池</b>的基本概念

    線程的創(chuàng)建方式有幾種

    線程是一種用于管理和調(diào)度線程的技術(shù),能夠有效地提高系統(tǒng)的性能和資源利用率。它通過(guò)預(yù)先創(chuàng)建一組線程并維護(hù)一個(gè)工作隊(duì)列,將任務(wù)提交給
    的頭像 發(fā)表于 12-04 16:52 ?1291次閱讀

    什么是動(dòng)態(tài)線程?動(dòng)態(tài)線程的簡(jiǎn)單實(shí)現(xiàn)思路

    因此,動(dòng)態(tài)可監(jiān)控線程一種針對(duì)以上痛點(diǎn)開(kāi)發(fā)的線程管理工具。主要可實(shí)現(xiàn)功能有:提供對(duì) Spring 應(yīng)用內(nèi)線程
    的頭像 發(fā)表于 02-28 10:42 ?1139次閱讀
    主站蜘蛛池模板: 国产内地激情精品毛片在线一 | 2021国产精品成人免费视频 | 高清人人天天夜夜曰狠狠狠狠 | 国产网站免费 | 手机看片中文字幕 | 一级特黄aaa大片在线观看 | 夜夜骑夜夜操 | 午夜刺激爽爽视频免费观看 | 天天操夜夜添 | 7777色鬼xxxx欧美色夫 | 免费特黄一区二区三区视频一 | 加勒比视频网站 | 一级做a爰片久久毛片美女图片 | 欧洲精品码一区二区三区免费看 | 美女扒开下面让男人捅 | 国产偷窥女洗浴在线观看亚洲 | 婷婷色六月 | 久久夜色精品国产尤物 | 欧美日a | 综合婷婷 | 国产精品成人一区二区三区 | 国产91久久最新观看地址 | 天天艹夜夜| 永井玛丽亚中文在线观看视频 | 国产精品香蕉成人网在线观看 | 爽死你个放荡粗暴小淫视频 | 国产三级在线 | 精品亚洲综合在线第一区 | 国产精品国产午夜免费福利看 | 2017亚洲男人天堂 | 日韩午夜r电影在线观看 | 久久久久999 | 国产黄在线观看免费观看不卡 | 六月色播 | 黄www片| 91夜夜操| 瑟瑟久久 | 手机在线亚洲 | 五月天亚洲综合 | 天天曰天天爽 | 被公侵犯肉体中文字幕一区二区 |