LScheduler.Redis
0.1.0
dotnet add package LScheduler.Redis --version 0.1.0
NuGet\Install-Package LScheduler.Redis -Version 0.1.0
<PackageReference Include="LScheduler.Redis" Version="0.1.0" />
<PackageVersion Include="LScheduler.Redis" Version="0.1.0" />
<PackageReference Include="LScheduler.Redis" />
paket add LScheduler.Redis --version 0.1.0
#r "nuget: LScheduler.Redis, 0.1.0"
#:package LScheduler.Redis@0.1.0
#addin nuget:?package=LScheduler.Redis&version=0.1.0
#tool nuget:?package=LScheduler.Redis&version=0.1.0
LScheduler
LScheduler is a lightweight embedded .NET job scheduler for single-process applications.
It supports:
- Cron schedules
- recurring interval schedules
- one-time delay schedules
- retry policies
- file persistence by default
- optional SQLite / MySQL / SQL Server / Redis stores
- persistent jobs that survive process restarts
- in-memory jobs for temporary runtime work
Quick Start
Default registration uses file persistence.
using LScheduler;
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddLScheduler();
var app = builder.Build();
var scheduler = app.Services.GetRequiredService<JobScheduler>();
await scheduler.AddJobAsync(
"heartbeat",
JobSchedule.Every(TimeSpan.FromSeconds(30)),
DemoJobs.HeartbeatAsync);
await app.RunAsync();
public static class DemoJobs
{
public static Task HeartbeatAsync(CancellationToken cancellationToken)
{
Console.WriteLine($"[{DateTime.UtcNow:O}] heartbeat");
return Task.CompletedTask;
}
}
What this gives you:
- a singleton
JobScheduler - hosted startup and shutdown
- file persistence in
AppContext.BaseDirectory/lscheduler-data - persisted schedule metadata, retry policy, next run time, method identity, and optional payload
Packages
LSchedulerLScheduler.SqliteLScheduler.MySqlLScheduler.SqlServerLScheduler.Redis
Core API
Resolve JobScheduler from DI and register jobs at runtime:
var scheduler = app.Services.GetRequiredService<JobScheduler>();
Use AddJobAsync(...) for persistent jobs.
Use AddInMemoryJobAsync(...) for temporary runtime work such as lambdas and closures.
JobSchedule supports:
- Cron
- recurring intervals
- one-time delay
- daily / weekly / monthly / yearly builder-style schedules
Documentation
- Configuration and appsettings
- Storage providers
- Jobs, schedules, retries, and runtime APIs
- Persistence and restart restoration
- Worker / ASP.NET Core integration patterns
- Releasing packages
Key Rules
Persistent jobs require a direct public method group on a stable named type.
Good fits:
- public static methods
- public instance methods on DI services
- public instance methods on constructible types
Use AddInMemoryJobAsync(...) for:
- lambdas
- closures
- local functions
- compiler-generated delegates
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 is compatible. 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 is compatible. 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 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 is compatible. 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. net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.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 was computed. 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. |
-
.NETStandard 2.0
- LScheduler (>= 0.1.0)
- Microsoft.Bcl.AsyncInterfaces (>= 8.0.0)
- StackExchange.Redis (>= 2.12.4)
- System.Text.Json (>= 8.0.5)
-
.NETStandard 2.1
- LScheduler (>= 0.1.0)
- StackExchange.Redis (>= 2.12.4)
- System.Text.Json (>= 8.0.5)
-
net10.0
- LScheduler (>= 0.1.0)
- StackExchange.Redis (>= 2.12.4)
-
net5.0
- LScheduler (>= 0.1.0)
- StackExchange.Redis (>= 2.12.4)
-
net6.0
- LScheduler (>= 0.1.0)
- StackExchange.Redis (>= 2.12.4)
-
net7.0
- LScheduler (>= 0.1.0)
- StackExchange.Redis (>= 2.12.4)
-
net8.0
- LScheduler (>= 0.1.0)
- StackExchange.Redis (>= 2.12.4)
-
net9.0
- LScheduler (>= 0.1.0)
- StackExchange.Redis (>= 2.12.4)
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 |
|---|---|---|
| 0.1.0 | 108 | 3/23/2026 |