.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接口了..因为稍微麻烦一点,所以我们下篇再讲..

作者:顾振印 出处:http://www.cnblogs.com/GuZhenYin/ 如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面

一行代码完成定时任务调度,基于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

.NET Core基础篇之:集成Swagger文档与自定义Swagger UI

Core Graphics框架 利用Quartz 2D绘图

从零实操基于WSL2 Docker部署Asp.Net Core项目