ASP.NET MVC 5 实现基于Quartz.net 的任务调度管理平台(四)(完)
来源:互联网 发布:手机mv制作软件 编辑:程序博客网 时间:2024/06/08 13:47
Common层类图
DBUtility层类图
MVC层类图
SQL脚本
USE [master]GOCREATE DATABASE [TaskManager] ON PRIMARY ( NAME = N'TaskManager', FILENAME = N'C:\Program Files\Microsoft SQL Server\MSSQL10.MSSQLSERVER\MSSQL\DATA\TaskManager.mdf' , SIZE = 2048KB , MAXSIZE = UNLIMITED, FILEGROWTH = 1024KB ) LOG ON ( NAME = N'TaskManager_log', FILENAME = N'C:\Program Files\Microsoft SQL Server\MSSQL10.MSSQLSERVER\MSSQL\DATA\TaskManager_log.ldf' , SIZE = 1024KB , MAXSIZE = 2048GB , FILEGROWTH = 10%)GOALTER DATABASE [TaskManager] SET COMPATIBILITY_LEVEL = 100GOIF (1 = FULLTEXTSERVICEPROPERTY('IsFullTextInstalled'))beginEXEC [TaskManager].[dbo].[sp_fulltext_database] @action = 'enable'endUSE [TaskManager]GOSET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOSET ANSI_PADDING ONGOCREATE TABLE [dbo].[p_User]( [UserId] [int] NOT NULL, [UserName] [varchar](50) NULL, [PassWord] [varchar](50) NULL, [TrueName] [varchar](50) NULL, [UserEmail] [varchar](50) NULL, [PhoneNum] [varchar](30) NULL, [IsAdmin] [int] NULL, [Status] [int] NULL, [CreateTime] [datetime] NULL, [LastLoginTime] [datetime] NULL, CONSTRAINT [PK_p_User] PRIMARY KEY CLUSTERED ( [UserId] ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]) ON [PRIMARY]GOSET ANSI_PADDING OFFGOINSERT [dbo].[p_User] ([UserId], [UserName], [PassWord], [TrueName], [UserEmail], [PhoneNum], [IsAdmin], [Status], [CreateTime], [LastLoginTime]) VALUES (1, N'admin', N'zdYqbXkNc1iKJ6s2NRB+9w==', N'admin', N'417114764@qq.com', N'18618243664', 1, 1, CAST(0x0000A5E900000000 AS DateTime), CAST(0x0000A5E900000000 AS DateTime))/****** Object: Table [dbo].[p_Task] Script Date: 03/29/2017 15:45:46 ******/SET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOCREATE TABLE [dbo].[p_Task]( [TaskID] [uniqueidentifier] NOT NULL, [TaskName] [nvarchar](300) NULL, [TaskParam] [nvarchar](max) NULL, [CronExpressionString] [nvarchar](200) NULL, [AssemblyName] [nvarchar](150) NULL, [ClassName] [nvarchar](150) NULL, [Status] [int] NULL, [IsDelete] [int] NULL, [CreatedTime] [datetime] NULL, [ModifyTime] [datetime] NULL, [RecentRunTime] [datetime] NULL, [NextFireTime] [datetime] NULL, [CronRemark] [nvarchar](300) NULL, [Remark] [nvarchar](1000) NULL, CONSTRAINT [PK__p_Task__7C6949D12F10007B] PRIMARY KEY CLUSTERED ( [TaskID] ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]) ON [PRIMARY]GOEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'任务ID' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'p_Task', @level2type=N'COLUMN',@level2name=N'TaskID'GOEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'任务名称' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'p_Task', @level2type=N'COLUMN',@level2name=N'TaskName'GOEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'任务参数' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'p_Task', @level2type=N'COLUMN',@level2name=N'TaskParam'GOEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'任务运行Cron表达式' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'p_Task', @level2type=N'COLUMN',@level2name=N'CronExpressionString'GOEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'程序集名称' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'p_Task', @level2type=N'COLUMN',@level2name=N'AssemblyName'GOEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'任务所在类包含命名空间' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'p_Task', @level2type=N'COLUMN',@level2name=N'ClassName'GOEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'任务运行状态 1:运行 0:停止 -1 删除' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'p_Task', @level2type=N'COLUMN',@level2name=N'Status'GOEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'创建时间' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'p_Task', @level2type=N'COLUMN',@level2name=N'CreatedTime'GOEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'修改时间' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'p_Task', @level2type=N'COLUMN',@level2name=N'ModifyTime'GOEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'最近运行时间' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'p_Task', @level2type=N'COLUMN',@level2name=N'RecentRunTime'GOEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'下次运行时间' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'p_Task', @level2type=N'COLUMN',@level2name=N'NextFireTime'GOEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'表达式中文说明' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'p_Task', @level2type=N'COLUMN',@level2name=N'CronRemark'GOEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'备注' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'p_Task', @level2type=N'COLUMN',@level2name=N'Remark'GOEXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'任务表' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'p_Task'GOINSERT [dbo].[p_Task] ([TaskID], [TaskName], [TaskParam], [CronExpressionString], [AssemblyName], [ClassName], [Status], [IsDelete], [CreatedTime], [ModifyTime], [RecentRunTime], [NextFireTime], [CronRemark], [Remark]) VALUES (N'5fbaa648-d1e8-e511-b79d-54ee75868d11', N'自动增加Job', N'', N'0/10 * * * * ?', N'Weiz.TaskManager.TaskSet', N'Weiz.TaskManager.TaskSet.AutoAddJob', 1, 0, CAST(0x0000A5F300F9CD76 AS DateTime), CAST(0x0000A65F01268671 AS DateTime), CAST(0x0000A65F01268670 AS DateTime), CAST(0x0000A65F01269228 AS DateTime), N'每10秒运行一次,将后台添加的job 增加到quartz 服务中,请勿删除 ', NULL)INSERT [dbo].[p_Task] ([TaskID], [TaskName], [TaskParam], [CronExpressionString], [AssemblyName], [ClassName], [Status], [IsDelete], [CreatedTime], [ModifyTime], [RecentRunTime], [NextFireTime], [CronRemark], [Remark]) VALUES (N'5fbaa648-d1e8-e511-b79d-54ee75868db0', N'取消超时订单', N'', N'0/20 * * * * ?', N'Weiz.TaskManager.TaskSet', N'Weiz.TaskManager.TaskSet.OrderCancel', 1, 0, CAST(0x0000A5F300F9CD76 AS DateTime), CAST(0x0000A65F01268671 AS DateTime), CAST(0x0000A65F01268670 AS DateTime), CAST(0x0000A65F01269228 AS DateTime), N'每10秒运行一次', NULL)INSERT [dbo].[p_Task] ([TaskID], [TaskName], [TaskParam], [CronExpressionString], [AssemblyName], [ClassName], [Status], [IsDelete], [CreatedTime], [ModifyTime], [RecentRunTime], [NextFireTime], [CronRemark], [Remark]) VALUES (N'5fbaa648-d1e8-e511-b79d-54ee75868db1', N'测试任务,输出当前时间', N'', N'0/10 * * * * ?', N'Weiz.TaskManager.TaskSet', N'Weiz.TaskManager.TaskSet.TestJob', 1, 0, CAST(0x0000A5F300F9CD76 AS DateTime), CAST(0x0000A65F01268671 AS DateTime), CAST(0x0000A65F01268670 AS DateTime), CAST(0x0000A65F01269228 AS DateTime), N'每10秒运行一次', NULL)/****** Object: Table [dbo].[p_RunningLog] Script Date: 03/29/2017 15:45:46 ******/SET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOSET ANSI_PADDING ONGOCREATE TABLE [dbo].[p_RunningLog]( [Id] [bigint] IDENTITY(1,1) NOT NULL, [TaskID] [uniqueidentifier] NULL, [Remark] [varchar](500) NULL, [Description] [varchar](1000) NULL, [CreateTime] [datetime] NULL, CONSTRAINT [PK_p_TaskRunLog] PRIMARY KEY CLUSTERED ( [Id] ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]) ON [PRIMARY]GOSET ANSI_PADDING OFFGOSET ANSI_NULLS ONGOSET QUOTED_IDENTIFIER ONGOSET ANSI_PADDING ONGOCREATE TABLE [dbo].[p_ErrorLog]( [nId] [bigint] IDENTITY(1,1) NOT NULL, [dtDate] [datetime] NULL, [sThread] [varchar](100) NULL, [sLevel] [varchar](100) NULL, [sLogger] [varchar](3000) NULL, [sMessage] [varchar](8000) NULL, [sException] [varchar](8000) NULL, [sName] [varchar](200) NULL, CONSTRAINT [PK_p_ErrorLog] PRIMARY KEY CLUSTERED ( [nId] ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]) ON [PRIMARY]GOSET ANSI_PADDING OFFGOALTER TABLE [dbo].[p_Task] ADD CONSTRAINT [DF__p_Task__TaskID__30F848ED] DEFAULT (newsequentialid()) FOR [TaskID]GOALTER TABLE [dbo].[p_Task] ADD CONSTRAINT [DF__p_Task__Status__31EC6D26] DEFAULT ((0)) FOR [Status]GOALTER TABLE [dbo].[p_Task] ADD CONSTRAINT [DF__p_Task__CreatedO__32E0915F] DEFAULT (getdate()) FOR [CreatedTime]GO
详细说明
ServiceBus服务,其实就是 Scheduler 的宿主,负责初始化,Scheduler ,以及相关的Jobs 的配置,然后由Scheduler实例负责调度执行相关的Jobs。
TaskManager数据库,存储Jobs 的配置,同时记录job 的执行执行日志记录。
HouTai_New管理后台,负责维护 Jobs 的配置信息和控制Jobs的状态。管理后台启动之后,会初始化远程ServiceBus服务忠的Scheduler 实例。并通过Scheduler 实例修改控制jobs 的状态。
TaskManager.TaskUtility项目,封装所有quartz的操作。初始化Scheduler,读取修改jobs 等。
运行结果如图:
阅读全文
0 0
- ASP.NET MVC 5 实现基于Quartz.net 的任务调度管理平台(四)(完)
- ASP.NET MVC 5实现基于Quartz.net 的任务调度管理平台(一)
- ASP.NET MVC 5 实现基于Quartz.net 的任务调度管理平台(二)
- ASP.NET MVC 5 实现基于Quartz.net 的任务调度管理平台(三)
- 基于ASP.NET MVC(C#)和Quartz.Net组件实现的定时执行任务调度
- 基于ASP.NET MVC(C#)和Quartz.Net组件实现的定时执行任务调度
- 基于ASP.NET MVC(C#)和Quartz.Net组件实现的定时执行任务调度
- Quartz.net基于数据库的任务调度管理(Only.Jobs)
- 基于Quartz.net 的开源任务管理平台
- ASP.NET使用Quartz.NET实现定时任务调度
- 任务调度~Quartz.net实现简单的任务调试
- Quartz.NET 通过配置文件实现任务调度
- .net Windows服务采用Quartz.NET实现任务调度
- Quartz.NET 任务调度框架
- 任务调度框架 Quartz.NET
- Quartz.NET 任务调度框架
- Quartz.NET--基于配置的调度方案
- 实现基于ASP.NET MVC快速开发平台
- LINQ系列:Linq to Object生成操作符
- [LeetCode] 347. Top K Frequent Elements
- C++学习:map(键值对)和set(集合)
- 4A平台的管理功能
- Hive1.2.1<常用操作示例>
- ASP.NET MVC 5 实现基于Quartz.net 的任务调度管理平台(四)(完)
- 数据库日期转换
- PreparedStatement对象替代Statement解决sql注入
- tiny4412学习(一)之从零搭建linux系统(烧写uboot、内核进emmc+uboot启动内核)
- Qt(C++) 截屏的方法
- Android 为什么我的Galaxy S2上空间不足?转载
- 日期类 class_Date
- NodeJS学习笔记-0
- Vmware12安装Redhat6.8