Skip to content

Commit ee6bd56

Browse files
authored
Merge pull request #31444 from tengqm/zh-configmap
[zh] Resync the configmap page
2 parents f698454 + d97e53f commit ee6bd56

File tree

1 file changed

+41
-36
lines changed

1 file changed

+41
-36
lines changed

content/zh/docs/concepts/configuration/configmap.md

Lines changed: 41 additions & 36 deletions
Original file line numberDiff line numberDiff line change
@@ -77,8 +77,8 @@ ConfigMap 是一个 API [对象](/zh/docs/concepts/overview/working-with-objects
7777
让你可以存储其他对象所需要使用的配置。
7878
和其他 Kubernetes 对象都有一个 `spec` 不同的是,ConfigMap 使用 `data`
7979
`binaryData` 字段。这些字段能够接收键-值对作为其取值。`data``binaryData`
80-
字段都是可选的。`data` 字段设计用来保存 UTF-8 字节序列,而 `binaryData`
81-
被设计用来保存二进制数据作为 base64 编码的字串。
80+
字段都是可选的。`data` 字段设计用来保存 UTF-8 字节序列,而 `binaryData`
81+
则被设计用来保存二进制数据作为 base64 编码的字串。
8282

8383
ConfigMap 的名字必须是一个合法的
8484
[DNS 子域名](/zh/docs/concepts/overview/working-with-objects/names#dns-subdomain-names)
@@ -92,11 +92,11 @@ Starting from v1.19, you can add an `immutable` field to a ConfigMap
9292
definition to create an [immutable ConfigMap](#configmap-immutable).
9393
-->
9494
`data``binaryData` 字段下面的每个键的名称都必须由字母数字字符或者
95-
`-``_``.` 组成。在 `data` 下保存的键名不可以与在 `binaryData`
96-
出现的键名有重叠
95+
`-``_``.` 组成。在 `data` 下保存的键名不可以与在 `binaryData`
96+
下出现的键名有重叠
9797

98-
从 v1.19 开始,你可以添加一个 `immutable` 字段到 ConfigMap 定义中,创建
99-
[不可变更的 ConfigMap](#configmap-immutable)
98+
从 v1.19 开始,你可以添加一个 `immutable` 字段到 ConfigMap 定义中,
99+
创建[不可变更的 ConfigMap](#configmap-immutable)
100100

101101
<!--
102102
## ConfigMaps and Pods
@@ -107,8 +107,8 @@ the same {{< glossary_tooltip text="namespace" term_id="namespace" >}}.
107107
-->
108108
## ConfigMaps 和 Pods
109109

110-
你可以写一个引用 ConfigMap 的 Pod 的 `spec`,并根据 ConfigMap 中的数据
111-
在该 Pod 中配置容器。这个 Pod 和 ConfigMap 必须要在同一个
110+
你可以写一个引用 ConfigMap 的 Pod 的 `spec`,并根据 ConfigMap 中的数据在该
111+
Pod 中配置容器。这个 Pod 和 ConfigMap 必须要在同一个
112112
{{< glossary_tooltip text="名字空间" term_id="namespace" >}} 中。
113113

114114
<!--
@@ -183,10 +183,9 @@ technique also lets you access a ConfigMap in a different namespace.
183183
Here's an example Pod that uses values from `game-demo` to configure a Pod:
184184
-->
185185
第四种方法意味着你必须编写代码才能读取 ConfigMap 和它的数据。然而,
186-
由于你是直接使用 Kubernetes API,因此只要 ConfigMap 发生更改,你的
187-
应用就能够通过订阅来获取更新,并且在这样的情况发生的时候做出反应。
188-
通过直接进入 Kubernetes API,这个技术也可以让你能够获取到不同的名字空间
189-
里的 ConfigMap。
186+
由于你是直接使用 Kubernetes API,因此只要 ConfigMap 发生更改,
187+
你的应用就能够通过订阅来获取更新,并且在这样的情况发生的时候做出反应。
188+
通过直接进入 Kubernetes API,这个技术也可以让你能够获取到不同的名字空间里的 ConfigMap。
190189

191190
下面是一个 Pod 的示例,它通过使用 `game-demo` 中的值来配置一个 Pod:
192191

@@ -243,16 +242,16 @@ definition specifies an `items` array in the `volumes` section.
243242
If you omit the `items` array entirely, every key in the ConfigMap becomes
244243
a file with the same name as the key, and you get 4 files.
245244
-->
246-
ConfigMap 不会区分单行属性值和多行类似文件的值,重要的是 Pods 和其他对象
247-
如何使用这些值
245+
ConfigMap 不会区分单行属性值和多行类似文件的值,重要的是 Pods
246+
和其他对象如何使用这些值
248247

249248
上面的例子定义了一个卷并将它作为 `/config` 文件夹挂载到 `demo` 容器内,
250249
创建两个文件,`/config/game.properties` 和
251250
`/config/user-interface.properties`
252251
尽管 ConfigMap 中包含了四个键。
253252
这是因为 Pod 定义中在 `volumes` 节指定了一个 `items` 数组。
254-
如果你完全忽略 `items` 数组,则 ConfigMap 中的每个键都会变成一个与
255-
该键同名的文件,因此你会得到四个文件。
253+
如果你完全忽略 `items` 数组,则 ConfigMap 中的每个键都会变成一个与该键同名的文件,
254+
因此你会得到四个文件。
256255

257256
<!--
258257
## Using ConfigMaps
@@ -263,9 +262,8 @@ ConfigMaps can hold data that other parts of the system should use for configura
263262
-->
264263
## 使用 ConfigMap {#using-configmaps}
265264

266-
ConfigMap 可以作为数据卷挂载。ConfigMap 也可被系统的其他组件使用,而
267-
不一定直接暴露给 Pod。例如,ConfigMap 可以保存系统中其他组件要使用
268-
的配置数据。
265+
ConfigMap 可以作为数据卷挂载。ConfigMap 也可被系统的其他组件使用,
266+
而不一定直接暴露给 Pod。例如,ConfigMap 可以保存系统中其他组件要使用的配置数据。
269267

270268
<!--
271269
The most common way to use ConfigMaps is to configure settings for
@@ -308,8 +306,8 @@ To consume a ConfigMap in a volume in a Pod:
308306
1. 创建一个 ConfigMap 对象或者使用现有的 ConfigMap 对象。多个 Pod 可以引用同一个
309307
ConfigMap。
310308
1. 修改 Pod 定义,在 `spec.volumes[]` 下添加一个卷。
311-
为该卷设置任意名称,之后将 `spec.volumes[].configMap.name` 字段设置为对
312-
你的 ConfigMap 对象的引用。
309+
为该卷设置任意名称,之后将 `spec.volumes[].configMap.name` 字段设置为对你的
310+
ConfigMap 对象的引用。
313311
1. 为每个需要该 ConfigMap 的容器添加一个 `.spec.containers[].volumeMounts[]`。
314312
设置 `.spec.containers[].volumeMounts[].readOnly=true` 并将
315313
`.spec.containers[].volumeMounts[].mountPath` 设置为一个未使用的目录名,
@@ -349,8 +347,8 @@ own `volumeMounts` block, but only one `.spec.volumes` is needed per ConfigMap.
349347
-->
350348
你希望使用的每个 ConfigMap 都需要在 `spec.volumes` 中被引用到。
351349

352-
如果 Pod 中有多个容器,则每个容器都需要自己的 `volumeMounts` 块,但针对
353-
每个 ConfigMap,你只需要设置一个 `spec.volumes` 块。
350+
如果 Pod 中有多个容器,则每个容器都需要自己的 `volumeMounts` 块,但针对每个
351+
ConfigMap,你只需要设置一个 `spec.volumes` 块。
354352

355353
<!--
356354
#### Mounted ConfigMaps are updated automatically
@@ -367,7 +365,7 @@ the [KubeletConfiguration struct](/docs/reference/config-api/kubelet-config.v1be
367365
kubelet 组件会在每次周期性同步时检查所挂载的 ConfigMap 是否为最新。
368366
不过,kubelet 使用的是其本地的高速缓存来获得 ConfigMap 的当前值。
369367
高速缓存的类型可以通过
370-
[KubeletConfiguration 结构](https://github.com/kubernetes/kubernetes/blob/{{< param "docsbranch" >}}/staging/src/k8s.io/kubelet/config/v1beta1/types.go)
368+
[KubeletConfiguration 结构](/zh/docs/reference/config-api/kubelet-config.v1beta1/).
371369
的 `ConfigMapAndSecretChangeDetectionStrategy` 字段来配置。
372370

373371
<!--
@@ -380,8 +378,8 @@ propagation delay, where the cache propagation delay depends on the chosen cache
380378
-->
381379
ConfigMap 既可以通过 watch 操作实现内容传播(默认形式),也可实现基于 TTL
382380
的缓存,还可以直接经过所有请求重定向到 API 服务器。
383-
因此,从 ConfigMap 被更新的那一刻算起,到新的主键被投射到 Pod 中去,这一
384-
时间跨度可能与 kubelet 的同步周期加上高速缓存的传播延迟相等。
381+
因此,从 ConfigMap 被更新的那一刻算起,到新的主键被投射到 Pod 中去,
382+
这一时间跨度可能与 kubelet 的同步周期加上高速缓存的传播延迟相等。
385383
这里的传播延迟取决于所选的高速缓存类型
386384
(分别对应 watch 操作的传播延迟、高速缓存的 TTL 时长或者 0)。
387385

@@ -391,6 +389,14 @@ ConfigMaps consumed as environment variables are not updated automatically and r
391389
以环境变量方式使用的 ConfigMap 数据不会被自动更新。
392390
更新这些数据需要重新启动 Pod。
393391

392+
{{< note >}}
393+
<!--
394+
A container using a ConfigMap as a [subPath](/docs/concepts/storage/volumes#using-subpath) volume mount will not receive ConfigMap updates.
395+
-->
396+
将 ConfigMap 作为 [subPath](/docs/concepts/storage/volumes#using-subpath)
397+
卷挂载的容器无法收到 ConfigMap 更新。
398+
{{< /note >}}
399+
394400
<!--
395401
A container using a ConfigMap as a [subPath](/docs/concepts/storage/volumes#using-subpath) volume mount will not receive ConfigMap updates.
396402
-->
@@ -412,8 +418,8 @@ individual Secrets and ConfigMaps as immutable. For clusters that extensively us
412418
data has the following advantages:
413419
-->
414420
Kubernetes 特性 _不可变更的 Secret 和 ConfigMap_ 提供了一种将各个
415-
Secret 和 ConfigMap 设置为不可变更的选项。对于大量使用 ConfigMap
416-
集群(至少有数万个各不相同的 ConfigMap 给 Pod 挂载)而言,禁止更改
421+
Secret 和 ConfigMap 设置为不可变更的选项。对于大量使用 ConfigMap 的集群
422+
(至少有数万个各不相同的 ConfigMap 给 Pod 挂载)而言,禁止更改
417423
ConfigMap 的数据有以下好处:
418424

419425
<!--
@@ -422,8 +428,8 @@ ConfigMap 的数据有以下好处:
422428
closing watches for ConfigMaps marked as immutable.
423429
-->
424430
- 保护应用,使之免受意外(不想要的)更新所带来的负面影响。
425-
- 通过大幅降低对 kube-apiserver 的压力提升集群性能,这是因为系统会关闭
426-
对已标记为不可变更的 ConfigMap 的监视操作。
431+
- 通过大幅降低对 kube-apiserver 的压力提升集群性能,
432+
这是因为系统会关闭对已标记为不可变更的 ConfigMap 的监视操作。
427433

428434
<!--
429435
This feature is controlled by the `ImmutableEphemeralVolumes`
@@ -432,8 +438,8 @@ You can create an immutable ConfigMap by setting the `immutable` field to `true`
432438
For example:
433439
-->
434440
此功能特性由 `ImmutableEphemeralVolumes`
435-
[特性门控](/zh/docs/reference/command-line-tools-reference/feature-gates/)
436-
来控制。你可以通过将 `immutable` 字段设置为 `true` 创建不可变更的 ConfigMap。
441+
[特性门控](/zh/docs/reference/command-line-tools-reference/feature-gates/)来控制。
442+
你可以通过将 `immutable` 字段设置为 `true` 创建不可变更的 ConfigMap。
437443
例如:
438444

439445
```yaml
@@ -454,8 +460,7 @@ to the deleted ConfigMap, it is recommended to recreate these pods.
454460
-->
455461
一旦某 ConfigMap 被标记为不可变更,则 _无法_ 逆转这一变化,,也无法更改
456462
`data` 或 `binaryData` 字段的内容。你只能删除并重建 ConfigMap。
457-
因为现有的 Pod 会维护一个对已删除的 ConfigMap 的挂载点,建议重新创建
458-
这些 Pods。
463+
因为现有的 Pod 会维护一个对已删除的 ConfigMap 的挂载点,建议重新创建这些 Pods。
459464

460465
## {{% heading "whatsnext" %}}
461466

@@ -466,6 +471,6 @@ to the deleted ConfigMap, it is recommended to recreate these pods.
466471
separating code from configuration.
467472
-->
468473
* 阅读 [Secret](/zh/docs/concepts/configuration/secret/)。
469-
* 阅读 [配置 Pod 来使用 ConfigMap](/zh/docs/tasks/configure-pod-container/configure-pod-configmap/)。
470-
* 阅读 [Twelve-Factor 应用](https://12factor.net/) 来了解将代码和配置分开的动机。
474+
* 阅读[配置 Pod 使用 ConfigMap](/zh/docs/tasks/configure-pod-container/configure-pod-configmap/)。
475+
* 阅读 [Twelve-Factor 应用](https://12factor.net/zh_cn/)来了解将代码和配置分开的动机。
471476

0 commit comments

Comments
 (0)