免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5173 | 回复: 0
打印 上一主题 下一主题

java B2B2C Springboot仿淘宝电子商城系统-Spring Cloud Task [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2019-01-18 09:45 |只看该作者 |倒序浏览
概述
Spring Cloud Task的目标是为Spring Boot应用程序提供创建短运行期微服务的功能。在Spring Cloud Task中,我们可以灵活地动态运行任何任务,按需分配资源并在任务完成后检索结果。Tasks是Spring Cloud Data Flow中的一个基础项目,允许用户将几乎任何Spring Boot应用程序作为一个短期任务执行。


Spring Cloud Task的生命周期

现代的云平台都是围绕着长生命周期的服务而设计的,如web应用,一经启用,除非手动去重启应用,否则就会没有终点的持续运行。虽然大多数平台都有方法在不重启应用的情况下,将服务的生命周期推向终点,但每个服务的处理结果难以以可重用的方式来维护。Spring Cloud Task可以在平台环境中执行短生命周期的应用,并记录这些应用的结果,经由通过消息通知的机制来集成各个tasks。通过这特性就可以实现让短生命周期的应用像长生命周期的应用一样组成微服务架构。

Spring Task Cloud的方式对现代的云环境是非常有用的,但它也在部署应用方面带来新问题。如使用调度器(如corn)来执行Spring Boot应用时,如何在应用结束后监控到其执行结果?

Spring Cloud Task采用的方法是,将Spring Boot应用分为开始、结束、以及正在运行等状态。如批处理任务就是一个清晰的短生命周期应用,Spring Cloud Task会监控指定任务的所有生命周期事件。
生命周期是一个任务task实例运行的全过程,也是一个被配置为task的Spring Boot应用被执行的过程(通过 添加@EnableTask注解配置)。
在task刚刚开始运行时(CommandLineRunner或ApplicationRunner及其子类的实例被执行之前)TaskRespository会创建一条task纪录并将其标记为start状态。start事件由spring框架的SmartLifecycle#start触发。开始事件被触发说明了系统已经做好了执行CommandLineRunner或ApplicationRunner及其子类的实例的准备。

任务纪录只有在 ApplicationContext被成功启动后才会被纪录。如果ApplicationContext没有被成功启动,那么task的相关信息也不会被纪录。

当Spring Boot应用的所有*Runner#run接口都被调用后,或者在ApplicationContext发生了失败(由ApplicationFailedEvent来表现),任务仓库中此任务的执行结果都会被更新。

task 完成之后(*Runner#run方法被执行完)默认情况下会被关闭ApplicationContext。这个特性可以在配置文件中设置spring.cloud.task.closecontext_enable属性为false来更改。

其实现原理如下面代码所示:

  1.     public class TaskLifecycleListener{

  2.         ...



  3.         /**

  4.          * 在发生task相关的事件后,会自动调用这个方法

  5.          * Utilizes {@link ApplicationEvent}s to determine the start, end, and failure of a

  6.          * task.  Specifically:

  7.          * <ul>

  8.          *     <li>{@link ContextRefreshedEvent} - Start of a task</li>

  9.          *     <li>{@link ApplicationReadyEvent} - Successful end of a task</li>

  10.          *     <li>{@link ApplicationFailedEvent} - Failure of a task</li>

  11.          * </ul>

  12.          *

  13.          * @param applicationEvent The application being listened for.

  14.          */

  15.         @Override

  16.         public void onApplicationEvent(ApplicationEvent applicationEvent) {

  17.             if(applicationEvent instanceof ApplicationFailedEvent) {

  18.                 this.applicationFailedEvent = (ApplicationFailedEvent) applicationEvent;

  19.                 doTaskEnd();

  20.             }

  21.             else if(applicationEvent instanceof ExitCodeEvent){

  22.                 this.exitCodeEvent = (ExitCodeEvent) applicationEvent;

  23.             }

  24.             else if(applicationEvent instanceof ApplicationReadyEvent) {

  25.                 doTaskEnd();

  26.             }

  27.         }

  28.         }
复制代码
需要JAVA Spring Cloud大型企业分布式微服务云构建的B2B2C电子商务平台源码 一零三八七七四六二六



您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP