quantz.net基于数据库的任务调度管理(Only.Jobs)

一 前言:

各大调度组件优缺点在这就不讨论了,使用quantz.net是因为它可以执行秒级任务。

Only.Jobs 项目通过将各Job存储在数据库中,启动一个专门的Job管理任务来循环调度各Job的的调度情况。

项目分为 Web管理系统  、服务运行端   、数据提供逻辑处理层

数据访问使用了 SqlSugar 4.1.1.5版本,目前支持MySql、SqlServer

采用quantz.net+Topshelf  可安装为windows服务。

二 项目结构:

一一介绍下:

Only.Jobs.Items 下是创建的测试Job项目。

Only.Jobs  是一个调度服务项目,集成了Topshelf,可安装成windows服务。

Only.Jobs.Core  是项目的核心层,对外提供数据操作。

Only.Jobs.Web 为调度任务的管理和状态监控管理系统。

先来看下总体效果吧

运行Only.Jobs.Web项目:

在任务管理模块可停止、启用各Job.

三 表结构介绍

BackgroundJob  为任务信息存储表

BackgroundJobLog 为任务执行跟踪日志表

四 实现介绍

通过任务管理模块将开发好的Job所在的项目配置起来,存储到BackgroundJob表中。

在Only.Jobs项目中创建ManagerJob 类,Job调度任务管理。

 1     [DisallowConcurrentExecution]
 2     public class ManagerJob : IJob
 3     {
 4         private readonly ILog _logger = LogManager.GetLogger(typeof(ManagerJob));
 5
 6         public void Execute(IJobExecutionContext context)
 7         {
 8             Version Ver = System.Reflection.Assembly.GetExecutingAssembly().GetName().Version;
 9             _logger.InfoFormat("ManagerJob Execute begin Ver." + Ver.ToString());
10             try
11             {
12                 new QuartzManager().JobScheduler(context.Scheduler);
13                 _logger.InfoFormat("ManagerJob Executing ...");
14             }
15             catch (Exception ex)
16             {
17                 JobExecutionException e2 = new JobExecutionException(ex);
18                 e2.RefireImmediately = true;
19             }
20             finally
21             {
22                 _logger.InfoFormat("ManagerJob Execute end ");
23             }
24         }
25     }

JobScheduler 方法:

 1  /// <summary>
 2         /// Job状态管控
 3         /// </summary>
 4         /// <param name="Scheduler"></param>
 5         public void JobScheduler(IScheduler Scheduler)
 6         {
 7             List<BackgroundJobInfo> list = new BackgroundJobService().GeAllowScheduleJobInfoList();
 8             if (list != null && list.Count > 0)
 9             {
10                 foreach (BackgroundJobInfo jobInfo in list)
11                 {
12                     JobKey jobKey = new JobKey(jobInfo.BackgroundJobId.ToString(), jobInfo.BackgroundJobId.ToString() + "Group");
13                     if (Scheduler.CheckExists(jobKey) == false)
14                     {
15                         if (jobInfo.State == 1 || jobInfo.State == 3)
16                         {
17                             ScheduleJob(Scheduler, jobInfo);
18                             if (Scheduler.CheckExists(jobKey) == false)
19                             {
20                                 new BackgroundJobService().UpdateBackgroundJobState(jobInfo.BackgroundJobId, 0);
21                             }
22                             else
23                             {
24                                 new BackgroundJobService().UpdateBackgroundJobState(jobInfo.BackgroundJobId, 1);
25                             }
26                         }
27                         else if (jobInfo.State == 5)
28                         {
29                             new BackgroundJobService().UpdateBackgroundJobState(jobInfo.BackgroundJobId, 0);
30                         }
31                     }
32                     else
33                     {
34                         if (jobInfo.State == 5)
35                         {
36                             Scheduler.DeleteJob(jobKey);
37                             new BackgroundJobService().UpdateBackgroundJobState(jobInfo.BackgroundJobId, 0);
38                         }
39                         else if (jobInfo.State == 3)
40                         {
41                             new BackgroundJobService().UpdateBackgroundJobState(jobInfo.BackgroundJobId, 1);
42                         }
43                     }
44                 }
45             }
46         }

其他的简单的就不在这描述了。

接下来看下运行效果:

启动Only.Jobs项目

仅仅是一个工具项目而已,大家可尽管仍砖头过来。

代码已上传github

https://github.com/mamingbo/Only.Jobs  欢迎下载使用。

时间: 2024-10-12 17:29:27

quantz.net基于数据库的任务调度管理(Only.Jobs)的相关文章

[更新] 基于Quartz.NET 的任务调度管理工具

更新列表: 任务参数可视化. 立即中断正在执行的任务. 每个任务独立的应用程序域 上一版参见: 基于Quqrtz.NET 做的任务调度管理工具 界面具体变化如下: 任务参数可视化 如上图所示, 在管理任务的界面上就可以知道这个任务需哪些参数/类型 及 参数的说明. 实现方式, 在 Job 上添加 特性 :  ParameterTypeAttribute 1 namespace JobA { 2 [ParameterType(typeof(Parameter))] 3 public class J

vsftpd基于数据库文件实现虚拟用户管理站点目录

vsftpd基于数据库文件来实现虚拟用户管理站点目录: ftp授权单个系统用户管理(此用户要禁止登陆服务器),虚拟出多个虚拟用户来管理不同的站点目录 一环境:(1)关闭selinux,centos6.8 x_86_64开启防火墙,放开ftp的端口 (2).存放虚拟用户的密码文件[[email protected] vsftpd]# cat /etc/vsftpd/vsftpd_logindrxiaowu ##账户ZkJxu55rt9 ##密码yanyonGZk&aO=+w09xiaowuZk&am

PostgreSQL数据库web维护管理软件

TreeSoft数据库管理系统使用JAVA开发,采用稳定通用的springMVC +JDBC架构,实现基于WEB方式对 MySQL,Oracle,PostgreSQL 等数据库进行维护管理操作. 功能包括:数据库的展示,库表的展示,表字段结构的展示, SQL语句的在线编辑批量执行,表结构的在线设计维护,数据的在线编辑维护,查询语句保存,JSON数据格式化,SQL语法帮助,在线数据源选择配置等.系统内置14套UI皮肤,45套代码编辑区UI方案,使用中可以依个人喜好选择配色方案. 本系统不但稳定,实

MySQL数据库web维护管理软件

TreeSoft数据库管理系统使用JAVA开发,采用稳定通用的springMVC +JDBC架构,实现基于WEB方式对 MySQL,Oracle,PostgreSQL 等数据库进行维护管理操作. 功能包括:数据库的展示,库表的展示,表字段结构的展示, SQL语句的在线编辑批量执行,表结构的在线设计维护,数据的在线编辑维护,查询语句保存,JSON数据格式化,SQL语法帮助,在线数据源选择配置等.系统内置14套UI皮肤,45套代码编辑区UI方案,使用中可以依个人喜好选择配色方案. 软件不但稳定,实用

Oracle数据库web维护管理软件

TreeSoft数据库管理系统使用JAVA开发,采用稳定通用的springMVC +JDBC架构,实现基于WEB方式对 MySQL,Oracle,PostgreSQL 等数据库进行维护管理操作. 功能包括:数据库的展示,库表的展示,表字段结构的展示, SQL语句的在线编辑批量执行,表结构的在线设计维护,数据的在线编辑维护,查询语句保存,JSON数据格式化,SQL语法帮助,在线数据源选择配置等.系统内置14套UI皮肤,45套代码编辑区UI方案,使用中可以依个人喜好选择配色方案. 本系统不但稳定,实

MySQL,Oracle,PostgreSQL 数据库web维护管理软件

TreeSoft数据库管理系统使用JAVA开发,采用稳定通用的springMVC +JDBC架构,实现基于WEB方式对 MySQL,Oracle,PostgreSQL 等数据库进行维护管理操作. 功能包括:数据库的展示,库表的展示,表字段结构的展示, SQL语句的在线编辑批量执行,表结构的在线设计维护,数据的在线编辑维护,查询语句保存,JSON数据格式化,SQL语法帮助,在线数据源选择配置等.系统内置14套UI皮肤,45套代码编辑区UI方案,使用中可以依个人喜好选择配色方案. 本系统不但稳定,实

Mybatis分页-利用Mybatis Generator插件生成基于数据库方言的分页语句,统计记录总数 (转)

众所周知,Mybatis本身没有提供基于数据库方言的分页功能,而是基于JDBC的游标分页,很容易出现性能问题.网上有很多分页的解决方案,不外乎是基于Mybatis本机的插件机制,通过拦截Sql做分页.但是在像Oracle这样的数据库上,拦截器生成的Sql语句没有变量绑定,而且每次语句的都要去拦截,感觉有点浪费性能. Mybatis Generator是Mybatis的代码生成工具,可以生成大部分的查询语句. 本文提供的分页解决方案是新增Mybatis Generator插件,在用Mybatis

quartz.net 基于数据库的简单实现

前面简单学习了通过XML配置或者内存指定的方式实现调度任务.但此用法实战用途较小,企业上多需要分布式集群的方式.quart团队也考虑到了这点,于是有了我们今天要学习的.基于数据库实现分布式. 1 NameValueCollection properties = new NameValueCollection(); 2 3 // 驱动类型,这里用的mysql,目前支持如下驱动: 4 //Quartz.Impl.AdoJobStore.FirebirdDelegate 5 //Quartz.Impl

分享一个自己用的基于mvc编程工作管理

前言: 最近在家没事学习下mvc,正好把以前用webform写的一个帮助自己编码的工具重构成了mvc,另外根据自己的编程工作感悟添加了公司常用软件维护 ,数据库操作记录这些新功能. 技术没什么高深的技术,就是mvc+jquery easyUi+简单的三层,生成文档的模板引擎用的Razor. 主要还是解决沟通成本太高的问题,都是根据工作中遇到的问题慢慢解决的,至少很多功能可以解决小型软件团队很多流程问题,自己摸索真是又痛苦又快乐.相信也有很多朋友和我一样没有去过大型软件公司,很多问题只能看别人的文