---
api_metadata:
apiVersion: "node.k8s.io/v1"
import: "k8s.io/api/node/v1"
kind: "RuntimeClass"
content_type: "api_reference"
description: "RuntimeClass 定义集群中支持的容器运行时类。"
title: "RuntimeClass"
weight: 6
---
`apiVersion: node.k8s.io/v1`
`import "k8s.io/api/node/v1"`
## RuntimeClass {#RuntimeClass}
RuntimeClass 定义集群中支持的容器运行时类。
RuntimeClass 用于确定哪个容器运行时用于运行某 Pod 中的所有容器。
RuntimeClass 由用户或集群制备程序手动定义,并在 PodSpec 中引用。
Kubelet 负责在运行 Pod 之前解析 RuntimeClassName 引用。
有关更多详细信息,请参阅
https://kubernetes.io/zh-cn/docs/concepts/containers/runtime-class/
- **apiVersion**: node.k8s.io/v1
- **kind**: RuntimeClass
- **metadata** (}}">ObjectMeta)
更多信息:
https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
- **handler** (string),必需
handler 指定底层运行时和配置,在 CRI 实现过程中将使用这些运行时和配置来处理这个类的 Pod。
可能的值特定于节点和 CRI 配置。
假定所有 handler 可用于每个节点上,且同一名称的 handler 在所有节点上是等效的。
例如,一个名为 “runc” 的 handler 可能指定 runc OCI 运行时将(使用原生 Linux 容器)
用于运行 Pod 中的容器。该 handler 必须采用小写,遵从 DNS Label (RFC 1123) 要求,且是不可变更的。
- **overhead** (Overhead)
overhead 表示运行给定 RuntimeClass 的 Pod 时所关联的资源开销。有关更多详细信息,请参阅
https://kubernetes.io/zh-cn/docs/concepts/scheduling-eviction/pod-overhead/
**Overhead 结构表示运行一个 Pod 所关联的资源开销。**
- **overhead.podFixed** (map[string]}}">Quantity)
podFixed 表示与运行一个 Pod 所关联的资源开销。
- **scheduling** (Scheduling)
scheduling 包含调度约束,这些约束用来确保以这个 RuntimeClass 运行的 Pod 被调度到支持此运行时类的节点。
如果 scheduling 设为空,则假定所有节点支持此 RuntimeClass。
**Scheduling 指定支持 RuntimeClass 的节点的调度约束。**
- **scheduling.nodeSelector** (map[string]string)
nodeSelector 列出支持此 RuntimeClass 的节点上必须存在的标签。
使用此 RuntimeClass 的 Pod 只能调度到与这个选择算符匹配的节点上。
RuntimeClass nodeSelector 与 Pod 现有的 nodeSelector 合并。
任何冲突均会使得该 Pod 在准入时被拒绝。
- **scheduling.tolerations** ([]Toleration)
**原子性:将在合并期间被替换**
tolerations 在准入期间追加到以此 RuntimeClass 运行的 Pod(不包括重复项)上,
本质上是求取 Pod 和 RuntimeClass 所容忍的节点并集。
**附加此容忍度的 Pod 将容忍用匹配运算符 `operator` 运算后与三元组
`` 匹配的任何污点。**
- **scheduling.tolerations.key** (string)
key 是容忍度所应用到的污点键。空意味着匹配所有污点键。
如果键为空,则运算符必须为 Exists;这个组合意味着匹配所有值和所有键。
- **scheduling.tolerations.operator** (string)
operator 表示一个键与值的关系。有效的运算符为 Exists 和 Equal。默认为 Equal。
Exists 等价于将值设置为通配符的情况,因此一个 Pod 可以容忍特定类别的所有污点。
- **scheduling.tolerations.value** (string)
value 是容忍度匹配到的污点值。如果运算符为 Exists,则值应为空,否则就是一个普通字符串。
- **scheduling.tolerations.effect** (string)
effect 表示匹配度污点效果。空意味着匹配所有污点效果。
当指定值时,允许的值为 NoSchedule、PreferNoSchedule 或 NoExecute。
- **scheduling.tolerations.tolerationSeconds** (int64)
tolerationSeconds 表示容忍度容忍污点的时间段(必须是 NoExecute 的效果,否则忽略此字段)。
默认情况下,不设置此字段,这意味着永远容忍污点(不驱逐)。零和负值将被系统视为 0(立即驱逐)。
## RuntimeClassList {#RuntimeClassList}
RuntimeClassList 是 RuntimeClass 对象的列表。
- **apiVersion**: node.k8s.io/v1
- **kind**: RuntimeClassList
- **metadata** (}}">ListMeta)
标准的对象元数据。更多信息:
https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata
- **items** ([]}}">RuntimeClass),必需
items 是 schema 对象的列表。
## 操作 {#Operations}
### `get` 读取指定的 RuntimeClass
#### HTTP 请求
GET /apis/node.k8s.io/v1/runtimeclasses/{name}
##### 参数
- **name** (**路径参数**): string,必需
RuntimeClass 的名称
- **pretty** (**查询参数**): string
}}">pretty
#### 响应
200 (}}">RuntimeClass): OK
401: Unauthorized
### `list` 列出或监视 RuntimeClass 类别的对象
#### HTTP 请求
GET /apis/node.k8s.io/v1/runtimeclasses
##### 参数
- **allowWatchBookmarks** (**查询参数**): boolean
}}">allowWatchBookmarks
- **continue** (**查询参数**): string
}}">continue
- **fieldSelector** (**查询参数**): string
}}">fieldSelector
- **labelSelector** (**查询参数**): string
}}">labelSelector
- **limit** (**查询参数**): integer
}}">limit
- **pretty** (**查询参数**): string
}}">pretty
- **resourceVersion** (**查询参数**): string
}}">resourceVersion
- **resourceVersionMatch** (**查询参数**): string
}}">resourceVersionMatch
- **sendInitialEvents** (**查询参数**): boolean
}}">sendInitialEvents
- **timeoutSeconds** (**查询参数**): integer
}}">timeoutSeconds
- **watch** (**查询参数**): boolean
}}">watch
#### 响应
200 (}}">RuntimeClassList): OK
401: Unauthorized
### `create` 创建 RuntimeClass
#### HTTP 请求
POST /apis/node.k8s.io/v1/runtimeclasses
##### 参数
- **body**: }}">RuntimeClass,必需
- **dryRun** (**查询参数**): string
}}">dryRun
- **fieldManager** (**查询参数**): string
}}">fieldManager
- **fieldValidation** (**查询参数**): string
}}">fieldValidation
- **pretty** (**查询参数**): string
}}">pretty
#### 响应
200 (}}">RuntimeClass): OK
201 (}}">RuntimeClass): Created
202 (}}">RuntimeClass): Accepted
401: Unauthorized
### `update` 替换指定的 RuntimeClass
#### HTTP 请求
PUT /apis/node.k8s.io/v1/runtimeclasses/{name}
##### 参数
- **name** (**路径参数**): string,必需
RuntimeClass 的名称
- **body**: }}">RuntimeClass,必需
- **dryRun** (**查询参数**): string
}}">dryRun
- **fieldManager** (**查询参数**): string
}}">fieldManager
- **fieldValidation** (**查询参数**): string
}}">fieldValidation
- **pretty** (**查询参数**): string
}}">pretty
#### 响应
200 (}}">RuntimeClass): OK
201 (}}">RuntimeClass): Created
401: Unauthorized
### `patch` 部分更新指定的 RuntimeClass
#### HTTP 请求
PATCH /apis/node.k8s.io/v1/runtimeclasses/{name}
##### 参数
- **name** (**路径参数**): string,必需
RuntimeClass 的名称
- **body**: }}">Patch,必需
- **dryRun** (**查询参数**): string
}}">dryRun
- **fieldManager** (**查询参数**): string
}}">fieldManager
- **fieldValidation** (**查询参数**): string
}}">fieldValidation
- **force** (**查询参数**): boolean
}}">force
- **pretty** (**查询参数**): string
}}">pretty
#### 响应
200 (}}">RuntimeClass): OK
201 (}}">RuntimeClass): Created
401: Unauthorized
### `delete` 删除 RuntimeClass
#### HTTP 请求
DELETE /apis/node.k8s.io/v1/runtimeclasses/{name}
##### 参数
- **name** (**路径参数**): string,必需
RuntimeClass 的名称
- **body**: }}">DeleteOptions
- **dryRun** (**查询参数**): string
}}">dryRun
- **gracePeriodSeconds** (**查询参数**): integer
}}">gracePeriodSeconds
- **pretty** (**查询参数**): string
}}">pretty
- **propagationPolicy** (**查询参数**): string
}}">propagationPolicy
#### 响应
200 (}}">Status): OK
202 (}}">Status): Accepted
401: Unauthorized
### `deletecollection` 删除 RuntimeClass 的集合
#### HTTP 请求
DELETE /apis/node.k8s.io/v1/runtimeclasses
##### 参数
- **body**: }}">DeleteOptions
- **continue** (**查询参数**): string
}}">continue
- **dryRun** (**查询参数**): string
}}">dryRun
- **fieldSelector** (**查询参数**): string
}}">fieldSelector
- **gracePeriodSeconds** (**查询参数**): integer
}}">gracePeriodSeconds
- **labelSelector** (**查询参数**): string
}}">labelSelector
- **limit** (**查询参数**): integer
}}">limit
- **pretty** (**查询参数**): string
}}">pretty
- **propagationPolicy** (**查询参数**): string
}}">propagationPolicy
- **resourceVersion** (**查询参数**): string
}}">resourceVersion
- **resourceVersionMatch** (**查询参数**): string
}}">resourceVersionMatch
- **sendInitialEvents** (**查询参数**): boolean
}}">sendInitialEvents
- **timeoutSeconds** (**查询参数**): integer
}}">timeoutSeconds
#### 响应
200 (}}">Status): OK
401: Unauthorized