主頁 > 後端開發 > Java配置執行緒池

Java配置執行緒池

2023-05-25 07:35:38 後端開發

一、Java配置執行緒池

1、執行緒池分類、其他

1.1、分類

IO密集型 和 CPU密集型 任務的特點不同,因此針對不同型別的任務,選擇不同型別的執行緒池可以獲得更好的性能表現,

1.1. IO密集型任務

? IO密集型任務的特點是需要頻繁讀寫磁盤、網路或者其他IO資源,執行時間長,CPU占用率較低,

對于這類任務,執行緒的執行時間主要取決于IO操作的速度,而非CPU的執行能力,

? 因此,執行緒池的執行緒數應該設定較大,以便充分利用IO資源,

通常建議使用CachedThreadPool執行緒池或者FixedThreadPool執行緒池來處理IO密集型任務,

1.2. CPU密集型任務

? CPU密集型任務的特點是需要進行大量的計算,執行時間長,CPU占用率較高,

對于這類任務,執行緒的執行時間主要取決于CPU的執行能力,

? 因此,執行緒池的執行緒數應該設定較小,以充分利用CPU的計算能力,避免過多的執行緒切換和背景關系切換導致的性能損失,

通常建議使用FixedThreadPool執行緒池或者SingleThreadPool執行緒池來處理CPU密集型任務,


總之,選擇恰當的執行緒池型別可以充分發揮不同型別任務的性能,提高程式效率和回應速度,

1.2. 異步執行緒池的選擇

對于異步執行緒池,通常建議使用IO密集型執行緒池,
異步任務通常是網路IO或磁盤IO等操作,這些操作的執行時間相對于CPU計算的執行時間要長得多,
使用IO密集型執行緒池可以更好地利用IO資源,提高多個異步任務的執行效率和吞吐量,
同時避免由于過多的執行緒切換和背景關系切換導致的性能損失,

1.3. 執行緒池作業步奏

很多任務——》執行緒池創建核心執行緒——》任務超過最大執行緒——》把任務放入佇列中等待執行——》佇列中放滿了——》進入處理策略

2、執行緒池引數、合理引數

2.1、引數

①、核心執行緒數

當執行緒池中的執行緒數量為 corePoolSize核心執行緒數 時,即使這些執行緒處于空閑狀態,也不會銷毀(除非設定 allowCoreThreadTimeOut=true),
//  -> 核心執行緒,也就是正在處理中的任務
//  -> 雖然 CPU 核心數可以作為執行緒池中執行緒數量的參考指標,但最終執行緒數量還需要根據具體情況進行設定和調整,
//  -> 如果同時運行的執行緒數量超過 CPU 核心數,就會發生--執行緒背景關系切換--,導致額外的開銷和性能下降,所以執行緒不能創建得過多

②、最大執行緒數

執行緒池中允許的執行緒數量的最大值,
        //  -> 當執行緒數 = maxPoolSize最大執行緒數時,還有新任務,就會放進佇列中等待執行 ↓↓↓

③、佇列長度

當核心執行緒數達到最大時,新任務會放在佇列中排隊等待執行
        //  -> 根據業務配置,如果佇列長度過大,可能會導致系統記憶體資源占用過高,最終導致 OOM,需要注意控制
        //  -> 如果需要執行的任務裝滿了佇列,就會走拒絕策略 ↓↓↓

④、拒絕策略

(官方提供4種,也可以自定義):因達到執行緒邊界和任務佇列滿時,針對新任務的處理方法,
        // -> AbortPolicy:直接丟棄任務并拋出 RejectedExecutionException 例外,(默認策略)
        // -> DiscardPolicy:直接丟棄掉,不會拋出例外
        // -> DiscardOldestPolicy:丟棄佇列最前面的任務,然后重新嘗試執行任務(重復此程序)
        // -> CallerRunsPolicy:交給主執行緒(呼叫執行緒)去執行

⑤、空閑執行緒存活時間

(默認60s):設定當前執行緒池中空閑執行緒的存活時間,即執行緒池中的執行緒如果有一段時間沒有任務可執行,則會被回收掉,
        //  -> 當執行緒池中的執行緒數大于 corePoolSize 時,多余的空閑執行緒將在銷毀之前等待新任務的最長時間,
        //  -> 如果一個執行緒在空閑時間超過了 keepAliveSeconds,且當前執行緒池中執行緒數量大于 corePoolSize,則該執行緒將會被回收;
        //  -> 核心執行緒會一直存活,除非執行緒池被關閉 或 設定下面的引數
        //  -> 如果 AllowCoreThreadTimeout設定為true,核心執行緒也會被回收,直到執行緒池中的執行緒數降為 0,
        //     但如果執行緒池中有任務在執行,那么空閑執行緒就會一直保持存活狀態,直到任務執行完畢,
        //  -> 該方法的使用可以將執行緒池的空閑執行緒回收,以減少資源占用,同時也能保證執行緒池中始終有可用的執行緒來執行任務,提高執行緒池的效率,

⑥、是否禁止執行緒池自動終止空閑的核心執行緒

為 true 時,空閑的核心執行緒會在 keepAliveTime 時間后被回收,并且在后續任務到來時需要重新創建執行緒來執行任務,
        // 為 false 時,執行緒池中的核心執行緒不會被回收,即使它們處于空閑狀態一段時間,
        //  -> 在執行緒池創建時,就會預先創建核心執行緒數的執行緒,這些執行緒將一直存在,除非執行緒池被關倍訓重新配置,

⑦、當前執行緒池的等待時間

指等待所有任務執行完畢后執行緒池的最長時間,300秒 = 5分鐘
        // -> 當所有任務執行完畢后,執行緒池會等待一段時間(即等待時間),來確保所有任務都已經完成,
        // -> 如果在等待時間內所有任務仍未完成,則執行緒池會強制停止,以確保任務不會無限制地執行下去,

⑧、當前執行緒池是否在關閉時等待所有任務執行完成

		// -> 可以確保所有任務都執行完畢后才關閉執行緒池,避免任務被丟棄,同時也確保執行緒池可以正常結束,釋放資源,
        // -> 為 true 時,執行緒池在關閉時會等待所有任務都執行完成后再關閉
        // -> 為 false 時,執行緒池會直接關閉,未執行完成的任務將被丟棄,

⑨、執行緒名稱前綴

		// 9執行緒前綴名稱
        executor.setThreadNamePrefix("myIo-Th-Pool-");
        // 初始化
        executor.initialize();

2.2、合理配置

①執行緒數量:N = 計算機cpu數量

  • 如果同時運行的執行緒數量超過 CPU 核心數,就會發生--執行緒背景關系切換--,導致額外的開銷和性能下降,所以執行緒不能創建得過多
  • 一般的配置如下:也可以通過計算獲取,
     * IO密級 :2 * N
     * CPU密級:1 + N

②佇列長度:

  • 如果佇列長度過大,可能會導致系統記憶體資源占用過高,最終導致 OOM,需要注意控制
  • 根據自身業務配置

3、配置

3.1、配置執行緒池的Bean的選擇

配置執行緒池選擇:ThreadPoolTaskExecutor(Spring專案推薦),還是選擇ThreadPoolExecutor?

ThreadPoolTaskExecutor 是 Spring 框架中對 Java 自帶的執行緒池 ThreadPoolExecutor 進行了封裝和擴展,并增加了一些優化和功能,通常來說,如果你使用 Spring 框架,需要使用執行緒池,那么建議使用 ThreadPoolTaskExecutor, ThreadPoolTaskExecutor 提供了更多的配置選項,例如執行緒池的最大執行緒數、核心執行緒數、緩沖佇列大小、執行緒命名前綴、執行緒池飽和策略等等,同時可以方便地集成到 Spring 應用中,另外,ThreadPoolTaskExecutor 還能夠支持異步執行任務,使用方便, 相比之下,ThreadPoolExecutor 是 Java 自帶的執行緒池實作類,提供了基本的執行緒池功能,但沒有 ThreadPoolTaskExecutor 提供的更多配置選項和功能,如果你不使用 Spring 框架,或者使用 Spring 框架但不需要使用其提供的執行緒池實作,那么可以考慮使用 ThreadPoolExecutor,

綜上所述,選擇使用 ThreadPoolTaskExecutor 還是 ThreadPoolExecutor 取決于具體的業務需求和技術堆疊,可以根據實際情況進行選擇,

3.2、獲取當前電腦(服務器)的核心執行緒數

int N = Runtime.getRuntime().availableProcessors()

3.3、IO密集型

package com.cc.md.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.EnableAsync;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;

import java.util.concurrent.ThreadPoolExecutor;

/** IO型的執行緒池
 * <li>IO密集型配置執行緒數經驗值是:2N (CPU核數*2)</li>
 * <li>異步執行緒池:建議用io密集型:</li>
 *      對于異步執行緒池,通常建議使用IO密集型執行緒池,
 *      異步任務通常是網路IO或磁盤IO等操作,這些操作的執行時間相對于CPU計算的執行時間要長得多,
 *      使用IO密集型執行緒池可以更好地利用IO資源,提高多個異步任務的執行效率和吞吐量,
 *      同時避免由于過多的執行緒切換和背景關系切換導致的性能損失,
 * @author CC
 * @since 2023/5/23 0023
 */
@Configuration
@EnableAsync
public class IoThreadPool {

    /** 執行緒數量
     * CUP數量:N = Runtime.getRuntime().availableProcessors()
     * IO密級:2 * N
     * CPU密級:1 + N
     */
    public static final int THREAD_SIZE = 2 * (Runtime.getRuntime().availableProcessors());
    /**
     * 佇列大小
     */
    public static final int QUEUE_SIZE = 1000;

    @Bean(name = "myIoThreadPool")
    public ThreadPoolTaskExecutor threadPoolExecutor(){
        //配置執行緒池選擇:ThreadPoolTaskExecutor,還是選擇ThreadPoolExecutor好些?
        // -> ThreadPoolTaskExecutor 是 Spring 框架中對 Java 自帶的執行緒池 ThreadPoolExecutor 進行了封裝和擴展,
        //    并增加了一些優化和功能,通常來說,如果你使用 Spring 框架,需要使用執行緒池,那么建議使用 ThreadPoolTaskExecutor,
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        // 1核心執行緒數:當執行緒池中的執行緒數量為 corePoolSize 時,即使這些執行緒處于空閑狀態,也不會銷毀(除非設定 allowCoreThreadTimeOut=true),
        //  -> 核心執行緒,也就是正在處理中的任務
        //  -> 雖然 CPU 核心數可以作為執行緒池中執行緒數量的參考指標,但最終執行緒數量還需要根據具體情況進行設定和調整,
        //  -> 如果同時運行的執行緒數量超過 CPU 核心數,就會發生--執行緒背景關系切換--,導致額外的開銷和性能下降,所以執行緒不能創建得過多
        executor.setCorePoolSize(THREAD_SIZE);
        // 2最大執行緒數:執行緒池中允許的執行緒數量的最大值,
        //  -> 當執行緒數 = maxPoolSize最大執行緒數時,還有新任務,就會放進佇列中等待執行 ↓↓↓
        executor.setMaxPoolSize(THREAD_SIZE);
        // 3佇列長度:當核心執行緒數達到最大時,新任務會放在佇列中排隊等待執行
        //  -> 根據業務配置,如果佇列長度過大,可能會導致系統記憶體資源占用過高,最終導致 OOM,需要注意控制
        //  -> 如果需要執行的任務裝滿了佇列,就會走拒絕策略 ↓↓↓
        executor.setQueueCapacity(QUEUE_SIZE);
        // 4拒絕策略(官方提供4種,也可以自定義):因達到執行緒邊界和任務佇列滿時,針對新任務的處理方法,
        // -> AbortPolicy:直接丟棄任務并拋出 RejectedExecutionException 例外,(默認策略)
        // -> DiscardPolicy:直接丟棄掉,不會拋出例外
        // -> DiscardOldestPolicy:丟棄佇列最前面的任務,然后重新嘗試執行任務(重復此程序)
        // -> CallerRunsPolicy:交給主執行緒(呼叫執行緒)去執行
        executor.setRejectedExecutionHandler(new ThreadPoolExecutor.AbortPolicy());
        // 5空閑執行緒存活時間(默認60s):設定當前執行緒池中空閑執行緒的存活時間,即執行緒池中的執行緒如果有一段時間沒有任務可執行,則會被回收掉,
        //  -> 當執行緒池中的執行緒數大于 corePoolSize 時,多余的空閑執行緒將在銷毀之前等待新任務的最長時間,
        //  -> 如果一個執行緒在空閑時間超過了 keepAliveSeconds,且當前執行緒池中執行緒數量大于 corePoolSize,則該執行緒將會被回收;
        //  -> 核心執行緒會一直存活,除非執行緒池被關閉 或 設定下面的引數
        //  -> 如果 AllowCoreThreadTimeout設定為true,核心執行緒也會被回收,直到執行緒池中的執行緒數降為 0,
        //     但如果執行緒池中有任務在執行,那么空閑執行緒就會一直保持存活狀態,直到任務執行完畢,
        //  -> 該方法的使用可以將執行緒池的空閑執行緒回收,以減少資源占用,同時也能保證執行緒池中始終有可用的執行緒來執行任務,提高執行緒池的效率,
        executor.setKeepAliveSeconds(60);
        //6是否禁止執行緒池自動終止空閑的核心執行緒,
        // 為 true 時,空閑的核心執行緒會在 keepAliveTime 時間后被回收,并且在后續任務到來時需要重新創建執行緒來執行任務,
        // 為 false 時,執行緒池中的核心執行緒不會被回收,即使它們處于空閑狀態一段時間,
        //  -> 在執行緒池創建時,就會預先創建核心執行緒數的執行緒,這些執行緒將一直存在,除非執行緒池被關倍訓重新配置,
        executor.setAllowCoreThreadTimeOut(true);
        // 7當前執行緒池的等待時間:指等待所有任務執行完畢后執行緒池的最長時間,300秒 = 5分鐘
        // -> 當所有任務執行完畢后,執行緒池會等待一段時間(即等待時間),來確保所有任務都已經完成,
        // -> 如果在等待時間內所有任務仍未完成,則執行緒池會強制停止,以確保任務不會無限制地執行下去,
        executor.setAwaitTerminationSeconds(300);
        // 8當前執行緒池是否在關閉時等待所有任務執行完成
        // -> 可以確保所有任務都執行完畢后才關閉執行緒池,避免任務被丟棄,同時也確保執行緒池可以正常結束,釋放資源,
        // -> 為 true 時,執行緒池在關閉時會等待所有任務都執行完成后再關閉
        // -> 為 false 時,執行緒池會直接關閉,未執行完成的任務將被丟棄,
        executor.setWaitForTasksToCompleteOnShutdown(true);
        // 9執行緒前綴名稱
        executor.setThreadNamePrefix("myIo-Th-Pool-");
        // 初始化
        executor.initialize();
        return executor;
    }
}

3.4、CPU密集型

package com.cc.md.config;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;

import java.util.concurrent.ThreadPoolExecutor;

/** CPU型的執行緒池
 * @author CC
 * @since 2023/5/23 0023
 */
@Configuration
public class CpuThreadPool {

    /** 執行緒數量
     * CUP數量:N = Runtime.getRuntime().availableProcessors()
     * IO密級:2 * N
     * CPU密級:1 + N
     */
    public static final int THREAD_SIZE = 1 + (Runtime.getRuntime().availableProcessors());
    /**
     * 佇列大小
     */
    public static final int QUEUE_SIZE = 1000;

    @Bean(name = "myCpuThreadPool")
    public ThreadPoolTaskExecutor threadPoolExecutor(){
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        executor.setCorePoolSize(THREAD_SIZE);
        executor.setMaxPoolSize(THREAD_SIZE);
        executor.setQueueCapacity(QUEUE_SIZE);
        executor.setRejectedExecutionHandler(new ThreadPoolExecutor.AbortPolicy());
        executor.setKeepAliveSeconds(60);
        executor.setAllowCoreThreadTimeOut(true);
        executor.setAwaitTerminationSeconds(300);
        executor.setWaitForTasksToCompleteOnShutdown(true);
        executor.setThreadNamePrefix("myCpu-T-Pool-");
        executor.initialize();
        return executor;
    }
}

4、執行緒池的原始使用

  • 不要這樣使用
  • 使用CompletableFuture:見《Java的CompletableFuture,Java的多執行緒開發》
    @Resource(name = "myIoThreadPool")
    private ThreadPoolTaskExecutor myIoThreadPool;
    
    //執行緒池原始的使用
    @Test
    void test2() {
        try {
            for (int i = 0; i < 1000; i++) {
                int finalI = i;
                myIoThreadPool.submit(() -> {
                    //第一批創建的執行緒數
                    log.info("列印:{}", finalI);
                    //模仿io流耗時
                    try {
                        Thread.sleep(5000);
                    } catch (InterruptedException e) {
                        throw new RuntimeException(e);
                    }
                });
            }
        }catch(Exception e){
            throw new RuntimeException(e);
        }finally {
            myIoThreadPool.shutdown();
        }
    }

  • 參考

https://zhuanlan.zhihu.com/p/112527671

https://blog.csdn.net/shang_0122/article/details/120777113

https://blog.csdn.net/zhuimeng_by/article/details/107891268

https://blog.csdn.net/qq_25720801/article/details/129559164

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/553260.html

標籤:Java

上一篇:Spring Boot 我隨手封裝了一個萬能的 Excel 匯出工具,傳什么都能匯出!

下一篇:返回列表

標籤雲
其他(159587) Python(38165) JavaScript(25446) Java(18118) C(15231) 區塊鏈(8268) C#(7972) AI(7469) 爪哇(7425) MySQL(7208) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5873) 数组(5741) R(5409) Linux(5340) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4576) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2433) ASP.NET(2403) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1976) 功能(1967) Web開發(1951) HtmlCss(1942) C++(1922) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1878) .NETCore(1861) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Java配置執行緒池

    # 一、Java配置執行緒池 ## 1、執行緒池==分類==、其他 ### 1.1、分類 ==IO密集型 和 CPU密集型== 任務的特點不同,因此針對不同型別的任務,選擇不同型別的執行緒池可以獲得更好的性能表現。 #### 1.1. IO密集型任務 ? IO密集型任務的特點是需要頻繁讀寫磁盤、網路或者其 ......

    uj5u.com 2023-05-25 07:35:38 more
  • Spring Boot 我隨手封裝了一個萬能的 Excel 匯出工具,傳什么都能

    ## 前言 如題,這個小玩意,就是不限制你查的是哪張表,用的是什么類。 我直接一把梭,嘎嘎給你一頓匯出。 我知道,這是很多人都想過的, 至少我就收到很多人問過我這個類似的問題。 我也跟他們說了,但是他們就是不動手,其實真的很簡單。 不動手怎么辦? 我出手唄。 不多說開搞 。 ## 正文 玩法很簡單。 ......

    uj5u.com 2023-05-25 07:35:08 more
  • springboot~mybatis-plus的DynamicTableNameInnerInterceptor實

    # 超輕量級 DynamicTableNameInnerInterceptor是mybatis-plug的一個攔截器插件,可以自己定義需要攔截的表單,然后對它進行加工,這時mybatis-plus就會把SQL代碼的表名加上你的這個裝飾。 # 封裝的思想 我們通常把mybatis做成一個包,公司其它同 ......

    uj5u.com 2023-05-25 07:34:46 more
  • Netty實戰(二)

    # 一、環境準備 Netty需要的運行環境很簡單,只有2個。 - JDK 1.8+ - Apache Maven 3.3.9+ # 二、Netty 客戶端/服務器概覽 ![在這里插入圖片描述](https://img-blog.csdnimg.cn/c49191e6ee6e448f8c525b450 ......

    uj5u.com 2023-05-25 07:34:41 more
  • springboot~sharding-jdbc實作分庫分表

    # 原因 當mysql資料庫單表大于1千萬以后,查詢的性能就不能保證了,我們必須考慮分庫,分表的方案了,還好,sharding-jdbc可以很優雅的與springboot對接,完成對mysql的分庫和分表。 # 依賴整理 > 為了不影響其它小容量的表,所有添加了動態資料源,只對需要分庫分表的進行配置 ......

    uj5u.com 2023-05-25 07:34:34 more
  • Maven的概述

    # Maven的概述 @[toc] Java 專案開發程序中,構建指的是使用『原材料生產產品』的程序。 - 原材料 - Java 源代碼 - 基于 HTML 的 Thymeleaf 檔案 - 圖片 - 組態檔 - …… - 產品 - 一個可以在服務器上運行的專案 構建程序包含的主要的環節: - 清 ......

    uj5u.com 2023-05-25 07:34:20 more
  • 面試必問:RabbitMQ 有哪幾種訊息模式?

    原文:juejin.cn/post/6998363970037874724 ## **前言** Rabbitmq 是使用 Erlang 語言開發的開源訊息佇列系統,基于 AMQP 實作,是一種應用程式對應用程式的通信方法,應用程式通過讀寫出入佇列的訊息來通信,而無需專用連接來鏈接它們。訊息傳遞指的是 ......

    uj5u.com 2023-05-25 07:28:52 more
  • Markdown標題自動添加編號

    用`markdown`寫檔案很方便,但是有個困擾的地方,就是標題的編號問題。 寫檔案的時候,經常會在中間插入新的標題和內容,所以手動管理編號的話,如果新的標題插在前面,則要調整后面所有的編號。 如果在檔案完成后再手動加上編號的話,不僅容易忘記, 而且有時候我們是在其他編輯器里編輯檔案再匯出`mark ......

    uj5u.com 2023-05-25 07:21:50 more
  • JAVA8新特性

    # Lambda運算式 ## 1.基本格式 ~~~java (引數串列)->{代碼} ~~~ ## 2.省略規則 - 引數型別可以省略 - 方法體只有一句代碼時大括號return和唯一一句代碼的分號可以省略 - 方法只有一個引數時小括號可以省略 # Stream流 ## 1.創建流 - 單列集合:集 ......

    uj5u.com 2023-05-24 08:21:31 more
  • 什么是 Spring?為什么學它?

    歡迎來到本篇文章!在這里,我將帶領大家快速學習 Spring 的基本概念,并解答兩個關鍵問題:什么是 Spring,以及為什么學習 Spring。

    廢話少說,下面,我們開始吧! ......

    uj5u.com 2023-05-24 08:21:24 more