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

做网站还是做公众号搜客通

做网站还是做公众号,搜客通,网站内置多语言,金华seo快速排名接上篇文章, 拿SpringBoot举个例 1.1 默认线程池的隐患 Spring Boot的Async默认使用SimpleAsyncTaskExecutor(无复用线程),频繁创建/销毁线程易引发性能问题。 1.2 自定义线程池配置 Configuration EnableAsync public class A…

接上篇文章, 拿SpringBoot举个例

1.1 默认线程池的隐患
Spring Boot的@Async默认使用SimpleAsyncTaskExecutor(无复用线程),频繁创建/销毁线程易引发性能问题。
1.2 自定义线程池配置
@Configuration
@EnableAsync
public class AsyncConfig implements AsyncConfigurer {@Overridepublic Executor getAsyncExecutor() {ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();executor.setCorePoolSize(10);          // 核心线程数=CPU核心数×2executor.setMaxPoolSize(20);           // 突发流量缓冲executor.setQueueCapacity(100);        // 根据业务容忍延迟调整executor.setThreadNamePrefix("Async-");executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());executor.initialize();return executor;}
}// 使用示例
@Service
public class ReportService {@Async  // 指定使用自定义线程池public CompletableFuture<Report> generateReportAsync(Long id) {// 模拟耗时操作Thread.sleep(2000);return CompletableFuture.completedFuture(new Report(id, "Done"));}
}
1.3 线程池监控(Micrometer + Prometheus)
# application.yml
management:endpoints:web:exposure:include: "metrics,prometheus"metrics:tags:application: ${spring.application.name}
@Bean
public MeterBinder threadPoolMetrics(ThreadPoolTaskExecutor executor) {return registry -> {Gauge.builder("thread.pool.active", executor, ThreadPoolTaskExecutor::getActiveCount).description("当前活跃线程数").register(registry);Gauge.builder("thread.pool.queue.size", executor, e -> e.getThreadPoolExecutor().getQueue().size()).description("任务队列长度").register(registry);};
}

通过http://localhost:8080/actuator/prometheus可获取实时指标。

二、Spring Boot内存泄漏排查:一个真实OOM案例

2.1 故障现象

  • 应用运行24小时后出现java.lang.OutOfMemoryError: Java heap space

  • GC日志显示老年代占用持续增长

2.2 诊断步骤
步骤1:生成堆转储文件

# 在应用启动命令中添加
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/tmp/heapdump.hprof

步骤2:使用MAT分析

  1. 打开heapdump.hprof,选择Dominator Tree

  2. 发现ConcurrentHashMap$Node[]占用80%内存

  3. 查看引用链,定位到缓存工具类未清理过期数据

步骤3:代码修复

// 错误代码:静态Map无限增长
public class CacheManager {private static Map<String, Object> cache = new ConcurrentHashMap<>();public static void put(String key, Object value) {cache.put(key, value);}
}// 修复:引入Guava Cache自动过期
public class CacheManager {private static LoadingCache<String, Object> cache = CacheBuilder.newBuilder().maximumSize(1000).expireAfterWrite(10, TimeUnit.MINUTES).build(new CacheLoader<>() {@Overridepublic Object load(String key) {return loadFromDB(key);}});
}
三、Spring Data JPA连接池优化(HikariCP实战)

3.1 默认配置风险
Spring Boot默认使用HikariCP,但以下参数需针对性调整:

spring:datasource:hikari:maximum-pool-size: 20          # 默认10,根据DB并发能力调整connection-timeout: 3000       # 获取连接超时时间(ms)idle-timeout: 600000           # 空闲连接存活时间(默认10分钟)max-lifetime: 1800000          # 连接最大生命周期(默认30分钟)leak-detection-threshold: 5000 # 连接泄漏检测阈值(生产环境建议开启)

3.2 监控集成

@Bean
public MeterBinder hikariMetrics(HikariDataSource dataSource) {return registry -> {HikariPoolMXBean pool = dataSource.getHikariPoolMXBean();Gauge.builder("db.pool.active", pool::getActiveConnections).register(registry);Gauge.builder("db.pool.idle", pool::getIdleConnections).register(registry);Gauge.builder("db.pool.total", pool::getTotalConnections).register(registry);};
}
四、生产级Spring Boot JVM参数模板

4.1 基础参数(JDK11+)

java -jar your-app.jar \-Xms2g -Xmx2g                 # 堆内存固定,避免动态调整开销 \-XX:MaxMetaspaceSize=256m     # 防止元空间膨胀 \-XX:+UseG1GC                  # 低延迟垃圾回收器 \-XX:MaxGCPauseMillis=200      # 目标最大停顿时间 \-Xlog:gc*,gc+heap=debug:file=gc.log:time,uptime:filecount=5,filesize=100m \-Dspring.profiles.active=prod

4.2 容器环境适配(Dfile.encoding警告修复)

FROM eclipse-temurin:17-jdk
ENV LANG C.UTF-8
ENV JAVA_OPTS="-Dfile.encoding=UTF-8"
五、实战:利用Arthas在线诊断Spring Boot应用

5.1 安装与附加进程

curl -O https://arthas.aliyun.com/arthas-boot.jar
java -jar arthas-boot.jar  # 选择目标进程

5.2 常用命令

# 1. 查看实时线程状态
thread -n 3                 # 显示CPU占用最高的3个线程# 2. 监控方法调用耗时
watch com.example.service.*Service * '{params, returnObj}' -x 3 # 3. 动态修改日志级别(无需重启)
logger --name ROOT --level debug

 

http://www.dtcms.com/wzjs/333610.html

相关文章:

  • 国际贸易网站开发优化大师官方免费
  • 中国基建人才网百度seo关键词优化电话
  • 做网站广州深圳外贸网络推广
  • 天津基础设施建设seo推广学院
  • 做网站需要什么软件网络建站公司
  • 中文编程江门seo推广公司
  • 贵阳网站建设方案百度指数的使用方法
  • 专门做颜料的网站武汉十大技能培训机构
  • 无为县住房建设局网站首页seo代码优化工具
  • wordpress安装到子目录湖南正规关键词优化
  • 科协网站建设的意见源码网站
  • 免费做翻页页面的网站百度官方入口
  • 郑州做网站建设公司排名百度推广天天打骚扰电话
  • 网站导航条和表格怎么做app注册接单平台
  • 做电影网站如何推广方案外包网络推广公司
  • 上海h5网站建设市场营销推广策划方案
  • 营销软件站网络营销的宏观环境
  • 淘宝网站维护武汉新一轮疫情
  • 国际财经新闻seo关键词软件
  • 用手机做网站的流程上海seo推广
  • 腾讯云做网站教程qq群推广拉人
  • 精彩网站制作站长统计官方网站
  • html个人网站源码淘宝推广平台有哪些
  • 仓储网站模板百度云登录首页
  • 网站空间需要多大武汉seo网站优化
  • 建e网官网效果图泰安网站优化公司
  • 快速网站推广工具广告网络营销
  • 外贸网站建设步骤baidu 百度一下
  • 张家港网站设计优化seo的主要分析工具
  • 深圳自适应网站制作添加友情链接的技巧