KubeOps.Operator
9.2.0
dotnet add package KubeOps.Operator --version 9.2.0
NuGet\Install-Package KubeOps.Operator -Version 9.2.0
<PackageReference Include="KubeOps.Operator" Version="9.2.0" />
paket add KubeOps.Operator --version 9.2.0
#r "nuget: KubeOps.Operator, 9.2.0"
// Install KubeOps.Operator as a Cake Addin #addin nuget:?package=KubeOps.Operator&version=9.2.0 // Install KubeOps.Operator as a Cake Tool #tool nuget:?package=KubeOps.Operator&version=9.2.0
KubeOps Operator
The KubeOps.Operator
package provides a framework
for building Kubernetes operators in .NET.
It is built on top of the Kubernetes client libraries for .NET
and provides a set of abstractions and utilities for implementing
operators that manage custom resources in a Kubernetes cluster.
Getting Started
To get started with the SDK, you can install it from NuGet:
dotnet add package KubeOps.Operator
Once you have installed the package, you can create entities, controllers, finalizers, and more to implement your operator.
All resources must be added to the operator builder in order to be recognized by the SDK and to be used as operator resources. The KubeOps.Generator helps with convenience methods to register everything at once.
You'll need to use the Generic Host to run your operator. However, for a plain operator without webhooks, no ASP.net is required (in contrast to v7).
using KubeOps.Operator;
using Microsoft.Extensions.Hosting;
using Microsoft.Extensions.Logging;
var builder = Host.CreateApplicationBuilder(args);
builder.Logging.SetMinimumLevel(LogLevel.Trace);
builder.Services
.AddKubernetesOperator()
.RegisterComponents();
using var host = builder.Build();
await host.RunAsync();
Registering Resources
When using the KubeOps.Generator,
you can use the RegisterResources
function:
builder.Services
.AddKubernetesOperator()
.RegisterComponents();
Otherwise, you can register resources manually:
builder.Services
.AddKubernetesOperator()
.AddController<TestController, V1TestEntity>()
.AddFinalizer<FirstFinalizer, V1TestEntity>("first")
.AddFinalizer<SecondFinalizer, V1TestEntity>("second")
Entity
To create an entity, you need to implement the
IKubernetesObject<V1ObjectMeta>
interface. There are convenience
classes available to help with initialization, status and spec
properties.
[KubernetesEntity(Group = "testing.dev", ApiVersion = "v1", Kind = "TestEntity")]
public class V1TestEntity :
CustomKubernetesEntity<V1TestEntity.EntitySpec, V1TestEntity.EntityStatus>
{
public override string ToString()
=> $"Test Entity ({Metadata.Name}): {Spec.Username} ({Spec.Email})";
public class EntitySpec
{
public string Username { get; set; } = string.Empty;
public string Email { get; set; } = string.Empty;
}
public class EntityStatus
{
public string Status { get; set; } = string.Empty;
}
}
Controller
A controller is the element that reconciles a specific entity. You can reconcile your own custom entities or all other entities as long as they are registered within the SDK. For a guide on how to reconcile external entities, refer to the documentation.
A simple controller could look like this:
[EntityRbac(typeof(V1TestEntity), Verbs = RbacVerb.All)]
public class V1TestEntityController : IEntityController<V1TestEntity>
{
private readonly IKubernetesClient _client;
private readonly EntityFinalizerAttacher<FinalizerOne, V1TestEntity> _finalizer1;
public V1TestEntityController(
IKubernetesClient client,
EntityFinalizerAttacher<FinalizerOne, V1TestEntity> finalizer1)
{
_client = client;
_finalizer1 = finalizer1;
}
public async Task ReconcileAsync(V1TestEntity entity)
{
_logger.LogInformation("Reconciling entity {Entity}.", entity);
entity = await _finalizer1(entity);
entity.Status.Status = "Reconciling";
entity = await _client.UpdateStatus(entity);
entity.Status.Status = "Reconciled";
await _client.UpdateStatus(entity);
}
}
This controller attaches a specific finalizer to the entity, updates its status and then saves the entity.
[!CAUTION] It is important to always use the returned values of an entity when using modifying actions of the Kubernetes client. Otherwise, you will receive "HTTP CONFLICT" errors because of the resource version field in the entity.
[!NOTE] Do not update the entity itself in the reconcile loop. It is considered bad practice to update entities while reconciling them. However, the status may be updated. To update entities before they are reconciled (e.g. to ban certain values or change values), use webhooks instead.
Finalizer
A finalizer is an element for asynchronous cleanup in Kubernetes.
It is attached with an EntityFinalizerAttacher
and is called
when the entity is marked as deleted.
public class FinalizerOne : IEntityFinalizer<V1TestEntity>
{
public Task FinalizeAsync(V1TestEntity entity)
{
return Task.CompletedTask;
}
}
[!NOTE] The controller (if you overwrote the
DeletedAsync
method) will receive the notification as soon as all finalizers are removed.
Documentation
For more information, please visit the documentation.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | 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. |
-
net6.0
- KubeOps.Abstractions (>= 9.2.0)
- KubeOps.KubernetesClient (>= 9.2.0)
- KubeOps.Transpiler (>= 9.2.0)
- Microsoft.Extensions.Hosting (>= 8.0.0)
-
net7.0
- KubeOps.Abstractions (>= 9.2.0)
- KubeOps.KubernetesClient (>= 9.2.0)
- KubeOps.Transpiler (>= 9.2.0)
- Microsoft.Extensions.Hosting (>= 8.0.0)
-
net8.0
- KubeOps.Abstractions (>= 9.2.0)
- KubeOps.KubernetesClient (>= 9.2.0)
- KubeOps.Transpiler (>= 9.2.0)
- Microsoft.Extensions.Hosting (>= 8.0.0)
-
net9.0
- KubeOps.Abstractions (>= 9.2.0)
- KubeOps.KubernetesClient (>= 9.2.0)
- KubeOps.Transpiler (>= 9.2.0)
- Microsoft.Extensions.Hosting (>= 8.0.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on KubeOps.Operator:
Package | Downloads |
---|---|
KubeOps.Operator.Web
This is an operator sdk written in c#. It enables a developer to create a custom controller for CRDs (CustomResourceDefinitions) that runs on kubernetes. This operator uses ASP.net to support webhooks and external access to the operator. |
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on KubeOps.Operator:
Repository | Stars |
---|---|
josephnhtam/live-streaming-server-net
A .NET implementation of RTMP live streaming server, supporting HTTP-FLV, WebSocket-FLV, HLS, Kubernetes, cloud storage services integration and more.
|
Version | Downloads | Last updated |
---|---|---|
9.2.0 | 25 | 1/24/2025 |
9.1.5 | 20,198 | 9/10/2024 |
9.1.4 | 1,149 | 8/26/2024 |
9.1.3 | 14,500 | 6/28/2024 |
9.1.2 | 9,418 | 6/20/2024 |
9.1.1 | 4,848 | 5/22/2024 |
9.1.0 | 2,012 | 5/15/2024 |
9.0.2 | 219 | 5/13/2024 |
9.0.0 | 12,615 | 3/13/2024 |
9.0.0-pre.4 | 82 | 4/19/2024 |
9.0.0-pre.3 | 68 | 3/21/2024 |
9.0.0-pre.2 | 69 | 3/13/2024 |
9.0.0-pre.1 | 77 | 3/7/2024 |
8.0.2-pre.2 | 85 | 2/21/2024 |
8.0.2-pre.1 | 67 | 2/19/2024 |
8.0.1 | 10,512 | 2/13/2024 |
8.0.1-pre.7 | 82 | 2/12/2024 |
8.0.1-pre.6 | 80 | 2/7/2024 |
8.0.1-pre.5 | 75 | 2/5/2024 |
8.0.1-pre.4 | 76 | 1/31/2024 |
8.0.1-pre.3 | 75 | 1/26/2024 |
8.0.1-pre.2 | 78 | 1/25/2024 |
8.0.1-pre.1 | 69 | 1/18/2024 |
8.0.0 | 871 | 1/17/2024 |
8.0.0-pre.45 | 69 | 1/17/2024 |
8.0.0-pre.44 | 71 | 1/16/2024 |
8.0.0-pre.43 | 71 | 1/16/2024 |
8.0.0-pre.42 | 815 | 1/10/2024 |
8.0.0-pre.41 | 302 | 1/2/2024 |
8.0.0-pre.40 | 173 | 12/27/2023 |
8.0.0-pre.39 | 80 | 12/21/2023 |
8.0.0-pre.38 | 422 | 12/6/2023 |
8.0.0-pre.37 | 143 | 12/6/2023 |
8.0.0-pre.36 | 146 | 12/3/2023 |
8.0.0-pre.35 | 109 | 11/28/2023 |
8.0.0-pre.34 | 97 | 11/24/2023 |
8.0.0-pre.33 | 79 | 11/24/2023 |
8.0.0-pre.32 | 77 | 11/23/2023 |
8.0.0-pre.31 | 82 | 11/23/2023 |
8.0.0-pre.30 | 83 | 11/23/2023 |
8.0.0-pre.29 | 486 | 11/11/2023 |
8.0.0-pre.28 | 95 | 11/8/2023 |
8.0.0-pre.27 | 585 | 10/23/2023 |
8.0.0-pre.26 | 118 | 10/19/2023 |
8.0.0-pre.25 | 85 | 10/18/2023 |
8.0.0-pre.24 | 106 | 10/13/2023 |
8.0.0-pre.23 | 87 | 10/13/2023 |
8.0.0-pre.22 | 82 | 10/13/2023 |
8.0.0-pre.21 | 89 | 10/12/2023 |
8.0.0-pre.20 | 87 | 10/11/2023 |
8.0.0-pre.19 | 88 | 10/9/2023 |
8.0.0-pre.18 | 82 | 10/9/2023 |
8.0.0-pre.17 | 81 | 10/7/2023 |
8.0.0-pre.16 | 113 | 10/6/2023 |
8.0.0-pre.15 | 80 | 10/6/2023 |
8.0.0-pre.14 | 80 | 10/5/2023 |
8.0.0-pre.13 | 79 | 10/5/2023 |
8.0.0-pre.12 | 82 | 10/4/2023 |
8.0.0-pre.11 | 83 | 10/3/2023 |
8.0.0-pre.10 | 85 | 10/3/2023 |
8.0.0-pre.9 | 83 | 10/3/2023 |
8.0.0-pre.8 | 81 | 10/2/2023 |
8.0.0-pre.7 | 81 | 10/2/2023 |
8.0.0-pre.6 | 83 | 9/29/2023 |
8.0.0-pre.5 | 79 | 9/28/2023 |
8.0.0-pre.4 | 79 | 9/28/2023 |
8.0.0-pre.3 | 78 | 9/27/2023 |
8.0.0-pre.2 | 68 | 9/26/2023 |
8.0.0-pre.1 | 78 | 9/22/2023 |
'# [9.2.0](https://github.com/buehler/dotnet-operator-sdk/compare/v9.1.5...v9.2.0) (2025-01-24)
### Bug Fixes
* Default to setting Nullable to null in CRD generation ([#830](https://github.com/buehler/dotnet-operator-sdk/issues/830)) ([5e061d5](https://github.com/buehler/dotnet-operator-sdk/commit/5e061d5093984413b534598bc7c578a326af134c))
* **deps:** upgrade localtunnel ([#814](https://github.com/buehler/dotnet-operator-sdk/issues/814)) ([307835e](https://github.com/buehler/dotnet-operator-sdk/commit/307835efbfc3676c9794f9d75ee72e2f5095f470))
* Limit the number of types to process ([#816](https://github.com/buehler/dotnet-operator-sdk/issues/816)) ([092ae45](https://github.com/buehler/dotnet-operator-sdk/commit/092ae455b3eebd1ce874af54e4118102d86f510b))
* Set KubeOps.Generator as a DevelopmentDependency ([#834](https://github.com/buehler/dotnet-operator-sdk/issues/834)) ([5a98290](https://github.com/buehler/dotnet-operator-sdk/commit/5a982901bd85ad82587a809be588b6fd5b7371de)), closes [#698](https://github.com/buehler/dotnet-operator-sdk/issues/698)
### Features
* Add EnumMemberAttribute and .NET 9's JsonStringEnumMemberNameAttribute ([#833](https://github.com/buehler/dotnet-operator-sdk/issues/833)) ([c9beb6d](https://github.com/buehler/dotnet-operator-sdk/commit/c9beb6de97346ada5507f2d60d72321b97085481))
* Add support for generating CRD's for entities that contain other custom resources ([#823](https://github.com/buehler/dotnet-operator-sdk/issues/823)) ([f2129cf](https://github.com/buehler/dotnet-operator-sdk/commit/f2129cf746f928a431fd855dcf2736e3dbb819af))
* upgrade to dotnet 9 ([#838](https://github.com/buehler/dotnet-operator-sdk/issues/838)) ([9b905fb](https://github.com/buehler/dotnet-operator-sdk/commit/9b905fbe7b37077b779b9bae5d340057c3dd8ad8))
'