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/