kubectl taint

概要

更新一个或多个节点上的污点(taint)。

  • 污点(taint)包含 key、value 和 effect。在此处作为参数时,其表达形式为 key=value:effect。
  • Key 必须以字母或数字开头,且可以包含字母、数字、连字符、点号和下划线,最多 253 个字符。
  • Key 也可以选择性地以 DNS 子域前缀和单个 '/' 开头,例如 example.com/my-app。
  • Value 是可选的。如果提供,必须以字母或数字开头,且可以包含字母、数字、连字符、点号和下划线,最多 63 个字符。
  • Effect 必须是 NoSchedule、PreferNoSchedule 或 NoExecute。
  • 当前,污点(taint)只能应用于节点。
kubectl taint NODE NAME KEY_1=VAL_1:TAINT_EFFECT_1 ... KEY_N=VAL_N:TAINT_EFFECT_N

示例

  # Update node 'foo' with a taint with key 'dedicated' and value 'special-user' and effect 'NoSchedule'
  # If a taint with that key and effect already exists, its value is replaced as specified
  kubectl taint nodes foo dedicated=special-user:NoSchedule
  
  # Remove from node 'foo' the taint with key 'dedicated' and effect 'NoSchedule' if one exists
  kubectl taint nodes foo dedicated:NoSchedule-
  
  # Remove from node 'foo' all the taints with key 'dedicated'
  kubectl taint nodes foo dedicated-
  
  # Add a taint with key 'dedicated' on nodes having label myLabel=X
  kubectl taint node -l myLabel=X  dedicated=foo:PreferNoSchedule
  
  # Add to node 'foo' a taint with key 'bar' and no value
  kubectl taint nodes foo bar:NoSchedule

选项

--all

选择集群中的所有节点

--allow-missing-template-keys     默认值: true

如果为 true,当模板中缺少字段或 map key 时,忽略模板中的任何错误。仅适用于 golang 和 jsonpath 输出格式。

--dry-run string[="unchanged"]     默认值: "none"

必须是 "none"、"server" 或 "client"。如果采用 client 策略,仅打印将要发送的对象,而不实际发送。如果采用 server 策略,提交服务器端请求但不持久化资源。

--field-manager string     默认值: "kubectl-taint"

用于跟踪字段所有权的管理器的名称。

-h, --help

taint 的帮助信息

-o, --output string

输出格式。可为以下任一值:(json, yaml, name, go-template, go-template-file, template, templatefile, jsonpath, jsonpath-as-json, jsonpath-file)。

--overwrite

如果为 true,允许覆盖现有污点,否则拒绝覆盖现有污点的污点更新。

-l, --selector string

用于过滤的选择器 (标签查询),支持 '=', '==', '!=', 'in', 'notin'。(例如 -l key1=value1,key2=value2,key3 in (value3))。匹配的对象必须满足所有指定的标签约束。

--show-managed-fields

如果为 true,当以 JSON 或 YAML 格式打印对象时,保留 managedFields。

--template string

当使用 -o=go-template, -o=go-template-file 时要使用的模板字符串或模板文件路径。模板格式为 golang 模板 [https://golang.ac.cn/pkg/text/template/#pkg-overview]。

--validate string[="strict"]     默认值: "strict"

必须是以下之一:strict (或 true)、warn、ignore (或 false)。"true" 或 "strict" 将使用 schema 验证输入,如果无效则请求失败。如果在 api-server 上启用了 ServerSideFieldValidation,它将执行服务器端验证,否则将回退到不太可靠的客户端验证。"warn" 在 api-server 上启用服务器端字段验证时,将对未知或重复字段发出警告而不阻塞请求,否则行为与 "ignore" 相同。"false" 或 "ignore" 不执行任何 schema 验证,静默丢弃任何未知或重复的字段。

继承的父选项

--as string

用于操作的模拟用户名。用户可以是普通用户,也可以是命名空间中的服务账号。

--as-group strings

用于操作的模拟用户组,该标志可以重复使用以指定多个组。

--as-uid string

用于操作的模拟 UID。

--cache-dir string     默认值: "$HOME/.kube/cache"

默认缓存目录

--certificate-authority string

证书机构 cert 文件的路径

--client-certificate string

TLS 客户端证书文件的路径

--client-key string

TLS 客户端密钥文件的路径

--cluster string

要使用的 kubeconfig 集群名称

--context string

要使用的 kubeconfig 上下文名称

--default-not-ready-toleration-seconds int     默认值: 300

表示 toleration notReady:NoExecute 的 tolerationSeconds,该 toleration 默认添加到每个尚未具有此类 toleration 的 Pod。

--default-unreachable-toleration-seconds int     默认值: 300

表示 toleration unreachable:NoExecute 的 tolerationSeconds,该 toleration 默认添加到每个尚未具有此类 toleration 的 Pod。

--disable-compression

如果为 true,则对所有发往服务器的请求禁用响应压缩

--insecure-skip-tls-verify

如果为 true,则不检查服务器证书的有效性。这将使你的 HTTPS 连接不安全

--kubeconfig string

用于 CLI 请求的 kubeconfig 文件路径。

--match-server-version

要求服务器版本与客户端版本匹配

-n, --namespace string

如果存在,则为该 CLI 请求的命名空间范围

--password string

连接 API 服务器进行基本认证的密码

--profile string     默认值: "none"

要捕获的 profile 名称。可为以下之一:(none|cpu|heap|goroutine|threadcreate|block|mutex)

--profile-output string     默认值: "profile.pprof"

写入 profile 的文件名

--request-timeout string     默认值: "0"

放弃单个服务器请求前的等待时间。非零值应包含相应的时间单位(例如 1s、2m、3h)。值为零表示请求不会超时。

-s, --server string

Kubernetes API 服务器的地址和端口

--storage-driver-buffer-duration duration     默认值: 1m0s

存储驱动中的写入将在此持续时间内被缓冲,并作为单个事务提交给非内存后端

--storage-driver-db string     默认值: "cadvisor"

数据库名称

--storage-driver-host string     默认值: "localhost:8086"

数据库主机:端口

--storage-driver-password string     默认值: "root"

数据库密码

--storage-driver-secure

使用安全连接连接数据库

--storage-driver-table string     默认值: "stats"

表名称

--storage-driver-user string     默认值: "root"

数据库用户名

--tls-server-name string

用于验证服务器证书的服务器名称。如果未提供,则使用用于联系服务器的主机名

--token string

用于连接 API 服务器进行认证的 Bearer token

--user string

要使用的 kubeconfig 用户名称

--username string

连接 API 服务器进行基本认证的用户名

--version version[=true]

--version, --version=raw 打印版本信息并退出;--version=vX.Y.Z... 设置报告的版本

--warnings-as-errors

将从服务器收到的警告视为错误,并以非零退出码退出

另请参阅

  • kubectl - kubectl 用于控制 Kubernetes 集群管理器

此页面是自动生成的。

如果你打算报告此页面的问题,请在你的问题描述中提及此页面是自动生成的。修复可能需要在 Kubernetes 项目的其他地方进行。

上次修改时间:2025 年 4 月 24 日 上午 8:03 PST: kubectl reference for v1.33 (80481646c3)