Excalibur.LeaderElection
3.0.0-alpha.19
dotnet add package Excalibur.LeaderElection --version 3.0.0-alpha.19
NuGet\Install-Package Excalibur.LeaderElection -Version 3.0.0-alpha.19
<PackageReference Include="Excalibur.LeaderElection" Version="3.0.0-alpha.19" />
<PackageVersion Include="Excalibur.LeaderElection" Version="3.0.0-alpha.19" />
<PackageReference Include="Excalibur.LeaderElection" />
paket add Excalibur.LeaderElection --version 3.0.0-alpha.19
#r "nuget: Excalibur.LeaderElection, 3.0.0-alpha.19"
#:package Excalibur.LeaderElection@3.0.0-alpha.19
#addin nuget:?package=Excalibur.LeaderElection&version=3.0.0-alpha.19&prerelease
#tool nuget:?package=Excalibur.LeaderElection&version=3.0.0-alpha.19&prerelease
Excalibur.LeaderElection
Distributed leader election infrastructure for the Excalibur framework.
Installation
dotnet add package Excalibur.LeaderElection
Features
ILeaderElection- Leader election abstractionILeaderElectionFactory- Factory for multi-resource leadershipIHealthBasedLeaderElection- Health-aware leader electionInMemoryLeaderElection- In-memory implementation for testing- TypeForwarders for backward compatibility
- AOT-compatible with full Native AOT support
Usage
// Register leader election with in-memory (for testing)
services.AddInMemoryLeaderElection();
// Subscribe to leadership changes
leaderElection.LeaderChanged += (sender, args) =>
{
if (args.IsLeader)
Console.WriteLine("I am now the leader!");
};
// Acquire leadership
await leaderElection.AcquireLeadershipAsync(cancellationToken);
Provider Packages
Choose the provider that matches your infrastructure:
| Package | Backend | Use Case |
|---|---|---|
Excalibur.LeaderElection.SqlServer |
SQL Server | On-premises, Azure SQL |
Excalibur.LeaderElection.Redis |
Redis | High-performance, distributed cache |
Excalibur.LeaderElection.Consul |
HashiCorp Consul | Service mesh, multi-datacenter |
Excalibur.LeaderElection.Kubernetes |
Kubernetes Lease API | Cloud-native Kubernetes deployments |
Related Packages
Excalibur.Dispatch.LeaderElection.Abstractions- Canonical interfaces
License
This project is multi-licensed under:
See LICENSE for details.
| 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 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. |
-
net10.0
- Excalibur.Dispatch.Abstractions (>= 3.0.0-alpha.19)
- Excalibur.Dispatch.LeaderElection.Abstractions (>= 3.0.0-alpha.19)
- Medo.Uuid7 (>= 1.4.0)
- Microsoft.Extensions.Configuration.Abstractions (>= 10.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Diagnostics.HealthChecks (>= 10.0.0)
- Microsoft.Extensions.Diagnostics.HealthChecks.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Hosting.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Options (>= 10.0.0)
- Microsoft.Extensions.Options.DataAnnotations (>= 10.0.0)
-
net8.0
- Excalibur.Dispatch.Abstractions (>= 3.0.0-alpha.19)
- Excalibur.Dispatch.LeaderElection.Abstractions (>= 3.0.0-alpha.19)
- Medo.Uuid7 (>= 1.4.0)
- Microsoft.Extensions.Configuration.Abstractions (>= 10.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Diagnostics.HealthChecks (>= 10.0.0)
- Microsoft.Extensions.Diagnostics.HealthChecks.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Hosting.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Options (>= 10.0.0)
- Microsoft.Extensions.Options.DataAnnotations (>= 10.0.0)
- System.Diagnostics.DiagnosticSource (>= 10.0.0)
-
net9.0
- Excalibur.Dispatch.Abstractions (>= 3.0.0-alpha.19)
- Excalibur.Dispatch.LeaderElection.Abstractions (>= 3.0.0-alpha.19)
- Medo.Uuid7 (>= 1.4.0)
- Microsoft.Extensions.Configuration.Abstractions (>= 10.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Diagnostics.HealthChecks (>= 10.0.0)
- Microsoft.Extensions.Diagnostics.HealthChecks.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Hosting.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 10.0.0)
- Microsoft.Extensions.Options (>= 10.0.0)
- Microsoft.Extensions.Options.DataAnnotations (>= 10.0.0)
- System.Diagnostics.DiagnosticSource (>= 10.0.0)
NuGet packages (7)
Showing the top 5 NuGet packages that depend on Excalibur.LeaderElection:
| Package | Downloads |
|---|---|
|
Excalibur.Hosting
Core hosting infrastructure for Excalibur applications, including bootstrap and lifecycle integration for web and worker hosts. |
|
|
Excalibur.LeaderElection.Kubernetes
Kubernetes-based leader election implementation for the Excalibur framework. Provides distributed coordination using Kubernetes Lease resources for cloud-native applications. |
|
|
Excalibur.Data.Postgres
Postgres database provider implementation for Excalibur data access layer. |
|
|
Excalibur.LeaderElection.Consul
Consul-based leader election implementation for the Excalibur framework using session-based distributed locking. |
|
|
Excalibur.LeaderElection.InMemory
In-memory leader election implementation for the Excalibur framework. Suitable for single-process scenarios, testing, and development. |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 3.0.0-alpha.19 | 36 | 2/26/2026 |