建设课程网站/竞价sem托管

建设课程网站,竞价sem托管,做微信网站多少钱,wordpress links插件一、核心参数解析 线程池(ThreadPoolExecutor)的性能取决于以下关键参数: 参数说明corePoolSize核心线程数,即使空闲也不会被回收maximumPoolSize最大线程数,当队列满且核心线程忙时创建新线程workQueue任务队列&…

胶片质感

一、核心参数解析

线程池(ThreadPoolExecutor)的性能取决于以下关键参数:

参数说明
corePoolSize核心线程数,即使空闲也不会被回收
maximumPoolSize最大线程数,当队列满且核心线程忙时创建新线程
workQueue任务队列,存储等待执行的任务
keepAliveTime非核心线程空闲存活时间(单位由TimeUnit指定)
RejectedExecutionHandler拒绝策略,当队列和线程池满时的处理方式

二、优化策略
1. 任务类型分析
  • CPU 密集型任务(如计算、数据处理):

    // 建议参数:
    int corePoolSize = Runtime.getRuntime().availableProcessors() + 1;
    int maxPoolSize = corePoolSize;
    
  • I/O 密集型任务(如网络请求、DB 操作):

    // 建议参数:
    int corePoolSize = Runtime.getRuntime().availableProcessors() * 2;
    int maxPoolSize = corePoolSize * 2; // 或更高,需压测验证
    
2. 队列选择策略
队列类型适用场景配置示例
SynchronousQueue高吞吐场景,直接传递任务new SynchronousQueue<>()
ArrayBlockingQueue控制队列长度,防止资源耗尽new ArrayBlockingQueue<>(200)
LinkedBlockingQueue无界队列(慎用,可能导致 OOM)new LinkedBlockingQueue<>()
PriorityBlockingQueue需要任务优先级调度new PriorityBlockingQueue<>(100, comparator)
3. 拒绝策略选择
策略行为适用场景
AbortPolicy(默认)抛出 RejectedExecutionException需严格保证任务不丢失的场景
CallerRunsPolicy由提交任务的线程直接执行保证任务不丢弃,但可能阻塞主线程
DiscardPolicy静默丢弃新任务允许任务丢失的非关键场景
DiscardOldestPolicy丢弃队列中最旧的任务并重试提交允许丢弃旧任务的场景
4. 动态调参(适用于 JDK 21+)

通过 ThreadPoolExecutor 的扩展方法实时调整参数:

executor.setCorePoolSize(20);      // 动态调整核心线程数
executor.setMaximumPoolSize(50);   // 动态调整最大线程数
executor.setKeepAliveTime(30, TimeUnit.SECONDS); // 调整线程存活时间

三、优化工具与验证
1. 监控指标
指标监控工具健康阈值
活跃线程数executor.getActiveCount()≤ maximumPoolSize
队列积压任务数executor.getQueue().size()≤ 队列容量的 80%
拒绝任务数自定义 RejectedExecutionHandler 统计报警阈值:每分钟 > 10 次
2. 压测工具
  • JMeter:模拟高并发请求,观察线程池表现。
  • 自定义测试代码
    // 模拟任务提交
    IntStream.range(0, 1000).parallel().forEach(i -> {executor.submit(() -> {// 模拟任务处理Thread.sleep(100);});
    });
    
3. 日志分析

在拒绝策略中记录被拒任务:

ThreadPoolExecutor executor = new ThreadPoolExecutor(corePoolSize, maxPoolSize, keepAliveTime, TimeUnit.SECONDS,new ArrayBlockingQueue<>(100),new ThreadPoolExecutor.AbortPolicy() {@Overridepublic void rejectedExecution(Runnable r, ThreadPoolExecutor e) {// 记录任务信息logger.warn("Task rejected: {}", r.toString());super.rejectedExecution(r, e);}}
);

四、典型场景配置示例
场景 1:Web 服务请求处理
  • 任务类型:I/O 密集型(HTTP API 调用)
  • 配置
    int cores = Runtime.getRuntime().availableProcessors();
    ThreadPoolExecutor executor = new ThreadPoolExecutor(cores * 2,          // corePoolSizecores * 4,          // maxPoolSize60, TimeUnit.SECONDS,new ArrayBlockingQueue<>(200), // 控制队列长度new ThreadPoolExecutor.CallerRunsPolicy() // 拒绝策略
    );
    
场景 2:批量数据处理
  • 任务类型:CPU 密集型(数据计算)
  • 配置
    int cores = Runtime.getRuntime().availableProcessors();
    ThreadPoolExecutor executor = new ThreadPoolExecutor(cores + 1,          // corePoolSizecores + 1,          // maxPoolSize0, TimeUnit.MILLISECONDS,new LinkedBlockingQueue<>(), // 无界队列new ThreadPoolExecutor.AbortPolicy()
    );
    

五、高级优化技巧
1. 线程池隔离

为不同业务使用独立线程池,避免相互影响:

// 订单处理线程池
ThreadPoolExecutor orderExecutor = ...;
// 支付处理线程池
ThreadPoolExecutor paymentExecutor = ...;
2. 基于 Spring 的配置

在 Spring Boot 中动态配置线程池:

# application.yml
thread-pool:core-size: 20max-size: 50queue-capacity: 1000keep-alive: 60s
@Configuration
public class ThreadPoolConfig {@Beanpublic ThreadPoolExecutor threadPoolExecutor(@Value("${thread-pool.core-size}") int coreSize,@Value("${thread-pool.max-size}") int maxSize,@Value("${thread-pool.queue-capacity}") int queueCapacity,@Value("${thread-pool.keep-alive}") Duration keepAlive) {return new ThreadPoolExecutor(coreSize, maxSize,keepAlive.toSeconds(), TimeUnit.SECONDS,new ArrayBlockingQueue<>(queueCapacity),new CustomRejectedPolicy());}
}
3. 线程池预热

启动时提前创建核心线程:

executor.prestartAllCoreThreads(); // 立即初始化所有核心线程

六、总结
优化维度关键点
核心线程数根据任务类型(CPU/I/O 密集型)设置,并通过压测验证
队列容量控制队列长度避免 OOM,结合拒绝策略使用
拒绝策略根据业务容忍度选择丢弃、降级或排队策略
动态调整运行时监控并调整参数,适应流量变化
监控与日志实时跟踪线程池状态,记录拒绝任务便于问题排查

最终建议

  • 优先使用有界队列和合理的拒绝策略,防止系统崩溃。
  • 通过 监控 + 压测 + 动态调整 的组合策略持续优化。
  • 在高并发场景下,结合 熔断降级 机制(如 Hystrix 或 Sentinel)保护线程池。

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

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

相关文章

记一次线上环境JAR冲突导致程序报错org.springframework.web.util.NestedServletException

一、问题描述 有个文件导入功能&#xff0c;用到了Hutool 的加密解密功能&#xff0c;本地运行完全可以&#xff0c;但是线上报错&#xff1a;“org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.NoClassDefFou…

2.基于多线程的TCP服务器实现

目录 1. 简单分析之前的代码 2. 多线程服务器设计 2.1 C11线程的基本使用 2.2 服务器主体逻辑 3. 错误处理的封装 4. 完整的代码实现 客户端代码&#xff08;client.cpp&#xff09; 服务器代码&#xff08;server.cpp&#xff09; 5. 运行方式 在我们预想中&#xff…

从零构建大语言模型全栈开发指南:第二部分:模型架构设计与实现-2.2.3实战案例:在笔记本电脑上运行轻量级LLM

👉 点击关注不迷路 👉 点击关注不迷路 👉 点击关注不迷路 文章大纲 实战案例:在笔记本电脑上运行轻量级LLM2.2.3 模型架构设计与实现1. 环境与工具准备1.1 硬件要求1.2 软件栈选择2. 轻量级模型架构设计2.1 模型参数配置2.2 关键技术优化3. 实战流程3.1 数据准备流程3.2…

工业软件的破局与重构:从技术依赖到自主创新的未来路径

工业软件作为现代工业的“神经与大脑”&#xff0c;不仅是制造业数字化转型的核心工具&#xff0c;更是国家工业竞争力的战略制高点。近年来&#xff0c;中国工业软件市场在政策驱动与技术迭代中迅猛发展&#xff0c;但核心技术受制于人的困境仍待突破。如何实现从“跟跑”到“…

歌曲缓存相关功能

1. 核心组件 MusicCacheManager (音乐缓存管理器) 单例模式&#xff1a;确保全局只有一个实例&#xff0c;方便管理。 private static var instance: MusicCacheManager?static func shared() -> MusicCacheManager {if instance nil {instance MusicCacheManager()}ret…

阿里开源的免费数据集成工具——DataX

企业里真实的数据流转是什么样子的呢&#xff1f; 左侧描述了一个企业真实的样子&#xff0c;我们总是需要把数据从一个地方搬到另一个地方&#xff0c;最后就是搬来搬去搬成了一张张解不开的网。 右侧则表达了使用DataX为中心实现数据的同步。 什么是DataX DataX是一个异构…

26考研——图_图的遍历(6)

408答疑 文章目录 三、图的遍历图的遍历概述图的遍历算法的重要性图的遍历与树的遍历的区别图的遍历过程中的注意事项避免重复访问遍历算法的分类遍历结果的不唯一性 广度优先搜索广度优先搜索&#xff08;BFS&#xff09;概述BFS 的特点广度优先遍历的过程示例图遍历过程 BFS …

前端解决方案:实现网页截图并导出PDF功能

前端解决方案&#xff1a;实现网页截图并导出PDF功能 在前端开发中&#xff0c;我们经常会遇到需要将网页内容导出为PDF的需求。本文将以一个准考证预览和导出的例子&#xff0c;带你一步步实现这个功能。我们会处理包括跨域图片、Canvas绘图、PDF生成等多个技术要点。 一、基…

【MySQL】表操作

表操作 一、创建表 1、语句2、语句介绍3、注意事项4、介绍5、示例 二、查看表结构 1、语句2、介绍3、返回的信息4、示例 三、添加字段 1、语句2、语句介绍3、示例 四、修改 1、语句2、语句介绍3、示例 五、删除 1、语句2、示例 六、修改表名 1、语句2、语句介绍3、示例 七、删…

响应“一机两用”政策 ,实现政务外网安全

在数字化办公的浪潮下&#xff0c;企业与政务机构面临着既要保障数据安全&#xff0c;又要高效访问互联网的双重需求。“一机两用”成为解决这一难题的关键。 政策驱动&#xff0c;需求迫切 随着《网络安全法》《数据安全法》等法律法规的相继出台&#xff0c;网络安全防护的要…

文生图语义识别插件使用(controlnet)

1. 插件下载(github) https://github.com/Mikubill/sd-webui-controlnet https://github.com/lllyasviel/ControlNet2. 模型下载(hugging face) https://github.com/Mikubill/sd-webui-controlnet/wiki/Model-download https://huggingface.co/bdsqlsz/qinglong_controlnet-l…

学者观察 | web3.0产业发展与技术融合——北京大学研究员肖臻

导语 肖臻老师认为在未来很长一段时间内&#xff0c;Web 3.0将和现在的Web 2.0共存。Web 3.0和人工智能&#xff08;AI&#xff09;的融合发展前景非常广阔&#xff0c;Web 3.0致力于打造去中心化的互联网生态系统&#xff0c;赋予用户更大的数据所有权和控制权&#xff0c;而…

【模型压缩+推理加速】知识蒸馏综述解读

知识蒸馏综述解读 论文&#xff1a; https://arxiv.org/abs/2006.05525 最近Deepseek R1的技术报告中&#xff0c;训练部分提到使用了知识蒸馏&#xff0c;就像系统性的看看蒸馏算法的原理。看了很多的博客&#xff0c;很多都没有详细把知识蒸馏系统的讲清楚。我们还是读一下…

vivo 湖仓架构的性能提升之旅

作者&#xff1a;郭小龙 vivo互联网 大数据高级研发工程师 导读&#xff1a;本文整理自 vivo互联网 大数据高级研发工程师 郭小龙 在 StarRocks 年度峰会上的分享&#xff0c;聚焦 vivo 大数据多维分析面临的挑战、StarRocks 落地方案及应用收益。 在 即席分析 场景&#xff0c…

2025年如何避免使用验证码求解器时被IP封禁

引言 2025年&#xff0c;验证码求解器已成为自动化网络抓取和其他在线流程的关键工具。然而&#xff0c;自动化用户面临的一个常见挑战是IP封禁。当网站检测到自动化活动时&#xff0c;通常会阻止发出请求的IP地址&#xff0c;导致验证码挑战无法解决。本文将探讨使用验证码求…

JVM详解(包括JVM内存模型与GC垃圾回收)

&#x1f4d6;前言&#xff1a; 学会使用Java对于一个程序员是远远不够的。Java语法的掌握只是一部分&#xff0c;另一部分就是需要掌握Java内部的工作原理&#xff0c;从编译到运行&#xff0c;到底是谁在帮我们完成工作的&#xff1f; 接下来着重对Java虚拟机&#xff0c;也就…

【无标题】大亚湾文化体育场多美啊。

请推荐一些常用并且免费的&#xff0c;可直接在线运行【Python】代码的平台并列出对应网址 好的&#xff0c;用户想让我推荐一些常用且免费的、可以直接在线运行Python代码的平台&#xff0c;并且需要列出对应的网址。我需要先回想一下自己知道的在线Python运行环境&#xff0…

权限提升—Windows权限提升土豆家族溢出漏洞通杀全系

前言 OK&#xff0c;Java安全更新不下去了&#xff0c;实在是太难啦啊&#xff0c;想起来提权这一块没怎么更新过&#xff0c;接下来都主要是更新提权这一块的文章了&#xff0c;Java安全的话以后有耐心再搞了。 手动提权 今天主要是讲这个手动的提权&#xff0c;手动提权相…

python --face_recognition(人脸识别,检测,特征提取,绘制鼻子,眼睛,嘴巴,眉毛)/活体检测

dlib 安装方法 之前博文 https://blog.csdn.net/weixin_44634704/article/details/141332644 环境: python3.8 opencv-python4.11.0.86 face_recognition1.3.0 dlib19.24.6人脸检测 import cv2 import face_recognition# 读取人脸图片 img cv2.imread(r"C:\Users\123\…

禾赛盈利了,但激光雷达没有胜利

还远没有到激光雷达党欢呼的时候。 3月&#xff0c;随着禾赛科技公布2024年报&#xff0c;全世界第一家也是唯一一家实现全年盈利的激光雷达上市公司诞生&#xff0c;为了这个盈利目标&#xff0c;禾赛科技奋斗了十年。 但极大的出货量和不高的盈利水平&#xff0c;让禾赛科技…