https://mp.weixin.qq.com/s/b0kWM4wkumxSghctnTvY2Q

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

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

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

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

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

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

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

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

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

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

图片
由于篇幅优先,就不一一例举,感兴趣的可以去访问我 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

图片
一睹尊容
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 功能齐全的开源分布式作业调度系统,可从最小的应用程序到大型企业系统使用。

图片
特性
简化调度作业

支持作业监视器
支持作业执行器
支持自定义作业存储组件(持久化)
支持自定义策略执行
内置周期、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/

文档更新时间: 2023-11-18 13:19   作者:admin