排查和解决线程池瓶颈问题案例

在分布式系统中,线程池的使用非常普遍,尤其是在处理异步任务时。然而,线程池的配置不当可能会导致性能瓶颈,进而影响系统的整体性能。本文将分享一个实际案例,介绍如何通过日志分析和线程池优化来解决系统中的性能瓶颈问题。

问题背景

在我们的系统中,有一个基于Spring的事件监听机制,用于处理长连接消息的回调。事件监听器RawMessageEventListener通过onApplicationEvent方法处理事件。默认情况下,onApplicationEvent是同步执行的,但为了提升性能,我们使用了@Async注解将其改为异步执行。异步任务默认使用threadPoolTaskScheduler线程池。

在某天的10点左右,我们注意到系统的响应速度变慢,通过日志分析发现,threadPoolTaskScheduler线程池的处理能力成为了瓶颈。

问题排查

日志分析

首先,我们通过以下命令对日志进行分析:

tail -10000000 info-2025-02-23.log | grep '2025-02-23 10:' | grep 'threadPoolTaskScheduler' | awk '{print $4}' | sort | uniq -c

输出结果如下:

46586 [threadPoolTaskScheduler-1]

从日志中可以看到,在10点这个时间段内,threadPoolTaskScheduler线程池处理了4万多条日志,但只有一个线程在工作。这表明线程池的默认配置可能不足以应对高并发场景。

代码分析

我们进一步查看了事件监听器的代码:

@Async
public void onApplicationEvent(RawMessageEvent event) {// 处理事件逻辑ThreadPoolManager.getInstance().execute(() -> robotCallBackService.callBack(socketId, request, url));
}

@Async注解默认使用threadPoolTaskScheduler线程池,而该线程池的默认线程数为1。这意味着所有异步任务都会排队等待执行,导致任务积压,进而影响系统性能。

解决方案

增加线程池线程数

为了解决这个问题,我们决定自定义threadPoolTaskScheduler的配置,增加线程池的线程数。我们创建了一个配置类,设置了10个线程:

@Configuration
public class SchedulerConfig {@Beanpublic ThreadPoolTaskScheduler threadPoolTaskScheduler() {ThreadPoolTaskScheduler scheduler = new ThreadPoolTaskScheduler();scheduler.setPoolSize(10);scheduler.setThreadNamePrefix("CustomTaskScheduler-");return scheduler;}
}

通过这个配置,我们为threadPoolTaskScheduler线程池设置了10个线程,从而提升了并发处理能力。

验证效果

在应用了新的线程池配置后,我们再次观察系统的日志和性能。发现threadPoolTaskScheduler线程池能够同时处理多个任务,系统的响应速度明显提升,任务积压的问题得到了有效缓解。

结论

通过这次排查和优化,我们认识到线程池的配置对系统性能有着重要影响。在高并发场景下,默认的线程池配置可能无法满足需求,因此需要根据实际情况进行调整。通过自定义线程池配置,我们成功解决了系统中的性能瓶颈问题。

关键点总结

  1. 日志分析:通过日志分析发现线程池的瓶颈。
  2. 代码审查:确认@Async注解默认使用的线程池配置。
  3. 自定义线程池:通过自定义配置增加线程池的线程数,提升并发处理能力。
  4. 验证效果:通过日志和性能监控验证优化效果。

希望这个案例能够帮助大家在遇到类似问题时,快速定位并解决问题。如果你有类似的经验或其他优化方案,欢迎在评论区分享!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/70727.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

影响板材的热导率有哪些因素?

板材热导率受多种因素左右,可划分为内部材料特性与外部环境条件两大方面 内部材料特性 化学构成:不同化学元素及化合物组合形成的板材,热导率表现大相径庭;金属板材,像铜与铝,热导率优异,这是…

给字符串加密解密

加密规则:输入1a2b3c 输出 abbccc 解密:输入abbccc 输出 1a2b3c 代码: using System;namespace 加密解密 {class Program{static void Main(string[] args){Encryption("4b2a8p");Decryption("ppppppoovvv");Console.…

人工智能中的特征是什么?

什么是人工智能中的特征? 在人工智能中,特征(feature)是指从原始数据中提取出的、能够代表数据关键信息并用于模型训练的属性或变量。特征通常是对原始数据的抽象或转换,目的是捕捉数据中的模式、结构或相关性&#x…

20250226-代码笔记05-class CVRP_Decoder

文章目录 前言一、class CVRP_Decoder(nn.Module):__init__(self, **model_params)函数功能函数代码 二、class CVRP_Decoder(nn.Module):set_kv(self, encoded_nodes)函数功能函数代码 三、class CVRP_Decoder(nn.Module):set_q1(self, encoded_q1)函数功能函数代码 四、class…

洛谷 P3628/SPOJ 15648 APIO2010 特别行动队 Commando

题意 你有一支由 n n n 名预备役士兵组成的部队,士兵从 1 1 1 到 n n n 编号,你要将他们拆分成若干特别行动队调入战场。出于默契的考虑,同一支特别行动队中队员的编号应该连续,即为形如 i , i 1 , ⋯ , i k i, i 1, \cdo…

PCL源码分析:曲面法向量采样

文章目录 一、简介二、源码分析三、实现效果参考资料一、简介 曲面法向量点云采样,整个过程如下所述: 1、空间划分:使用递归方法将点云划分为更小的区域, 每次划分选择一个维度(X、Y 或 Z),将点云分为两部分,直到划分区域内的点少于我们指定的数量,开始进行区域随机采…

Go语言--语法基础2--下载安装

2、下载安装 1、下载源码包: go1.18.4.linux-amd64.tar.gz。 官方地址:https://golang.google.cn/dl/ 云盘地址:链接: https://pan.baidu.com/s/1N2jrRHaPibvmmNFep3VYag 提 取码: zkc3 2、将下载的源码包解压…

lowagie(itext)老版本手绘PDF,包含页码、水印、图片、复选框、复杂行列合并等。

入口类:exportPdf ​ package xcsy.qms.webapi.service;import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.alibaba.nacos.common.utils.StringUtils; import com.ibm.icu.text.RuleBasedNumberFormat; import com.lowa…

3-2 WPS JS宏 工作簿的打开与保存(模板批量另存为工作)学习笔记

************************************************************************************************************** 点击进入 -我要自学网-国内领先的专业视频教程学习网站 *******************************************************************************************…

Ubuntu20.04之VNC的安装使用与常见问题

Ubuntu20.04之VNC的安装与使用 安装图形桌面选择安装gnome桌面选择安装xface桌面 VNC-Server安装配置开机自启 VNC Clientroot用户无法登入问题临时方案永久方案 安装图形桌面 Ubuntu20.04主流的图形桌面有gnome和xface两种,两种桌面的安装方式我都会写&#xff0c…

Day46 反转字符串

I. 编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。 不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。 class Solution {public void reverseString(char[] s) {int i …

用FileZilla Server 1.9.4给Windows Server 2025搭建FTP服务端

FileZilla Server 是一款免费的开源 FTP 和 FTPS 服务器软件,分为服务器版和客户端版。服务器版原本只支持Windows操作系统,比如笔者曾长期使用过0.9.60版,那时候就只支持Windows操作系统。当时我们生产环境对FTP稳定性要求较高,比…

【愚公系列】《Python网络爬虫从入门到精通》033-DataFrame的数据排序

标题详情作者简介愚公搬代码头衔华为云特约编辑,华为云云享专家,华为开发者专家,华为产品云测专家,CSDN博客专家,CSDN商业化专家,阿里云专家博主,阿里云签约作者,腾讯云优秀博主,腾讯云内容共创官,掘金优秀博主,亚马逊技领云博主,51CTO博客专家等。近期荣誉2022年度…

营销过程乌龟图模版

营销过程乌龟图模版 输入 公司现状产品服务客户问询客户期望电话、电脑系统品牌软件硬件材料 售前 - 沟通 - 确定需求 - 满足需求 - 售后 机料环 电话、电脑等设备软件硬件、系统品牌等工具材料 人 责任人协助者生产者客户 法 订单由谁评审控制程序营销过程控制程序顾客满意度…

Kubernetes (K8S) 高效使用技巧与实践指南

Kubernetes(K8S)作为容器编排领域的核心工具,其灵活性和复杂性并存。本文结合实战经验,从运维效率提升、生产环境避坑、核心功能应用等维度,总结高频使用技巧与最佳实践,分享如何快速掌握 K8S。 一、kubect…

Idea java项目结构介绍

一般来说,一个典型的 IntelliJ IDEA Java 项目具有特定的结构,以下是对其主要部分的介绍: 项目根目录 项目的最顶层目录,包含了整个项目的所有文件和文件夹,通常以项目名称命名。在这个目录下可以找到.idea文件夹、.g…

C++大整数类的设计与实现

1. 简介 我们知道现代的计算机大多数都是64位的,因此能处理最大整数为 2 64 − 1 2^{64}-1 264−1。那如果是超过了这个数怎么办呢,那就需要我们自己手动模拟数的加减乘除了。 2. 思路 我们可以用一个数组来存储大数,数组中的每一个位置表…

2024年第十五届蓝桥杯大赛软件赛省赛Python大学A组真题解析

文章目录 试题A: 拼正方形(本题总分:5 分)解析答案试题B: 召唤数学精灵(本题总分:5 分)解析答案试题C: 数字诗意解析答案试题A: 拼正方形(本题总分:5 分) 【问题描述】 小蓝正在玩拼图游戏,他有7385137888721 个2 2 的方块和10470245 个1 1 的方块,他需要从中挑出一些…

开源RAG主流框架有哪些?如何选型?

开源RAG主流框架有哪些?如何选型? 一、开源RAG框架全景图 (一)核心框架类型对比 类型典型工具技术特征适用场景传统RAGLangChain, Haystack线性流程(检索→生成)通用问答、知识库检索增强型RAGRAGFlow, AutoRAG支持重排序、多路召回优化高精度问答、复杂文档处理轻量级…

Java SE与Java EE

Java SE(Java 平台标准版) Java SE 是 Java 平台的核心,提供了 Java 语言的基础功能。它包含了 Java 开发工具包(JDK),其中有 Java 编译器(javac)、Java 虚拟机(JVM&…