成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

用了很多年Dubbo,連Dubbo線程池監控都不知道,覺得自己很厲害?

安全 應用安全
micrometer 中自帶了很多其他框架的指標信息,可以很方便的通過 prometheus 進行采集和監控,常用的有 JVM 的信息,Http 請求的信息,Tomcat 線程的信息等。

[[381254]]

本文轉載自微信公眾號「猿天地」,作者尹吉歡。轉載本文請聯系猿天地公眾號。

前言

micrometer 中自帶了很多其他框架的指標信息,可以很方便的通過 prometheus 進行采集和監控,常用的有 JVM 的信息,Http 請求的信息,Tomcat 線程的信息等。

對于一些比較活躍的框架,有些還是不支持的,比如 Dubbo。如果想監控 Dubbo 的一些指標,比如線程池的狀況,我們需要手動去擴展,輸出對應的線程池指標才行。

在這種情況下,肯定是沒什么思路的,因為你不知道怎么去擴展,下面給大家介紹去做一件事情之前的思考,方式方法很重要。

  • Dubbo 有沒有現成的實現?
  • 參考 micrometer 中指標的實現,依葫蘆畫瓢?

Dubbo 有沒有現成的實現?

完整的實現應該沒有,至少我還沒用過,也沒有那種去搜索引擎一搜就大把結果的現狀,于是我在 Dubbo 的 Github 上找到了一個相關的項目 dubbo-spring-boot-actuator。

https://github.com/apache/dubbo-spring-boot-project/tree/master/dubbo-spring-boot-actuator

dubbo-spring-boot-actuator 看名稱就知道,提供了 Dubbo 相關的各種信息端點和健康檢查。從這里面也許能發現點有用的代碼。

果不其然,在介紹頁面中看到了想要的內容,線程池的指標數據,只不過是拼接成了字符串顯示而已。

  1. "threadpool": { 
  2.       "source""management.health.dubbo.status.extras"
  3.       "status": { 
  4.         "level""OK"
  5.         "message""Pool status:OK, max:200, core:200, largest:0, active:0, task:0, service port: 12345"
  6.         "description"null 
  7.       } 

然后就去翻 dubbo-spring-boot-actuator 的代碼了,沒找到線程池這塊的代碼。后面在 dubbo.jar 中找到了 ThreadPoolStatusChecker 這個類,核心邏輯在這里面。現在已經解決了第一個問題,就是獲取到 Dubbo 的線程池對象。

 

參考 micrometer 中指標的實現,依葫蘆畫瓢?

線程池對象能拿到了,各種數據也就能獲取了。接下來的問題就是如何暴露出去給 prometheus 采集。

兩種方式,一種是自定義一個新的端點暴露,一種是直接在已有的 prometheus 端點中增加指標數據的輸出,也就是依葫蘆畫瓢。

看源碼中已經有很多 Metrics 的實現了,我們也實現一個 Dubbo 線程池的 Metrics 即可。

 

上圖框起來的就是一個已經存在的線程池 Metrics,可以直接復用代碼。

實現的主要邏輯就是實現一個 MeterBinder 接口,然后將你需要的指標進行輸出即可。于是打算在 bindTo 方法中獲取 Dubbo 的線程池對象,然后輸出指標。經過測試,在 MeterBinder 實例化的時候 Dubbo 還沒初始化好,拿不到線程池對象,綁定后無法成功輸出指標。

后面還是打算采用定時采樣的方式來輸出,自定義一個后臺線程,定時去輸出數據。可以用 Timer,我這圖簡單就直接 while 循環了。

  1. /** 
  2.  * Dubbo線程池指標 
  3.  * 
  4.  * @author yinjihuan 
  5.  */ 
  6. @Configuration 
  7. public class DubboThreadMetrics { 
  8.     @Autowired 
  9.     private MeterRegistry meterRegistry; 
  10.     private final Iterable<Tag> TAG = Collections.singletonList(Tag.of("thread.pool.name""dubboThreadPool")); 
  11.     @PostConstruct 
  12.     public void init() { 
  13.         new Thread(() -> { 
  14.             while (true) { 
  15.                 try { 
  16.                     Thread.sleep(1000); 
  17.                 } catch (InterruptedException e) { 
  18.                     e.printStackTrace(); 
  19.                 } 
  20.                 DataStore dataStore = ExtensionLoader.getExtensionLoader(DataStore.class).getDefaultExtension(); 
  21.                 Map<String, Object> executors = dataStore.get(Constants.EXECUTOR_SERVICE_COMPONENT_KEY); 
  22.                 for (Map.Entry<String, Object> entry : executors.entrySet()) { 
  23.                     ExecutorService executor = (ExecutorService) entry.getValue(); 
  24.                     if (executor instanceof ThreadPoolExecutor) { 
  25.                         ThreadPoolExecutor tp = (ThreadPoolExecutor) executor; 
  26.                         Gauge.builder("dubbo.thread.pool.core.size", tp, ThreadPoolExecutor::getCorePoolSize) 
  27.                                 .description("核心線程數"
  28.                                 .baseUnit("threads"
  29.                                 .register(meterRegistry); 
  30.                         Gauge.builder("dubbo.thread.pool.largest.size", tp, ThreadPoolExecutor::getLargestPoolSize) 
  31.                                 .description("歷史最高線程數"
  32.                                 .baseUnit("threads"
  33.                                 .register(meterRegistry); 
  34.                         Gauge.builder("dubbo.thread.pool.max.size", tp, ThreadPoolExecutor::getMaximumPoolSize) 
  35.                                 .description("最大線程數"
  36.                                 .baseUnit("threads"
  37.                                 .register(meterRegistry); 
  38.                         Gauge.builder("dubbo.thread.pool.active.size", tp, ThreadPoolExecutor::getActiveCount) 
  39.                                 .description("活躍線程數"
  40.                                 .baseUnit("threads"
  41.                                 .register(meterRegistry); 
  42.                         Gauge.builder("dubbo.thread.pool.thread.count", tp, ThreadPoolExecutor::getPoolSize) 
  43.                                 .description("當前線程數"
  44.                                 .baseUnit("threads"
  45.                                 .register(meterRegistry); 
  46.                         Gauge.builder("dubbo.thread.pool.queue.size", tp, e -> e.getQueue().size()) 
  47.                                 .description("隊列大小"
  48.                                 .baseUnit("threads"
  49.                                 .register(meterRegistry); 
  50.                         Gauge.builder("dubbo.thread.pool.taskCount", tp, ThreadPoolExecutor::getTaskCount) 
  51.                                 .description("任務總量"
  52.                                 .baseUnit("threads"
  53.                                 .register(meterRegistry); 
  54.                         Gauge.builder("dubbo.thread.pool.completedTaskCount", tp, ThreadPoolExecutor::getCompletedTaskCount) 
  55.                                 .description("已完成的任務量"
  56.                                 .baseUnit("threads"
  57.                                 .register(meterRegistry); 
  58.                     } 
  59.                 } 
  60.             } 
  61.         }).start(); 
  62.     } 

指標信息:

 

配置線程池圖表

創建一個新的 dashboard 配置圖表,然后新建 panel 配置指標信息

 

左側配指標信息,右側選擇對應的圖表格式。需要注意的是,如果有多個服務實例,Metrics 這邊最好是根據服務實例來顯示,需要在指標后面增加條件,如下:

  1. dubbo_thread_pool_max_size_theads{application="$application", instance=~"$instance"

 

關于作者:尹吉歡,簡單的技術愛好者,《Spring Cloud 微服務-全棧技術與案例解析》, 《Spring Cloud 微服務 入門 實戰與進階》作者, 公眾號猿天地發起人。

原文鏈接:http://cxytiandi.com/blog/user/1

 

責任編輯:武曉燕 來源: 猿天地
相關推薦

2020-11-20 06:13:04

Like %

2023-01-05 23:18:06

CPU線程

2020-12-21 09:00:04

MySQL緩存SQL

2020-12-21 09:44:53

MySQL查詢緩存數據庫

2020-07-21 18:37:14

代碼條件變量

2022-12-05 15:23:33

JavaScript技巧運算符

2021-08-27 10:03:12

人工智能AI

2019-05-21 15:43:59

CIO云計算成本

2018-08-10 10:36:25

SSL證書誤區

2019-07-08 10:40:03

線程池策略CPU

2020-07-29 09:53:09

VSCode編碼工具插件

2025-02-18 00:05:00

2021-05-08 23:19:25

微信存儲小程序

2021-02-03 08:24:32

JavaScript技巧經驗

2020-02-03 09:00:51

物聯網安全物聯網IOT

2020-07-29 08:07:18

Python開發工具

2021-11-12 10:05:19

跳表BAT面試

2021-07-22 09:28:35

DockerLinux命令

2024-10-22 09:03:35

前端signalAPI

2023-01-13 16:48:48

前端開發JavaScript
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一级在线 | 欧美在线亚洲 | 欧美精品video | 365夜爽爽欧美性午夜免费视频 | 成人综合久久 | 99精品视频一区二区三区 | 中文字幕在线观看一区二区 | 国产一区二区三区视频在线观看 | 国产精品免费在线 | 国产精品视频网址 | 狠狠爱综合 | 一区二区精品 | 久久精品国产99国产精品亚洲 | 911网站大全在线观看 | 91精品国产综合久久香蕉麻豆 | a级大片免费观看 | www.国产精| 久久午夜精品福利一区二区 | 日本欧美国产 | 国产精品久久久久久久久 | h视频在线播放 | 麻豆av一区二区三区久久 | 日韩精品一区二区三区在线观看 | 免费人成在线观看网站 | 免费在线观看一级毛片 | 一本一道久久a久久精品综合 | 亚洲一区二区三区视频免费观看 | 久久99精品久久久97夜夜嗨 | 亚洲午夜精品一区二区三区他趣 | 亚洲高清免费观看 | 日韩精品一区二区在线 | 亚洲一区二区成人 | www.狠狠干 | 黄色免费av| 亚洲日韩中文字幕 | 日韩在线免费视频 | 久久久久国产精品免费免费搜索 | 成人福利网站 | 国产精品久久久久久久久久久免费看 | 一区二区三区网站 | 日韩中文欧美 |