翼度科技»论坛 编程开发 .net 查看内容

.NET 轻量化定时任务调度 FreeScheduler

7

主题

7

帖子

21

积分

新手上路

Rank: 1

积分
21
前言

在平时项目开发中,定时任务调度是一项重要的功能,广泛应用于后台作业、计划任务和自动化脚本等模块。
FreeScheduler 是一款轻量级且功能强大的定时任务调度库,它支持临时的延时任务和重复循环任务(可持久化),能够按秒、每天/每周/每月固定时间或自定义间隔执行(CRON 表达式)。
此外 FreeScheduler 还支持 .NET Framework 4.0、.NET Core 2.1+ 以及 Xamarin、MAUI 等平台。
本文将介绍 FreeScheduler 的基本功能和使用方法,能够立即上手使用,帮助我们快速 轻松的管理和调度定时任务,无论是用于个人项目还是企业级应用都是一个不错的选择,快来试试吧。
项目介绍

FreeScheduler 是一款基于 IdleBus 实现的轻量化定时任务调度库,支持集群部署、临时的延时任务和重复循环任务(可持久化)。
它可以按秒、每天/每周/每月固定时间或自定义间隔执行任务,并兼容 .NET Core 2.1+ 和 .NET Framework 4.0+ 运行环境。

  • 轻量化解释
了解 FreeRedis、FreeSql、csredis 的人都知道,我们发布的开源项目是绿色著称,零依赖发布后只有一个DLL,不会造成使用者项目依赖冲突,支持 .NET 4.0 堪称屎山项目的救星。现在还有很多.NET FX 4.0 的项目,这些项目因历史遗留原因或硬件限制,不能更换 .NET Core 版本。因此这些项目很难使用到现有的开源库,不能使用可靠的开源库,那么很多时候都要自行实现,在堆积代码的同时,项目也有可能越来越乱,代码越来越渣,项目逐渐变得不稳定。

  • 特色功能之一
持久化,比如创建订单半小时未支付,给用户催发短信,这种动态任务会用到技久化。

  • 特色功能之二
FreeScheduler 支持一个任务设置 [5,5,30,30,60] 不同的定时间隔,任何一次成功都可结束整个任务。
项目使用

1、安装相关Nuget包 
  1. dotnet add package FreeScheduler
复制代码
或者 
  1. Install-Package FreeScheduler
复制代码

2、对应 Program.cs
  1. using FreeScheduler;
  2. Scheduler scheduler = new FreeSchedulerBuilder()
  3.     .OnExecuting(task =>
  4.     {
  5.         Console.WriteLine($"[{DateTime.Now.ToString("HH:mm:ss.fff")}] {task.Topic} 被执行");
  6.         task.Remark("log..");
  7.     })
  8.     .Build();
  9. if (Datafeed.GetPage(scheduler, null, null, null, null).Total == 0)
  10. {
  11.     scheduler.AddTask("[系统预留]清理任务数据", "86400", -1, 3600);
  12.     scheduler.AddTaskRunOnWeek("(周一)武林大会", "json", -1, "1:12:00:00");
  13.     scheduler.AddTaskRunOnWeek("(周日)亲子活动", "json", -1, "0:00:00:00");
  14.     scheduler.AddTaskRunOnWeek("(周六)社交活动", "json", -1, "6:00:00:00");
  15.     scheduler.AddTaskRunOnMonth("月尾最后一天", "json", -1, "-1:16:00:00");
  16.     scheduler.AddTaskRunOnMonth("月初第一天", "json", -1, "1:00:00:00");
  17.     scheduler.AddTask("定时20秒", "json", 10, 20);
  18.     scheduler.AddTask("测试任务1", "json", new[] { 10, 30, 60, 100, 150, 200 });
  19. }
  20. var builder = WebApplication.CreateBuilder(args);
  21. builder.Services.AddControllers();
  22. builder.Services.AddEndpointsApiExplorer();
  23. builder.Services.AddSwaggerGen();
  24. builder.Services.AddSingleton(scheduler);
  25. var app = builder.Build();
  26. if (app.Environment.IsDevelopment())
  27. {
  28.     app.UseSwagger();
  29.     app.UseSwaggerUI();
  30. }
  31. app.UseFreeSchedulerUI("/freescheduler/");
  32. app.UseHttpsRedirection();
  33. app.UseAuthorization();
  34. app.MapControllers();
  35. app.Run();
复制代码
方法解释

打开浏览器访问 http://localhost:5000/freescheduler/ ,就可以看到我们设置的任务。

项目特点


  • 支持 单项目,多站点部署
  • 支持 多进程,不重复执行
  • 支持 进程退出后,由其他进程重新加载任务(约30秒后)
  • 支持 进程互通,任意进程都可以执行(RemoveTask/ExistsTask/PauseTask/RunNowTask/RemoveTempTask/ExistsTempTask)
  • 支持 进程意外离线后,卸载进程内的任务,重新安排上线
1、临时任务(不可持久化)
  1. void Callback()
  2. {
  3.     Console.WriteLine("时间到了");
  4.     scheduler.AddTempTask(TimeSpan.FromSeconds(10), Callback); //下一次定时
  5. }
  6. scheduler.AddTempTask(TimeSpan.FromSeconds(10), Callback);
复制代码
方法解释

2、循环任务/可持久化
  1. //每5秒触发,执行N次
  2. var id = scheduler.AddTask("topic1", "body1", round: -1, 5);
  3. //每次 不同的间隔秒数触发,执行6次
  4. var id = scheduler.AddTask("topic1", "body1", new [] { 5, 5, 10, 10, 60, 60 });
  5. //每天 20:00:00 触发,执行N次(注意设置时区 UseTimeZone)
  6. var id = scheduler.AddTaskRunOnDay("topic1", "body1", round: -1, "20:00:00");
  7. //每周一 20:00:00 触发,执行1次
  8. var id = scheduler.AddTaskRunOnWeek("topic1", "body1", round: 1, "1:20:00:00");
  9. //每月1日 20:00:00 触发,执行12次
  10. var id = scheduler.AddTaskRunOnMonth("topic1", "body1", round: 12, "1:20:00:00");
  11. //每月最后一日 20:00:00 触发,执行12次
  12. var id = scheduler.AddTaskRunOnMonth("topic1", "body1", round: 12, "-1:20:00:00");
  13. //自定义间隔 cron
  14. var id = scheduler.AddTaskCustom("topic1", "body1", "0/1 * * * * ? ");
  15. new FreeSchedulerBuilder()
  16.     ...
  17.     .UseCustomInterval(task =>
  18.     {
  19.         //利用 cron 功能库解析 task.IntervalArgument 得到下一次执行时间
  20.         //与当前时间相减,得到 TimeSpan,若返回 null 则任务完成
  21.         return TimeSpan.FromSeconds(5);
  22.     })
  23.     .Build();
复制代码
方法说明

3、预留任务
[系统预留]清理任务数据
  1. //每小时触发,定期清理24小时之前的数据(单位:秒)
  2. scheduler.AddTask("[系统预留]清理任务数据", "86400", round: -1, 3600);
复制代码
4、管理任务
  1. // 使用 FreeSql 或者 SQL 查询 TaskInfo、TaskLog 两个表进行分页显示
  2. fsql.Select<TaskInfo>().Count(out var total).Page(pageNumber, 30).ToList();
  3. fsql.Select<TaskLog>().Count(out var total).Page(pageNumber, 30).ToList();
  4. //暂停任务
  5. scheduler.PauseTask(id);
  6. //恢复暂停的任务
  7. scheduler.ResumeTask(id);
  8. //删除任务
  9. scheduler.RemoveTask(id);
  10. //立刻运行任务(人工触发)
  11. scheduler.RunNowTask(id);
复制代码
性能参考

FluentScheduler 单个 Registry 测试正常,但目测单线程执行(间隔1-10ms),处理速度不理想
尝试把 FreeScheduler 内核改成 HashedWheelTimer 内存占用更高(600兆),
结论 FreeScheduler 功能需要占用更多资源

项目地址

Gitee:https://gitee.com/hubo/FreeScheduler
Github:https://github.com/2881099/FreeScheduler
文档:https://freesql.net/guide/freescheduler.html
最后

如果你觉得这篇文章对你有帮助,不妨点个赞支持一下!你的支持是我继续分享知识的动力。如果有任何疑问或需要进一步的帮助,欢迎随时留言。也可以加入微信公众号 [DotNet技术匠] 社区,与其他热爱技术的同行一起交流心得,共同成长!


来源:https://www.cnblogs.com/1312mn/p/18356212
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具