-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Showing
2 changed files
with
63 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
# Configurable RuntimeClassNames | ||
|
||
**Author: Caleb Woodbine** | ||
|
||
Starting in Knative Serving v1.15, administrators are now able to configure default the RuntimeClassName field for deployments as default and via a Knative Service label selector. | ||
|
||
## Runtime Classes | ||
|
||
**What is a Runtime Class?** | ||
|
||
A Runtime Class for configuring the handler that runs a container, such as `runc`, `crun`, `runsc`, `nvidia` or `kata`. | ||
|
||
See documentation at the [Kubernetes docs here](https://kubernetes.io/docs/concepts/containers/runtime-class/). | ||
|
||
## Other configurations | ||
|
||
There are several feature flags in Knative Serving, one of which is enabling the field `.spec.template.spec.runtimeClassName` in Knative Service. | ||
|
||
This may be useful for self-service and is a helpful feature flag. | ||
|
||
See the documentation [here](https://knative.dev/docs/serving/configuration/feature-flags/#kubernetes-runtime-class). | ||
|
||
## Configuring Knative | ||
|
||
Knative is able to be configured with either the ConfigMaps if deployed with plain manifests or the KnativeServing resource if deployed with the operator. The following examples will be using just the plain manifests. | ||
|
||
See this example where Knative will configure deployments managed by Knative through Services to use Kata by default or gVisor when the Knative Service has a label matching `my-label=selector`: | ||
|
||
```yaml | ||
apiVersion: v1 | ||
kind: ConfigMap | ||
metadata: | ||
name: config-deployment | ||
namespace: knative-serving | ||
data: | ||
runtime-class-name: | | ||
kata: {} | ||
gvisor: | ||
selector: | ||
my-label: selector | ||
``` | ||
The keys, like `kata` and `gvisor` must match existing Kubernetes RuntimeClasses. | ||
|
||
For Knative docs, [see here](https://knative.dev/docs/serving/configuration/deployment/#configuring-selectable-runtimeclassname). | ||
|
||
## Why is this important? | ||
|
||
RuntimeClasses enable several things, including: | ||
|
||
- security | ||
- such as through Kata or gVisor | ||
- functionality | ||
- such as through GPU RuntimeClasses | ||
- | ||
|
||
## Closing | ||
|
||
Runtime Classes are an important piece in container platform infrastructure. | ||
Whether you're setting up a platform for production or just playing around, Runtime Classes can enhance or lockdown your workloads. | ||
|
||
Now with the Knative Serving deployment configuration settings for RuntimeClass, there's even more ability to configure Knative Services in a locked down and specific manner. |