App下載

Java 自定義線程池的名稱

一級抬杠運動員 2021-09-22 16:47:25 瀏覽數(shù) (2855)
反饋

我們的軟件傾向于使用大量的線程池——主要是通過?j?ava.util.concurrent.ExecutorService??實現(xiàn)(通過?Executors.new...?創(chuàng)建)。我們?yōu)楦鞣N異步用例創(chuàng)建這些線程池,它們隨處可見。所有這些執(zhí)行器都有一個線程工廠。它隱藏在默認工廠方法,但您可以提供線程工廠。如果未提供,則在需要線程時使用默認線程工廠。

使用 spring 時,可以使用?<task:executor />?。在這種情況下,每個執(zhí)行程序服務的線程工廠由 spring 提供,它使用執(zhí)行程序 bean 的名稱(用?id="executorName"?指定)。但是對于那些不是由 spring 創(chuàng)建的,使用默認名稱是沒有幫助的,并且不允許您按名稱區(qū)分線程。

并且您需要按名稱區(qū)分線程——如果出現(xiàn)性能問題,您有多種調查選項:線程轉儲和使用 top 命令。在這兩種情況下,了解線程服務的函數(shù)是有用的,因為轉儲中的堆棧跟蹤可能并不總是顯示出來。

我最喜歡的快速調查工具是?top?,更準確地說,?top -H -p <pid>?。這顯示了通常的頂部表,但 ?-H ?標志意味著應該打印所選進程的線程。按名稱,您基本上會獲得占用 CPU 最多且當前處于活動狀態(tài)的線程。在這些情況下,自定義名稱非常有用。

但是如何設置名稱呢?通過在創(chuàng)建每個執(zhí)行程序時指定一個命名的線程工廠。

我使用的方法基于第二個答案:

public class AsyncUtils {
    public static ThreadFactory createNamedThreadFactory(String name) {
        return new ThreadFactoryBuilder().setNameFormat(name + "-%d").build();
    }
}

通過 spring 集中管理所有 executor 可能是一個更好的主意,但并不是每個人都在使用 spring,有時甚至可能超出 spring bean 的一小部分功能需要一個 executor。因此,這是一個很好的方法。


0 人點贊