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

做新闻的网站怎样赚钱旺道seo优化软件怎么用

做新闻的网站怎样赚钱,旺道seo优化软件怎么用,乐清日报,安卓程序开发用什么软件1. 核心机制 Spring Boot 通过 TaskExecutor 和 Async 注解支持多线程编程,结合线程池管理,有效提升应用性能。核心组件包括: EnableAsync:启用异步任务支持。 Async:标记方法为异步执行。 ThreadPoolTaskExecutor&…
1. 核心机制

Spring Boot 通过 TaskExecutor 和 @Async 注解支持多线程编程,结合线程池管理,有效提升应用性能。核心组件包括:

  • @EnableAsync:启用异步任务支持。

  • @Async:标记方法为异步执行。

  • ThreadPoolTaskExecutor:线程池实现,替代默认的 SimpleAsyncTaskExecutor


2. 基础配置与使用
(1) 启用异步支持

在启动类或配置类添加 @EnableAsync

@SpringBootApplication
@EnableAsync
public class MyApplication {public static void main(String[] args) {SpringApplication.run(MyApplication.class, args);}
}
(2) 定义线程池

通过 ThreadPoolTaskExecutor 配置线程池:

@Configuration
public class AsyncConfig {@Bean("taskExecutor")public Executor taskExecutor() {ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();executor.setCorePoolSize(10);          // 核心线程数executor.setMaxPoolSize(20);           // 最大线程数executor.setQueueCapacity(200);        // 队列容量executor.setThreadNamePrefix("Async-");// 线程名前缀executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy()); // 拒绝策略executor.initialize();return executor;}
}
(3) 使用 @Async 执行异步方法

在方法上添加 @Async 并指定线程池:

@Service
public class MyService {@Async("taskExecutor")public void asyncTask() {// 异步执行的业务逻辑System.out.println("当前线程:" + Thread.currentThread().getName());}
}

3. 处理异步返回值
(1) 返回 CompletableFuture
@Async("taskExecutor")
public CompletableFuture<String> asyncMethodWithReturn() {return CompletableFuture.completedFuture("任务完成");
}// 调用示例
CompletableFuture<String> future = myService.asyncMethodWithReturn();
future.thenAccept(result -> System.out.println("结果: " + result));
(2) 返回 Future(旧版兼容)
@Async("taskExecutor")
public Future<String> legacyAsyncMethod() {return new AsyncResult<>("任务完成");
}// 调用示例
Future<String> future = myService.legacyAsyncMethod();
String result = future.get(); // 阻塞获取结果

4. 异常处理
(1) 自定义异常处理器

实现 AsyncUncaughtExceptionHandler

@Configuration
public class AsyncExceptionConfig implements AsyncConfigurer {@Overridepublic AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() {return (ex, method, params) -> {System.err.println("异步方法异常: " + method.getName());ex.printStackTrace();};}
}
(2) 捕获特定异常

在异步方法内部使用 try-catch

@Async("taskExecutor")
public void asyncTaskWithTryCatch() {try {// 可能抛出异常的代码} catch (Exception e) {// 处理异常}
}

5. 事务管理

异步方法默认不继承调用者的事务上下文,需显式配置:

@Async("taskExecutor")
@Transactional(propagation = Propagation.REQUIRES_NEW)
public void asyncTransactionalTask() {// 需要事务管理的数据库操作
}

6. 监控与调优
(1) 监控线程池状态

通过 ThreadPoolTaskExecutor 获取运行时指标:

@Autowired
private ThreadPoolTaskExecutor taskExecutor;public void monitorThreadPool() {System.out.println("活跃线程数: " + taskExecutor.getActiveCount());System.out.println("队列大小: " + taskExecutor.getThreadPoolExecutor().getQueue().size());
}
(2) 集成 Actuator

在 application.properties 中启用监控端点:

management.endpoints.web.exposure.include=metrics
management.endpoint.metrics.enabled=true

访问 http://localhost:8080/actuator/metrics/executor.pool.size 查看线程池指标。


7. 高级场景
(1) 动态调整线程池参数

结合配置中心(如 Apollo、Nacos)动态刷新线程池配置:

@RefreshScope
@Bean("taskExecutor")
public Executor taskExecutor(@Value("${thread.pool.core-size:10}") int coreSize,@Value("${thread.pool.max-size:20}") int maxSize
) {ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();executor.setCorePoolSize(coreSize);executor.setMaxPoolSize(maxSize);// 其他配置return executor;
}
(2) 优雅关闭线程池

实现 DisposableBean 确保应用关闭时释放资源:

@Bean("taskExecutor")
public Executor taskExecutor() {ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();// ... 配置参数return executor;
}@PreDestroy
public void destroy() {taskExecutor.shutdown();try {if (!taskExecutor.awaitTermination(60, TimeUnit.SECONDS)) {taskExecutor.shutdownNow();}} catch (InterruptedException e) {taskExecutor.shutdownNow();Thread.currentThread().interrupt();}
}

8. 典型应用场景
  • 批量数据处理:并行处理 CSV/Excel 导入导出。

  • 异步通知:发送短信、邮件、消息队列。

  • 耗时操作:生成报表、调用外部 API。

  • 高并发请求:Web 请求的异步响应(如 Spring WebFlux 结合)。


总结

通过 @Async 和线程池配置,Spring Boot 可高效实现多线程编程。关键步骤包括:

  1. 启用异步支持@EnableAsync

  2. 定制线程池:配置 ThreadPoolTaskExecutor

  3. 异常与事务管理:处理异步任务中的错误和事务边界。

  4. 监控与调优:利用 Actuator 和动态配置优化性能。

最佳实践:避免在异步方法中处理大量同步阻塞操作,合理设置线程池参数,结合监控工具持续优化。

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

相关文章:

  • 多用户网站管理系统站长工具seo综合查询广告
  • 常州网站开发培训体系包括四大体系
  • 网站怎么做认证南宁哪里有seo推广厂家
  • 爱站关键词广州网络推广
  • 做易购网站阿里域名购买网站
  • 龙岗地区做网站公司在线生成html网页
  • 做公务员考试哪个网站好优化营商环境建议
  • 大型网站系统百度一下你就知道了百度
  • 代理网页是干什么的西青seo
  • 网站营销单页怎么设计方案百度电话怎么转人工
  • 网络规划工程师seo优化个人博客
  • 数字营销技术应用网站什么优化
  • 企业网站seo点击软件网站定制的公司
  • 医疗网站备案免费域名解析平台
  • 做个产品网站要多少钱推广赚钱的微信小程序
  • 南宁住房和城乡建设委员会网站搜索引擎调价平台哪个好
  • 做宣传 为什么要做网站那优化网站关键词的技巧
  • 做网站需要购买什么seo交互论坛
  • 网站制作说明书永久免费的建站系统有哪些
  • 苏州相城网站建设搜索优化软件
  • wordpress 登录页面变了高平网站优化公司
  • 企业网站源代码免费下载农产品营销方案
  • 淘宝网站优化实例网络营销推广主要做什么
  • 长沙交互网站设计服务商关键词挖掘长尾词
  • 网站建立不安全怎么取消友情链接教程
  • 零基础学前端要多久才能成手优化疫情防控 这些措施你应该知道
  • 公司网站在百度搜不到上海抖音seo
  • 孝感网站建设孝感seo优化的网站
  • 湖北建设网站首页国内销售平台有哪些
  • 国外自助建站免费建站平台市场推广方案和思路