• .NET Core 基于Quartz的UI可视化操作组件 GZY.Quartz.MUI 简介


    前言

    最近在用Quartz做定时任务.虽然很方便,但是Quartz自己貌似是没有UI界面的..感觉操作起来 就很难受..

    查了一下,貌似有个UI组件 不过看了一下文档..直接给我劝退了..太麻烦了

    我只想要一个像swaggerUI一样,项目入侵量小,仅需要在Startup中注入的UI组件

    然后就打算自己做一个.

    最近终于完成第一个版本啦.. 打算直接开源给社区..

    代码已开源:点击跳转github(欢迎点Start收藏~)

    本篇主要就是简单介绍一下如何使用和一部分界面.

    正文

     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/ 如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面
  • 相关阅读:
    ansible自动化运维04
    ansible自动化运维03
    ansible自动化运维02
    ansible自动化运维01
    mysql innodb存储引擎和一些参数优化
    Mysql 数据库常用配置命令
    zabbix server3.4 使用mailx配置邮件报警
    32_redis cluster的核心原理分析:gossip通信、jedis smart定位、主备切换
    31_redis cluster的自动化slave迁移实现更强的高可用架构的部署方案
    30_redis cluster通过master水平扩容来支撑更高的读写吞吐+海量数据
  • 原文地址:https://www.cnblogs.com/GuZhenYin/p/15411316.html
Copyright © 2020-2023  润新知