.NET 分布式毫秒级定时任务 Sundial

何许人也

Hi,我是百小僧,我又来了。1993 年 05 月生,双子座,2008 年高中接触编程,进入大学后成痴迷状态,于 2012 年 09 月创业至今十年有余,跌跌撞撞还在路上,个人简介不过多阐述 https://furion.baiqian.ltd/docs/author。

开源十年,坚持每年至少开源一款项目,如今已有 30 个有余,十年间已是超 6 万人的群主。开源十年,我都做了啥?

1、创造了国内超流行的 .NET 框架 Furion:https://gitee.com/dotnetchina/Furion

3007ed5d2b5a5a55aebe500d52e844c6.png

2、创造了前端弹窗组件 LayX:https://gitee.com/monksoul/LayX

504a6f6937aaab97893fe4719e3bbd37.png

3、创办了 Gitee 平台超有知名度的 dotNET China 组织:https://gitee.com/dotnetchina

ef03e245d25b3b586b258c2be5060441.png

4、创造了分布式毫秒级定时任务 Sundial:https://gitee.com/dotnetchina/Sundial

25f9a5ed25c0d472137ba58faafd2bbd.png

5、创造了分布式事件总线 Jaina:https://gitee.com/dotnetchina/Jaina

2d567e8b17293847fb40bbdb02120363.png

6、.NET 全能 Cron 表达式解析 TimeCrontab 作者:https://gitee.com/dotnetchina/TimeCrontab

c9137cd8649bc502818e432a2727d601.png

7、曾经风靡一时的 Hui 框架作者:https://gitee.com/monksoul/Hui

093920826fa8b285c326164d0422ff9b.png

8、曾经被 NodeJS 官方推荐的 Monk.Node 框架作者:https://gitee.com/monksoul/Monk.Node

37a0096561e65a8296421832dbef7abe.png

9、前端 Javascript 验证库的作者:https://gitee.com/monksoul/availdate.js

f0a8d0d2c03f501cf46f642c3e079b78.png

由于篇幅优先,就不一一例举,感兴趣的可以去访问我 Gitee 个人主页:https://gitee.com/monksoul

沉默时光

在 .NET 领域,有两个主流的定时任务库,一个是 Quartz.NET,另外一个是 Hangfire,过去十年,所有接手的项目中只要涉及到定时任务就离不开这两个库,也只有这个选择,但它们属于国外大神作品,从功能需求上不能自主可控。

随着编程思维和技术的增长,慢慢有了自主创造的意识,所以于 2021 年 11 月就萌生出自己写定时任务的想法,它必须是国人完全自主的分布式毫秒级定时任务,为此我做了长足的准备。

不鸣则已

为了编写无依赖的分布式定时任务,我花费了 9 个月的时间去学习这些知识,见证我创建该库的心路历程:https://gitee.com/dotnetchina/Sundial/issues/I4IL3U

  • 必须了解 Cron 表达式所有原理

  • 必须了解 多线程、信号量,互斥锁,任务,绿色线程,线程 Token 知识

  • 必须了解 TCP/IP 知识,实现集群控制,持久化控制

  • 必须了解 CPU 休眠原理,唤醒原理,解决线程如何唤醒,休眠总时间计算

  • 必须了解 Hash 表,链表知识,数据结构和算法,解决作业内存存储问题

  • 必须了解 队列,管道通讯知识,解决作业运行时状态改变通知问题

  • 必须了解 反射知识,IOC/DI 知识,设计模式,架构设计,为以后拓展和维护

  • 还有很多很多小知识

一鸣惊人

经过了将近 10 个月的开发,测试,迭代,Sundial 诞生了,编写了超 10 万字文档。

https://furion.baiqian.ltd/docs/job

3cb41b7beb5f5f9451a88071f2033a27.png

一睹尊容

Sundial

licenseMIT:https://gitee.com/dotnetchina/Sundial/blob/master/LICENSE

nugetv2.5.0:https://www.nuget.org/packages/Sundial

dotNET China:https://gitee.com/dotnetchina

.NET 功能齐全的开源分布式作业调度系统,可从最小的应用程序到大型企业系统使用。

82bc83c3d1b5386cf4e69ca34ee28474.png

特性

  • 简化调度作业

    • 支持作业监视器

    • 支持作业执行器

    • 支持自定义作业存储组件(持久化)

    • 支持自定义策略执行

    • 内置周期、Cron 作业

    • 支持自定义作业触发器

    • 支持依赖注入控制(含 HTTP 控制支持)

  • 高内聚,低耦合,使代码更简单

  • 很小,仅41KB

  • 无第三方依赖

  • 可在Windows/Linux/MacOS守护进程部署

  • 支持分布式、集群(多实例)部署

  • 支持负载均衡(基于 TCP/IP)

  • 高质量代码和良好单元测试

  • 跨平台,支持 .NET5+

安装

  • Package Manager

Install-PackageSundial

  • .NET CLI

dotnetaddpackageSundial

快速入门

我们在主页上有不少例子,这是让您入门的第一个:

1、定义作业,并实现IJob接口:

public class MyJob : IJob
{
    private readonly ILogger<MyJob> _logger;

    public MyJob(ILogger<MyJob> logger)
    {
        _logger = logger;
    }

    public async Task ExecuteAsync(JobExecutingContext context, CancellationToken stoppingToken)
    {
        _logger.LogInformation($"{context.JobDetail}  {context.Trigger} {context.OccurrenceTime}");
        await Task.CompletedTask;
    }
}

2、在Startup.cs注册AddSchedule服务和作业:

services.AddSchedule(options =>
{
    options.AddJob<MyJob>(Triggers.PeriodSeconds(5)
                , Triggers.Minutely());
});

3、运行项目:

info: System.Logging.ScheduleService[0]
      Schedule Hosted Service is running.
warn: System.Logging.ScheduleService[0]
      Schedule Hosted Service cancels hibernation and GC.Collect().
info: System.Logging.ScheduleService[0]
      The Scheduler of <job1> successfully updated to the schedule.
info: Sundial.Samples.MyJob[0]
      <job1>   <job1 job1_trigger2>  5000ms 2022/11/23 16:22:51
info: Sundial.Samples.MyJob[0]
      <job1>   <job1 job1_trigger2>  5000ms 2022/11/23 16:22:56
info: Sundial.Samples.MyJob[0]
      <job1>   <job1 job1_trigger3>  * * * * * 2022/11/23 16:23:00
info: Sundial.Samples.MyJob[0]
      <job1>   <job1 job1_trigger2>  5000ms 2022/11/23 16:23:01
info: Sundial.Samples.MyJob[0]
      <job1>   <job1 job1_trigger2>  5000ms 2022/11/23 16:23:07

更多文档:https://furion.baiqian.ltd/docs/job/

文档

可以在主页找到Sundial文档:https://furion.baiqian.ltd/docs/job/

贡献

该存储库的主要目的是继续发展 Sundial 核心,使其更快、更易于使用。Sundial 的开发在Gitee上公开进行,我们感谢社区贡献错误修复和改进。

转自:oschina.net

链接:oschina.net/news/219126/sundial-released


版权声明:本文来源于网友收集或网友提供,仅供学习交流之用,如果有侵权,请转告版主或者留言,本公众号立即删除。

- EOF -

技术群:添加小编微信dotnet999

公众号:dotnet讲堂

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值