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

网站栏目设计模板口碑营销是什么意思

网站栏目设计模板,口碑营销是什么意思,html编辑器软件,全屏 单页网站在SpringBoot中#xff0c;如果使用Scheduled注解来定义多个定时任务#xff0c;默认情况下这些任务将会被安排在一个单线程的调度器中执行。这意味着#xff0c;这些任务将会串行执行#xff0c;而不是并行执行。当一个任务正在执行时#xff0c;其他被触发的任务将会等待…在SpringBoot中如果使用Scheduled注解来定义多个定时任务默认情况下这些任务将会被安排在一个单线程的调度器中执行。这意味着这些任务将会串行执行而不是并行执行。当一个任务正在执行时其他被触发的任务将会等待当前任务完成后再开始执行这可能导致任务执行上的阻塞特别是当某个任务执行时间较长时可能会延迟后续任务的启动时间影响定时任务的准时性。 Scheduled 1.问题代码及测试结果2.定时任务实现并行2.1 使用自定义线程池添加类2.2 使用异步处理添加类和注解 3.总结 1.问题代码及测试结果 问题代码 Scheduled(cron */1 * * * * *)public void a() throws InterruptedException {log.info(A Start {}!, System.currentTimeMillis());Thread.sleep(2000);log.info(A End {}!, System.currentTimeMillis());}Scheduled(cron */1 * * * * *)public void b() {log.info(B Start {}!, System.currentTimeMillis());log.info(B End {}!, System.currentTimeMillis());}部分测试结果 15:38:29.001 [scheduling-1] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716968309001! 15:38:29.001 [scheduling-1] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716968309001! 15:38:29.001 [scheduling-1] INFO c.x.e.m.SchedulerTask - [a,44] - A Start 1716968309001!15:38:31.003 [scheduling-1] INFO c.x.e.m.SchedulerTask - [a,46] - A End 1716968311003! 15:38:31.003 [scheduling-1] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716968311003! 15:38:31.003 [scheduling-1] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716968311003!15:38:32.002 [scheduling-1] INFO c.x.e.m.SchedulerTask - [a,44] - A Start 1716968312002!15:38:34.003 [scheduling-1] INFO c.x.e.m.SchedulerTask - [a,46] - A End 1716968314003! 15:38:34.003 [scheduling-1] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716968314003! 15:38:34.003 [scheduling-1] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716968314003!结果分析 A和B是串行的。 2.定时任务实现并行 2.1 使用自定义线程池添加类 可以通过配置一个自定义的TaskScheduler或者ThreadPoolTaskScheduler来为Scheduled任务提供一个线程池从而允许多个任务并行执行。例如可以在配置类中定义一个ThreadPoolTaskScheduler Bean Configuration public class AsyncConfig {Beanpublic ThreadPoolTaskScheduler taskScheduler() {ThreadPoolTaskScheduler scheduler new ThreadPoolTaskScheduler();// 设置线程池大小scheduler.setPoolSize(10); scheduler.setThreadNamePrefix(my-scheduled-task-);return scheduler;} }并确保你的配置类被扫描到且在EnableScheduling注解的上下文中。 测试代码 Scheduled(cron */1 * * * * *)public void a() throws InterruptedException {log.info(A Start {}!, System.currentTimeMillis());Thread.sleep(2000);log.info(A End {}!, System.currentTimeMillis());}Scheduled(cron */1 * * * * *)public void b() {log.info(B Start {}!, System.currentTimeMillis());log.info(B End {}!, System.currentTimeMillis());}部分测试结果 15:16:18.003 [my-scheduled-task-2] INFO c.x.e.m.SchedulerTask - [a,44] - A Start 1716966978003! 15:16:18.003 [my-scheduled-task-1] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716966978003! 15:16:18.003 [my-scheduled-task-1] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716966978003!15:16:19.002 [my-scheduled-task-1] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716966979002! 15:16:19.002 [my-scheduled-task-1] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716966979002!15:16:20.004 [my-scheduled-task-2] INFO c.x.e.m.SchedulerTask - [a,46] - A End 1716966980004! 15:16:20.004 [my-scheduled-task-3] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716966980004! 15:16:20.004 [my-scheduled-task-3] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716966980004!15:16:21.003 [my-scheduled-task-1] INFO c.x.e.m.SchedulerTask - [a,44] - A Start 1716966981003! 15:16:21.003 [my-scheduled-task-4] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716966981003! 15:16:21.003 [my-scheduled-task-4] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716966981003!15:16:22.001 [my-scheduled-task-2] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716966982001! 15:16:22.001 [my-scheduled-task-2] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716966982001!15:16:23.004 [my-scheduled-task-1] INFO c.x.e.m.SchedulerTask - [a,46] - A End 1716966983004! 15:16:23.004 [my-scheduled-task-3] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716966983004! 15:16:23.004 [my-scheduled-task-3] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716966983004!结果分析 A和B是并行的A和A或者B和B是串行的。 2.2 使用异步处理添加类和注解 结合Async注解和EnableAsync可以使得每个Scheduled任务在独立的线程中异步执行。 首先需要在配置类中启用异步支持并配置一个线程池然后在每个定时任务方法上添加Async注解。 EnableAsync Configuration public class AsyncConfig {Beanpublic Executor taskExecutor() {ThreadPoolTaskExecutor executor new ThreadPoolTaskExecutor();executor.setCorePoolSize(10);executor.setMaxPoolSize(20);executor.setQueueCapacity(200);executor.setThreadNamePrefix(Async-);executor.initialize();return executor;} }测试代码 AsyncScheduled(cron */1 * * * * *)public void a() throws InterruptedException {log.info(A Start {}!, System.currentTimeMillis());Thread.sleep(2000);log.info(A End {}!, System.currentTimeMillis());}AsyncScheduled(cron */1 * * * * *)public void b() {log.info(B Start {}!, System.currentTimeMillis());log.info(B End {}!, System.currentTimeMillis());}部分测试结果 15:26:52.008 [Async-2] INFO c.x.e.m.SchedulerTask - [a,44] - A Start 1716967612008! 15:26:52.008 [Async-1] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716967612008! 15:26:52.009 [Async-1] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716967612009!15:26:53.002 [Async-4] INFO c.x.e.m.SchedulerTask - [a,44] - A Start 1716967613002! 15:26:53.002 [Async-3] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716967613002! 15:26:53.002 [Async-3] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716967613002!15:26:54.001 [Async-6] INFO c.x.e.m.SchedulerTask - [a,44] - A Start 1716967614001! 15:26:54.001 [Async-5] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716967614001! 15:26:54.001 [Async-5] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716967614001! 15:26:54.010 [Async-2] INFO c.x.e.m.SchedulerTask - [a,46] - A End 1716967614010!15:26:55.002 [Async-8] INFO c.x.e.m.SchedulerTask - [a,44] - A Start 1716967615002! 15:26:55.002 [Async-7] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716967615002! 15:26:55.002 [Async-7] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716967615002! 15:26:55.002 [Async-4] INFO c.x.e.m.SchedulerTask - [a,46] - A End 1716967615002!15:26:56.001 [Async-10] INFO c.x.e.m.SchedulerTask - [a,44] - A Start 1716967616001! 15:26:56.001 [Async-9] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716967616001! 15:26:56.001 [Async-9] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716967616001! 15:26:56.002 [Async-6] INFO c.x.e.m.SchedulerTask - [a,46] - A End 1716967616002!15:26:57.001 [Async-3] INFO c.x.e.m.SchedulerTask - [a,44] - A Start 1716967617001! 15:26:57.001 [Async-1] INFO c.x.e.m.SchedulerTask - [b,52] - B Start 1716967617001! 15:26:57.001 [Async-1] INFO c.x.e.m.SchedulerTask - [b,53] - B End 1716967617001! 15:26:57.002 [Async-8] INFO c.x.e.m.SchedulerTask - [a,46] - A End 1716967617002!测试结果分析 A和B是并行的A和A或者B和B也是并行的。 3.总结 如有错误请小伙伴儿们不吝赐教。 定时任务有不同的需求使用串行还是并行要结合业务进行选择。
http://www.pierceye.com/news/896274/

相关文章:

  • 做移动网站点击软件cnzz网站建设
  • 高质量网站外链建设大揭秘做网站之前需要准备什么条件
  • 睢宁做网站百度一下做网站
  • 做国外购物网站国家高职示范校建设网站
  • 网站建设福州公司山西省大同市网站建设公司
  • 浙江网站建设推荐wordpress 增加小工具
  • 个人网站是商业的吗北京网站建设设计
  • 手机网站收费怎么停止网站
  • 网站建设 金疙瘩计划杭州小程序制作公司排行榜
  • 德泰诺网站建设软件著作权登记证书
  • 商标设计网页seo外包公司兴田德润官方地址
  • 网站开发人员岗位成功营销案例分享
  • 赤峰做网站的公司湘潭哪里做网站
  • 免费自助建站郑州官网seo费用
  • 称心的常州网站建设wordpress怎么用两个主题
  • 建设银行北京分行网站做视频网站用什么服务器配置
  • 网站备案流程实名认证医疗网站建设资讯
  • 一个做问卷调查的网站好wordpress七比2
  • 西双版纳网站制作公司临沂企业网站建站模板
  • 培训做网站国内适合个人做外贸的网站有哪些
  • 我想卖自己做的鞋子 上哪个网站好中信银行网站怎么做的怎么烂
  • 在线网站建设工程标准godaddy 上传网站
  • 营销型网站方案ppt模板手机建站平台微点
  • 网站信息备案管理系统电商网页精品欣赏网站
  • 推广公司让实名认证怎么办系统优化设置
  • 公司网站 正式上线如何创建一个软件
  • app备案查询网站上海缪斯设计公司地址
  • 旅游小网站怎样做精不做全组建网站 多少钱
  • 天津城乡住房建设厅网站网站建设观点
  • 电子商务网站建设的认识tk网站免费