Simplify.Scheduler
1.5.0
dotnet add package Simplify.Scheduler --version 1.5.0
NuGet\Install-Package Simplify.Scheduler -Version 1.5.0
<PackageReference Include="Simplify.Scheduler" Version="1.5.0" />
paket add Simplify.Scheduler --version 1.5.0
#r "nuget: Simplify.Scheduler, 1.5.0"
// Install Simplify.Scheduler as a Cake Addin #addin nuget:?package=Simplify.Scheduler&version=1.5.0 // Install Simplify.Scheduler as a Cake Tool #tool nuget:?package=Simplify.Scheduler&version=1.5.0
Simplify.Scheduler Documentation
Same as Simplify.WindowsServices library with removed Windows Services
dependency and specifically made for console (docker) execution.
Provides BasicScheduler
, SingleTaskScheduler
, MultitaskScheduler
classes for scheduling.
Allows you to simply create applications which can work on schedule. Every user class instance will be instantiated using Simplify.DI IOC container which provides DI by default for your application.
Available at NuGet as binary package
Principle of work
To use Simplify.Scheduler, you must create a class with the Run
method in it and pass this class to the handler as a type parameter. The Run
method will be invoked by the handler class (the handler types are listed below), this method will be your execution process root. An instance of your class will be created using the IOC Simplify.DI
container, so you can register any types that your class depends on through DIContainer.Current
, and they will be automatically resolved.
Run
method can be one of the following:
- Parameterless
Run()
method. Run(string serviceName)
if you want to access a service name.Run(IJobArgs args)
if you want to access a service name or startup parameters.
Run method can be void
or can return Task
(can be used for async/await code).
Quick start
There is a templates package available at nuget.org for Simplify.Scheduler.
Install Simplify.ProjectsTemplates
templates package:
dotnet new -i Simplify.ProjectsTemplates
Create an initial Simplify.Scheduler based project:
dotnet new simplify.scheduler -n HelloWorld
Types of Schedulers
BasicScheduler
BasicScheduler
class is best suited for services that run without timers, for example, a TCP server or client.
SingleTaskScheduler
SingleTaskScheduler
class is best suited to perform one task, which must be periodically started by a timer.
MultitaskScheduler
MultitaskScheduler
class is best suited for multiple tasks services.
This is the same as SingleTaskScheduler
but allows you to specify multiple working classes/methods.
You can add multiple jobs with different timer intervals/crontab expressions.
You can use single class with several methods, each specified method will be launched by the corresponding task (a new instance of the class will be created), or simply use several classes.
MultitaskScheduler working example
Setup a job schedule
You can specify timer intervals in seconds or just set the Ncrontab expression for timer. If no settings specified in the configuration, then the timer will be executed once every minute. If both timer interval and crontab expression specified in the config, then the crontab expression will be used instead.
Multiple crontab expressions can be specified, for example: 30 14 * * *|45 1 * * *|0 12 * * Mon
The main way to setup a job is to pass configuration based on Microsoft.Extensions.Configuration.IConfiguration
Example
Program.cs
var configuration = new ConfigurationBuilder()
.AddJsonFile("appsettings.json", false)
.Build();
using(var handler = new SingleTaskScheduler<MyClass>(configuration))
handler.Start();
appsettings.json
{
"JobSettings":
{
"CrontabExpression": "* * * * *",
"ProcessingInterval: 30
}
}
Additional settings
Option | default value | Description |
---|---|---|
CleanupOnTaskFinish | true | Execute GC.Collect(); after each "Run" method execution |
MaximumParallelTasksCount | 1 (so the only one task of the same job can exist at a time) | The maximum allowed parallel tasks of the same job (the new task will be create in parallel if previous task is not ended execution) |
Global exceptions catching which can be thrown when resolving instances by Simplify.DI in handler
Simplify.Scheduler
can catch all exceptions thrown by user code.
To receive such an event you should subscribe to handler OnException event.
static void Main(string[] args)
{
...
handler.OnException += OnException;
...
}
static void OnException(ServiceExceptionArgs args)
{
Console.Write(args.ServiceName);
Console.Write(args.Exception.Message);
}
Examples
BasicScheduler
MyClass.cs
public class MyClass
{
public void Run()
{
// Some task
}
}
Program.cs
static void Main(string[] args)
{
DIContainer.Current.Register<MyClass>();
using(var scheduler = new BasicScheduler<MyClass>())
scheduler.Start(args)
}
SingleTaskScheduler
static void Main(string[] args)
{
DIContainer.Current.Register<MyClass>();
using(var scheduler = new SingleTaskScheduler<MyClass>)
scheduler.Start(args);
}
MultitaskScheduler
Program.cs
static void Main(string[] args)
{
// Registering in IOC container
DIContainer.Current.Register<TaskProcessor1>();
DIContainer.Current.Register<TaskProcessor2>();
// Handler creation
using(var handler = new MultitaskScheduler())
{
// Jobs addition
// If configuration section is not specified then 'YourClassName + Settings' section name will be used
handler.AddJob<TaskProcessor1>();
// Manually specified section name and invoke method name
handler.AddJob<TaskProcessor1>("TaskProcessor1SecondTaskSettings", "RunTask2");
handler.AddJob<TaskProcessor2>();
handler.Start(args);
}
}
TaskProcessor1.cs
public class TaskProcessor1
{
public void Run()
{
Debug.WriteLine("TaskProcessor1 Run executed");
}
public void RunTask2()
{
Debug.WriteLine("TaskProcessor1 RunTask2 executed");
}
}
TaskProcessor2.cs
public class TaskProcessor2
{
public void Run()
{
Debug.WriteLine("TaskProcessor2 Run executed");
}
}
appsettings.json
{
"TaskProcessor1Settings": {
"CrontabExpression": "*/2 * * * *"
},
"TaskProcessor1SecondTaskSettings": {
"ProcessingInterval": 30
},
"TaskProcessor2Settings": {
"ProcessingInterval": 45
}
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 is compatible. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 is compatible. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETFramework 4.8
- Microsoft.Extensions.Configuration (>= 3.1.32)
- ncrontab (>= 3.3.1)
- Simplify.DI (>= 4.2.10)
- Simplify.System (>= 1.6.2)
-
.NETStandard 2.0
- Microsoft.Extensions.Configuration (>= 3.1.32)
- ncrontab (>= 3.3.1)
- Simplify.DI (>= 4.2.10)
- Simplify.System (>= 1.6.2)
-
.NETStandard 2.1
- Microsoft.Extensions.Configuration (>= 3.1.32)
- ncrontab (>= 3.3.1)
- Simplify.DI (>= 4.2.10)
- Simplify.System (>= 1.6.2)
-
net6.0
- Microsoft.Extensions.Configuration (>= 3.1.32)
- ncrontab (>= 3.3.1)
- Simplify.DI (>= 4.2.10)
- Simplify.System (>= 1.6.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.5.0 | 183 | 6/2/2024 |
1.4.0 | 177 | 1/9/2024 |
1.3.1 | 241 | 8/24/2023 |
1.3.0 | 1,736 | 11/18/2021 |
1.2.0 | 766 | 5/25/2021 |
1.1.2 | 376 | 5/24/2021 |
1.1.0 | 668 | 2/4/2021 |
1.0.1 | 354 | 2/2/2021 |
1.0.0 | 944 | 6/27/2020 |
1.0.0-pre05 | 409 | 12/9/2019 |
1.0.0-pre03 | 395 | 9/26/2019 |
1.0.0-pre02 | 366 | 9/12/2019 |
1.0.0-pre01 | 371 | 8/25/2019 |