之前做数据同步时,用过timer、window服务,现在不用那么费事了,可以使用Quartz,并且配置灵活,使用cron表达式配置XML就可以。我用的是3.0.7版本支持.netcore。

  • 首先创建一个.netcore控制台应用程序,添加Quartz、Quartz.Jobs、Quartz.Plugins引用,这里面添加了PostgreSql数据库的连接方法,其它数据库可以做为参考,添加Npgsql、Npgsql.EntityFrameworkCore.PostgreSQL引用,目录结构如下
  • 创建数据库DBContext类
  • using System;
    using System.Collections.Generic;
    using System.Text;
    using Microsoft.EntityFrameworkCore; namespace QuartzPro.DbContext
    {
    public class PostgreDbContext : Microsoft.EntityFrameworkCore.DbContext
    {
    private string _conn;
    public PostgreDbContext(DbContextOptions<PostgreDbContext> options) : base(options)
    {
    }
    public PostgreDbContext(string conn)
    {
    _conn = conn;
    } protected override void OnModelCreating(ModelBuilder builder)
    {
    base.OnModelCreating(builder);
    //builder.Entity<syrequest_main>().ToTable("book", "pro");
    } // public virtual DbSet<book> book { get; set; } }
    }
  • 创建Job类
  • using System;
    using System.Collections.Generic;
    using System.IO;
    using System.Text;
    using System.Threading.Tasks;
    using Microsoft.Extensions.Logging;
    using Quartz; namespace QuartzPro.Jobs
    {
    public class SyncUserInfoService : IJob
    {
    private readonly ILogger<SyncUserInfoService> _logger; public SyncUserInfoService()
    {
    _logger = BootStrapIoc.GetService<ILoggerFactory>().CreateLogger<SyncUserInfoService>();
    }
    public Task Execute(IJobExecutionContext context)
    {
    _logger.LogDebug($"SyncUserInfoService Execute start...");
    return Task.Run(() =>
    {
    using (StreamWriter sw = new StreamWriter(@"D:\print.txt", true, Encoding.UTF8))
    {
    sw.WriteLine(DateTime.Now + "任务执行中...");
    sw.Close();
    }
    });
    }
    }
    }
  • 创建依赖注入类
  • using Microsoft.Extensions.Configuration;
    using Microsoft.Extensions.DependencyInjection;
    using Microsoft.Extensions.Logging;
    using QuartzPro.DbContext; namespace QuartzPro
    {
    public static class BootStrapIoc
    {
    /// <summary>
    /// IOC容器
    /// </summary>
    private static IServiceCollection serviceCollection { get; } = new ServiceCollection(); /// <summary>
    /// 初始化IOC容器
    /// </summary>
    public static void InitIoc()
    { var configuration = new ConfigurationBuilder().AddJsonFile("appsettings.json", optional: true, reloadOnChange: true).AddEnvironmentVariables().Build(); var identityConn = configuration.GetConnectionString("IdentityConnection");
    //db
    serviceCollection.AddTransient(_ => new PostgreDbContext(identityConn));
    //log
    serviceCollection.AddLogging(configure =>
    {
    configure.AddConfiguration(configuration.GetSection("Logging"));
    configure.AddConsole();
    });
    //config
    serviceCollection.AddSingleton<IConfiguration>(configuration); } /// <summary>
    /// 获取实体
    /// </summary>
    /// <typeparam name="T"></typeparam>
    /// <returns></returns>
    public static T GetService<T>()
    {
    return serviceCollection.BuildServiceProvider().GetService<T>();
    }
    }
    }

      

  • 创建任务监听XML文件
  • <?xml version="1.0" encoding="utf-8" ?>
    <job-scheduling-data xmlns="http://quartznet.sourceforge.net/JobSchedulingData"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    version="2.0"> <processing-directives>
    <overwrite-existing-data>true</overwrite-existing-data>
    </processing-directives>
    <schedule> <!--同步用户信息:10分钟一次-->
    <job>
    <name>SyncUserInfoService</name>
    <group>GroupUserInfoManager</group>
    <description>同步用户信息</description>
    <job-type>QuartzPro.Jobs.SyncUserInfoService, QuartzPro</job-type>
    <durable>true</durable>
    <recover>false</recover>
    </job>
    <trigger>
    <cron>
    <name>TriggerSyncUserInfoService</name>
    <group>GroupTriggerUserInfoManager</group>
    <job-name>SyncUserInfoService</job-name>
    <job-group>GroupUserInfoManager</job-group>
    <start-time>2019-07-30T15:15:00.0Z</start-time>
    <cron-expression>0 0/10 * * * ?</cron-expression>
    <!--<cron-expression>1 0 0 * * ?</cron-expression>-->
    </cron>
    </trigger>
    </schedule>
    </job-scheduling-data>
  • json配置文件
  • {
    "Logging": {
    "LogLevel": {
    "Default": "Debug",
    "System": "Information",
    "Microsoft": "Information"
    },
    "Console": {
    "IncludeScopes": true
    }
    },
    "ConnectionStrings": {
    "IdentityConnection": "User ID=admin;Password=123456;Host=.;Port=5432;Database=identities;"
    }
    }
  • Program类,注意该项目为控制台程序 UserInfoManager.xml和 appsettings.json,需要右键设置为可输出文件
  • using System;
    using System.Collections.Specialized;
    using System.Threading.Tasks;
    using Quartz;
    using Quartz.Impl; namespace QuartzPro
    {
    class Program
    {
    private static void Main(string[] args)
    {
    BootStrapIoc.InitIoc();
    var task = Run();
    task.Wait();
    task.ConfigureAwait(false);
    while (true)
    {
    Console.Read();
    }
    }
    public static async Task Run()
    {
    try
    {
    var properties = new NameValueCollection
    {
    ["quartz.plugin.triggHistory.type"] = "Quartz.Plugin.History.LoggingJobHistoryPlugin, Quartz.Plugins",
    ["quartz.plugin.jobInitializer.type"] = "Quartz.Plugin.Xml.XMLSchedulingDataProcessorPlugin, Quartz.Plugins",
    ["quartz.plugin.jobInitializer.fileNames"] = "UserInfoManager.xml",
    ["quartz.plugin.jobInitializer.failOnFileNotFound"] = "true",
    ["quartz.plugin.jobInitializer.scanInterval"] = "120"
    };
    ISchedulerFactory sf = new StdSchedulerFactory(properties);
    IScheduler scheduler = await sf.GetScheduler();
    Console.WriteLine("start the schedule");
    await scheduler.Start();
    Console.WriteLine("end");
    }
    catch (SchedulerException se)
    {
    await Console.Error.WriteLineAsync(se.ToString());
    }
    catch (Exception ex)
    {
    Console.Write($"err={ex.ToString()}");
    }
    }
    }
    } 

.netcore控制台->定时任务Quartz的更多相关文章

  1. spring学习总结(mybatis,事务,测试JUnit4,日志log4j&slf4j,定时任务quartz&spring-task,jetty,Restful-jersey等)

    在实战中学习,模仿博客园的部分功能.包括用户的注册,登陆:发表新随笔,阅读随笔:发表评论,以及定时任务等.Entity层设计3张表,分别为user表(用户),essay表(随笔)以及comment表( ...

  2. windows下建立netcore控制台程序,然后传送到centos7下的docker容器里运行

    1.首先,在window下用vs2017开发netcore控制台项目. 2.把建立好的项目传送到centos7下面的容器里. docker cp sharefoldersforwindows/ 359 ...

  3. spring多个定时任务quartz配置

    spring多个定时任务quartz配置 <?xml version=”1.0″ encoding=”UTF-8″?> <beans xmlns=”http://www.spring ...

  4. Java生鲜电商平台-定时器,定时任务quartz的设计与架构

    Java生鲜电商平台-定时器,定时任务quartz的设计与架构 说明:任何业务有时候需要系统在某个定点的时刻执行某些任务,比如:凌晨2点统计昨天的报表,早上6点抽取用户下单的佣金. 对于Java开源生 ...

  5. 集群服务器+定时任务(Quartz) 重复执行的问题

    x StackExchange.Redis private readonly IDatabase _db; string key = string.Concat("{自己命名的Redis前缀 ...

  6. spring -boot定时任务 quartz 基于 MethodInvokingJobDetailFactoryBean 实现

    spring 定时任务 quartz 基于  MethodInvokingJobDetailFactoryBean 实现 依赖包 如下 <dependencies> <depende ...

  7. .net core 2.1控制台使用Quartz.net实现定时任务执行

    权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/qq_33435149/article/de ...

  8. Spring框架下的定时任务quartz框架的使用

    手头的这个项目需要用到定时任务,但之前没接触过这东西,所以不太会用,从网上找资料,大致了解了一下,其实也不难.Java的定时任务实现有三种,一种是使用JDK自带的Timer那个类来实现,另一种是使用q ...

  9. SpringBoot系列:Spring Boot集成定时任务Quartz

    一.关于Quartz Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,它可以与J2EE与J2SE应用程序相结合也可以单独使用.在java企业级应用中,Q ...

随机推荐

  1. 微信小程序 存储数据到本地以及本地获取数据

    1.wx存储数据到本地以及本地获取数据 存到本地就是存到你的手机 wx.setStorageSync与wx.setStorage 1.1 wx.setStorageSync(string key, a ...

  2. 未来已来:云原生 Cloud Native

    作者:天知,原文链接 前言 自 2013 年容器(虚拟)技术(Docker)成熟后,后端的架构方式进入快速迭代的阶段,出现了很多新兴概念: 微服务 k8s Serverless IaaS:基础设施服务 ...

  3. 基于MbedTLS的AES加密实现,含STM32H7和STM32F4的实现例程

    说明: 1.mbedTLS的前身是PolarSSL,开源免费. 主要提供了的SSL/TLS支持(在传输层对网络进行加密),各种加密算法,各种哈希算法,随机数生成以及X.509(密码学里公钥证书的格式标 ...

  4. (一)初识NumPy库(数组的创建和变换)

    在学习数据分析时,NumPy作为最基础的数据分析库,我们能够熟练的掌握它是学习数据分析的必要条件.接下来就让我们学习该库吧. 学习NumPy库的环境: python:3.6.6 编辑器:pycharm ...

  5. 测试人员必备之 mysql 常用命令学习指南

    1.数据库连接 1.通过命令行连接数据库 [root@localhost ~]# mysql -u root -p Enter password: 输入以上命令,回车后输入密码,回车,出现 mysql ...

  6. 一起学Spring之基础篇

    本文主要讲解Spring的基础环境搭建以及演变由来,仅供学习分享使用,如有不足之处,还请指正. 什么是Spring ? Spring是一个开源框架,用来处理业务逻辑层和其他层之间的耦合问题.因此Spr ...

  7. (转)利用Auto ARIMA构建高性能时间序列模型(附Python和R代码)

    转自:  原文标题:Build High Performance Time Series Models using Auto ARIMA in Python and R 作者:AISHWARYA SI ...

  8. 大部分人都会忽略的Python易错点总结

    python中复数实现(-2) 0.5和开根号sqrt(-2)的区别** (-2)**0.5和sqrt(-2)是不同的,前者是复数后者是会报错的. print((-2)**0.5) #输出:(8.65 ...

  9. VUE,基于vue-cli搭建创建vue项目

    前提:必须安装node.js,官方地址:https://nodejs.org/en/ 然后安装vue-cli 安装方式:cmd命令行安装:打开cmd命令符输入进行全局安装脚手架:npm install ...

  10. 简单使用vue-cli

    上一篇我们简单的看了看vue的基本用法,就是三步,首先就是用<script>标签引入vue的依赖,然后就是写html标签,在标签中用vue指令绑定一些属性,最后就是new Vue(xxx) ...