Flaminco.TickCronos
1.0.1
dotnet add package Flaminco.TickCronos --version 1.0.1
NuGet\Install-Package Flaminco.TickCronos -Version 1.0.1
<PackageReference Include="Flaminco.TickCronos" Version="1.0.1" />
paket add Flaminco.TickCronos --version 1.0.1
#r "nuget: Flaminco.TickCronos, 1.0.1"
// Install Flaminco.TickCronos as a Cake Addin #addin nuget:?package=Flaminco.TickCronos&version=1.0.1 // Install Flaminco.TickCronos as a Cake Tool #tool nuget:?package=Flaminco.TickCronos&version=1.0.1
Flaminco.TickCronos
Flaminco.TickCronos is a flexible and lightweight .NET package designed for cron-based background job scheduling. Utilizing the high-performance .NET 8 TimeProvider, TickCronons ensures precise and efficient timing, while allowing you to set unique TimeProvider configurations for each scheduled task.
Features
- Cron-based scheduling with second-level precision.
- High-performance timing with .NET 8 TimeProvider.
- Flexible time zone support for individual jobs.
- Scoping support for dependency injection within job execution.
Installation
Install Flaminco.TickCronos via NuGet:
dotnet add package Flaminco.TickCronos
Getting Started
Step 1: Create a Cron Job
Inherit from TickCrononsJobService
to create your job class, implementing the ExecuteAsync
method where the job logic is defined.
public class MyTickCronosExample1 : TickCrononsJobService
{
public MyTickCronosExample1(ITickCrononsConfig<MyTickCronosExample1> config, IServiceProvider serviceProvider, ILogger<MyTickCronosExample1> logger)
: base(config.CronExpression, config.TimeProvider, serviceProvider, logger) { }
public override string CronJobName => nameof(MyTickCronosExample1);
public override async Task ExecuteAsync(IServiceScope scope, CancellationToken cancellationToken)
{
// Define your scheduled job logic
Console.WriteLine("Running scheduled job for MyTickCronosExample1...");
await Task.Delay(1000, cancellationToken); // Simulated work
}
}
public class MyTickCronosExample2(ITickCronosConfig<MyTickCronosExample2> config, IServiceProvider serviceProvider, ILogger<MyTickCronosExample2> logger)
: TickCronosJobService(config.CronExpression, config.TimeProvider, serviceProvider, logger)
{
public override string CronJobName => nameof(MyTickCronosExample2);
public override async Task ExecuteAsync(IServiceScope scope, CancellationToken cancellationToken)
{
// Your job logic here
Console.WriteLine("Running scheduled job...");
await Task.Delay(1000, cancellationToken); // Simulated work
}
}
Step 2: Configure and Register Jobs
In your application setup (e.g., Program.cs
), use AddTickCronosJob
to configure and add your job with a cron expression and time provider.
builder.Services.AddTickCronosJob<MyTickCronosExample1>(a =>
{
a.CronExpression = "*/5 * * * * *"; // Every 5 seconds
a.TimeProvider = TimeProvider.System; // default if not provided
});
builder.Services.AddTickCronosJob<MyTickCronosExample2>(a =>
{
a.CronExpression = "*/5 * * * * *"; // Every 5 seconds
a.TimeProvider = new EgyptTimeProvider();
});
Custom Time Provider Example
TickCronons allows for custom time providers. Here�s an example of a TimeZoneTimeProvider
to run jobs in a specific time zone.
public class EgyptTimeProvider : TimeProvider
{
private readonly TimeZoneInfo _timeZoneInfo = TimeZoneInfo.FindSystemTimeZoneById("Egypt Standard Time");
public override DateTimeOffset GetUtcNow()
{
return TimeZoneInfo.ConvertTime(DateTimeOffset.UtcNow, _timeZoneInfo);
}
public override TimeZoneInfo LocalTimeZone => _timeZoneInfo;
}
Configuration Options
- CronExpression: Defines the cron schedule.
- TimeProvider: Customize time zones or use the default system time.
Logging
Flaminco.TickCronos logs job status, execution times, and errors using the .NET ILogger
. Ensure logging is set up in your application to capture job activities.
License
This project is licensed under the MIT License.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. 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. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net8.0
- Cronos (>= 0.8.4)
- Microsoft.Extensions.Hosting.Abstractions (>= 8.0.1)
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.0.1 | 108 | 11/9/2024 |