当前位置: 首页 > wzjs >正文

中国wix网站制作公司上海百度推广代理商

中国wix网站制作公司,上海百度推广代理商,网站建设是做什么的,网站建设代码好难啊一、核心参数解析 线程池(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.dtcms.com/wzjs/459515.html

相关文章:

  • 网站建设是 口号seo中国是什么
  • 洪湖网站建设发稿软文公司
  • 网站建设和程序开发哪个好东莞营销网站建设优化
  • 怎样才能访问没有备案的网站高端网站定制
  • 杭州下城区建设局网站如何进行搜索引擎营销
  • 北京网站建设+知乎属于网络营销特点的是
  • 网站关键词推广优化软文营销的成功案例
  • 建设工程教育网建设工程类的考试辅导网站徐州百度快照优化
  • 一般做音响的有哪些网站推广赚钱的软件排行
  • 网站必须做电子标识信息新闻摘抄
  • 网站标签怎么做百度客服在线咨询人工服务
  • seo针对网站做策划seo是什么缩写
  • 网站建设 上海网站seo综合查询站长工具
  • 宝塔搭建本地网站个人博客网站怎么做
  • 专门做淘宝特价的网站seo的理解
  • 长安网站建设网络营销的内涵
  • 网站建设岗位茂名百度seo公司
  • wordpress网站弹出垃圾广告最新免费网站收录提交入口
  • 网站开发建设专业短视频关键词优化
  • 手机网站建设语言app拉新推广一手接单平台
  • 做网站推广邢台什么叫seo
  • 如何建网站快捷方式近两年网络营销成功案例
  • 怎么用支付宝做发卡网站手机网站怎么优化关键词
  • 网站建设需要什么设备搜索推广公司
  • 软件网站建设长春网站建设公司哪家好
  • wordpress 创建自定义面板类文件刷关键词优化排名
  • 个人网站设计论文摘要安徽网络优化公司
  • 如何做色流量网站网站搜索引擎
  • 地方门户南宁优化网站网络服务
  • 北京网站制作网络营销策划书的结构