.NET Core 基于Quartz的UI可视化操作组件 GZY.Quartz.MUI 简介
Posted GuZhenYin
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了.NET Core 基于Quartz的UI可视化操作组件 GZY.Quartz.MUI 简介相关的知识,希望对你有一定的参考价值。
最近在用Quartz做定时任务.虽然很方便,但是Quartz自己貌似是没有UI界面的..感觉操作起来 就很难受..
查了一下,貌似有个UI组件 不过看了一下文档..直接给我劝退了..太麻烦了
我只想要一个像swaggerUI一样,项目入侵量小,仅需要在Startup中注入的UI组件
然后就打算自己做一个.
最近终于完成第一个版本啦.. 打算直接开源给社区..
代码暂时还没上传,容我在优化一下..
本篇主要就是简单介绍一下如何使用和一部分界面.
1.注入QuartzUI
我们随意创建一个托管项目,这里我们以WebAPI作为示例,
通过Nuget添加GZY.Quartz.MUI 组件,如图:
在Startup的ConfigureServices中添加注入代码如下:
public void ConfigureServices(IServiceCollection services) { services.AddControllers(); var optionsBuilder = new DbContextOptionsBuilder<QuarzEFContext>(); optionsBuilder.UseDm("server=xxxxxxx;database=xxx;User Id=xxxx;PWD=xxxx", b => b.MaxBatchSize(1)); services.AddQuartzUI(optionsBuilder.Options); }
组件使用EF Core作为数据持久化访问的工具(后期考虑扩展使用本地化的文本和其他的ORM框架,源码中也提供了接口,欢迎各路大神提交代码自行实现),所以需要创建一个DbContextOptionsBuilder,添加给QuartzUI即可.
在Startup的Configure方法中添加以下内容:
public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { if (env.IsDevelopment()) { app.UseDeveloperExceptionPage(); } app.UseRouting(); app.UseAuthorization(); app.UseQuartz(); //这里注入Quartz app.UseEndpoints(endpoints => { endpoints.MapControllers(); }); }
2.运行项目进入管理界面
直接运行项目,我们在URL中输入固定后缀 QuartzUI 如图:
这样,我们的定时任务组件就跑起来了.
3.创建一个API类型的定时任务
点击新建任务,输入对应参数.如图:
注意:新建完成后任务处于未开启状态,需手动启动.
点击启动任务,定时任务就会根据设置启动了.
4.查看任务执行日志
点击任务后面的执行记录,即可查询.如图:
5.任务持久化
组件已经自动将任务持久化处理,项目启动时会自行根据数据库的数据情况来初始化任务,无需进行其他处理.
有心的同学已经已经发现了..我们有DLL的类型..
这种类型是直接调用项目中的代码..就不用通过API接口了..因为稍微麻烦一点,所以我们下篇再讲..
一行代码完成定时任务调度,基于Quartz的UI可视化操作组件 GZY.Quartz.MUI
前言
之前发布过第一个版本,有兴趣的可以去看看: NET Core 基于Quartz的UI可视化操作组件 GZY.Quartz.MUI 简介
GitHub开源地址:l2999019/GZY.Quartz.MUI: 基于Quartz的轻量级,注入化的UI组件
总而言之,这个组件主要想做的就是:像swaggerUI一样,项目入侵量小,仅需要在Startup中注入的UI组件
目前完成了第二个版本,
1.增加本地json持久化调度任务,无需数据库
2.增加直接调用本地类方法,无需通过WebAPI接口.
本篇主要是介绍一下这两个新增的功能.
正文
一.增加本地json持久化调度任务,无需数据库
1.首先,我们创建一个空白的ASP.NET Core 项目(MVC、Razor和WebAPI都行),如图:
2.通过nuget引用最新版本的GZY.Quartz.MUI组件,如图:
3.修改一下Startup.cs
在ConfigureServices添加一行代码如下:
public void ConfigureServices(IServiceCollection services)
services.AddQuartzUI();
在Configure添加一行代码如下:
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
if (env.IsDevelopment())
app.UseDeveloperExceptionPage();
app.UseRouting();
app.UseQuartz(); //添加这行代码
app.UseEndpoints(endpoints =>
endpoints.MapGet("/", async context =>
await context.Response.WriteAsync("Hello World!");
);
);
4.运行并启动项目,在弹出来的地址中,输入后缀 /QuartzUI,如图:
我们就可以愉快的开始添加自己的定时调度任务啦~(PS:新添加的任务,默认是暂停状态,需要启动后才能立即执行哦)
二.增加直接调用本地类方法,无需通过WebAPI接口.
上一个版本发布之后,有小伙伴反映,调度任务只能通过webapi去调用,在一些小型项目中难应用,比如纯MVC的项目
这次我添加了通过继承接口,就可以直接调用本地方法的方式~ 我们来一步步介绍.
1.我们创建一个测试类,继承IJobService如下:
public class TestJob : IJobService
public string ExecuteService(string parameter)
return "定时任务已执行成功!";
2.在Startup的ConfigureServices方法中,添加如下代码:
public void ConfigureServices(IServiceCollection services)
services.AddQuartzUI();
services.AddQuartzClassJobs(); //添加本地调度任务访问
3.运行项目,并添加测试调度任务,如图:
4.启动任务,并立即执行, 这样,我们就完成了本地定时任务的调用啦~
以上是关于.NET Core 基于Quartz的UI可视化操作组件 GZY.Quartz.MUI 简介的主要内容,如果未能解决你的问题,请参考以下文章
一行代码完成定时任务调度,基于Quartz的UI可视化操作组件 GZY.Quartz.MUI
一行代码完成定时任务调度,基于Quartz的UI可视化操作组件 GZY.Quartz.MUI
net core quartz调度 warp打包 nssm部署到windowsservice