├── demoeee
│ ├── com //启动整个项目的moudle
│ └── example
│ └── demo
│ ├──aop //个人定义的写的自定义注解
│ ├──api //swagger API 访问地址:http://localhost:8080/quartz/swagger-ui.html
│ ├──command //命令开发模式
│ ├──commonfactory//普通工厂开发模式
│ ├──decorate //装饰者开发模式
│ ├──observer //观察者开发模式
│ ├──lambda //java8的一个新特性
│ ├──config //定时任务的配置
│ ├──controller //任务控制层
│ ├──dao //对应mybatis xml的配置文件
│ ├──entity //实体类
│ ├──interceptor //实体类
│ ├──service //业务逻辑层
│ ├──util //帮助类
│ ├──需要执行的job //实体类
│ └──DemoApplication.java //整个项目的启动类
│ └── resources
│ │ ├── application-dev.properties //开发环境
│ │ ├── application-prod.properties //生产环境
│ │ ├── application-test.properties //测试环境
│ │ ├── application.properties //配置总文件
│ │ ├── quartz.properties //定时任务配置文件
│ │ ├── mapper //mybatis的配置文件
│ │ ├── docker-compose.yml //docker配置文件
│ │ ├── sql //建库文件
│ │ ├── static //图片,js,css等页面需要的元素
│ │ └── templates//页面代码
│ └── pom启动整个项目的依赖 //
基于spring-boot+quartz的CRUD动态任务管理系统,适用于中小项目。
基于spring-boot 2.x +quartz 的CRUD任务管理系统:https://gitee.com/52itstyle/spring-boot-task
-
Timer,简单无门槛,一般也没人用。
-
spring @Scheduled注解,一般集成于项目中,小任务很方便。
-
开源工具 Quartz,分布式集群开源工具,以下两个分布式任务应该都是基于Quartz实现的,可以说是中小型公司必选,当然也视自身需求而定。
-
分布式任务 XXL-JOB,是一个轻量级分布式任务调度框架,支持通过 Web 页面对任务进行 CRUD 操作,支持动态修改任务状态、暂停/恢复任务,以及终止运行中任务,支持在线配置调度任务入参和在线查看调度结果。
-
分布式任务 Elastic-Job,是一个分布式调度解决方案,由两个相互独立的子项目 Elastic-Job-Lite 和 Elastic-Job-Cloud 组成。定位为轻量级无中心化解决方案,使用 jar 包的形式提供分布式任务的协调服务。支持分布式调度协调、弹性扩容缩容、失效转移、错过执行作业重触发、并行调度、自诊。
JDK1.8、Maven、IDEA
SpringBoot1.5.10、thymeleaf、quartz2.3.0、iview、vue、layer、AdminLTE、bootstrap、lombok、aop
- 项目使用的数据库为MySql,选择resources/sql中的tables_mysql_innodb.sql文件初始化数据库信息。
- 在resources/application.properties文件中替换为自己的数据源。
- 在resources/quartz.properties文件中替换为自己的数据源。
- 运行Application main方法,启动项目。
- 项目访问地址:http://localhost:8080/quartz
- API接口地址:http://localhost:8080/quartz/swagger-ui.html
由于工作原因,项目正在完善中(仅供参考),随时更新日志。
- 任务列表
- 任务新增和修改
- 任务执行
- 表达式生成器(集成:https://gitee.com/finira/cronboot)
- 任务移除
- Job中注入service为空的问题
- 系统启动,如果数据库任务为零则初始化测试任务,用于测试