@@ -77,8 +77,8 @@ ConfigMap 是一个 API [对象](/zh/docs/concepts/overview/working-with-objects
77
77
让你可以存储其他对象所需要使用的配置。
78
78
和其他 Kubernetes 对象都有一个 ` spec ` 不同的是,ConfigMap 使用 ` data ` 和
79
79
` binaryData ` 字段。这些字段能够接收键-值对作为其取值。` data ` 和 ` binaryData `
80
- 字段都是可选的。` data ` 字段设计用来保存 UTF-8 字节序列,而 ` binaryData ` 则
81
- 被设计用来保存二进制数据作为 base64 编码的字串。
80
+ 字段都是可选的。` data ` 字段设计用来保存 UTF-8 字节序列,而 ` binaryData `
81
+ 则被设计用来保存二进制数据作为 base64 编码的字串。
82
82
83
83
ConfigMap 的名字必须是一个合法的
84
84
[ 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
92
92
definition to create an [immutable ConfigMap](#configmap-immutable).
93
93
-->
94
94
` data ` 或 ` binaryData ` 字段下面的每个键的名称都必须由字母数字字符或者
95
- ` - ` 、` _ ` 或 ` . ` 组成。在 ` data ` 下保存的键名不可以与在 ` binaryData ` 下
96
- 出现的键名有重叠 。
95
+ ` - ` 、` _ ` 或 ` . ` 组成。在 ` data ` 下保存的键名不可以与在 ` binaryData `
96
+ 下出现的键名有重叠 。
97
97
98
- 从 v1.19 开始,你可以添加一个 ` immutable ` 字段到 ConfigMap 定义中,创建
99
- [ 不可变更的 ConfigMap] ( #configmap-immutable ) 。
98
+ 从 v1.19 开始,你可以添加一个 ` immutable ` 字段到 ConfigMap 定义中,
99
+ 创建 [ 不可变更的 ConfigMap] ( #configmap-immutable ) 。
100
100
101
101
<!--
102
102
## ConfigMaps and Pods
@@ -107,8 +107,8 @@ the same {{< glossary_tooltip text="namespace" term_id="namespace" >}}.
107
107
-->
108
108
## ConfigMaps 和 Pods
109
109
110
- 你可以写一个引用 ConfigMap 的 Pod 的 ` spec ` ,并根据 ConfigMap 中的数据
111
- 在该 Pod 中配置容器。这个 Pod 和 ConfigMap 必须要在同一个
110
+ 你可以写一个引用 ConfigMap 的 Pod 的 ` spec ` ,并根据 ConfigMap 中的数据在该
111
+ Pod 中配置容器。这个 Pod 和 ConfigMap 必须要在同一个
112
112
{{< glossary_tooltip text="名字空间" term_id="namespace" >}} 中。
113
113
114
114
<!--
@@ -183,10 +183,9 @@ technique also lets you access a ConfigMap in a different namespace.
183
183
Here's an example Pod that uses values from ` game-demo` to configure a Pod:
184
184
-->
185
185
第四种方法意味着你必须编写代码才能读取 ConfigMap 和它的数据。然而,
186
- 由于你是直接使用 Kubernetes API,因此只要 ConfigMap 发生更改,你的
187
- 应用就能够通过订阅来获取更新,并且在这样的情况发生的时候做出反应。
188
- 通过直接进入 Kubernetes API,这个技术也可以让你能够获取到不同的名字空间
189
- 里的 ConfigMap。
186
+ 由于你是直接使用 Kubernetes API,因此只要 ConfigMap 发生更改,
187
+ 你的应用就能够通过订阅来获取更新,并且在这样的情况发生的时候做出反应。
188
+ 通过直接进入 Kubernetes API,这个技术也可以让你能够获取到不同的名字空间里的 ConfigMap。
190
189
191
190
下面是一个 Pod 的示例,它通过使用 `game-demo` 中的值来配置一个 Pod:
192
191
@@ -243,16 +242,16 @@ definition specifies an `items` array in the `volumes` section.
243
242
If you omit the `items` array entirely, every key in the ConfigMap becomes
244
243
a file with the same name as the key, and you get 4 files.
245
244
-->
246
- ConfigMap 不会区分单行属性值和多行类似文件的值,重要的是 Pods 和其他对象
247
- 如何使用这些值 。
245
+ ConfigMap 不会区分单行属性值和多行类似文件的值,重要的是 Pods
246
+ 和其他对象如何使用这些值 。
248
247
249
248
上面的例子定义了一个卷并将它作为 `/config` 文件夹挂载到 `demo` 容器内,
250
249
创建两个文件,`/config/game.properties` 和
251
250
` /config/user-interface.properties` ,
252
251
尽管 ConfigMap 中包含了四个键。
253
252
这是因为 Pod 定义中在 `volumes` 节指定了一个 `items` 数组。
254
- 如果你完全忽略 `items` 数组,则 ConfigMap 中的每个键都会变成一个与
255
- 该键同名的文件, 因此你会得到四个文件。
253
+ 如果你完全忽略 `items` 数组,则 ConfigMap 中的每个键都会变成一个与该键同名的文件,
254
+ 因此你会得到四个文件。
256
255
257
256
<!--
258
257
# # Using ConfigMaps
@@ -263,9 +262,8 @@ ConfigMaps can hold data that other parts of the system should use for configura
263
262
-->
264
263
# # 使用 ConfigMap {#using-configmaps}
265
264
266
- ConfigMap 可以作为数据卷挂载。ConfigMap 也可被系统的其他组件使用,而
267
- 不一定直接暴露给 Pod。例如,ConfigMap 可以保存系统中其他组件要使用
268
- 的配置数据。
265
+ ConfigMap 可以作为数据卷挂载。ConfigMap 也可被系统的其他组件使用,
266
+ 而不一定直接暴露给 Pod。例如,ConfigMap 可以保存系统中其他组件要使用的配置数据。
269
267
270
268
<!--
271
269
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:
308
306
1. 创建一个 ConfigMap 对象或者使用现有的 ConfigMap 对象。多个 Pod 可以引用同一个
309
307
ConfigMap。
310
308
1. 修改 Pod 定义,在 `spec.volumes[]` 下添加一个卷。
311
- 为该卷设置任意名称,之后将 `spec.volumes[].configMap.name` 字段设置为对
312
- 你的 ConfigMap 对象的引用。
309
+ 为该卷设置任意名称,之后将 `spec.volumes[].configMap.name` 字段设置为对你的
310
+ ConfigMap 对象的引用。
313
311
1. 为每个需要该 ConfigMap 的容器添加一个 `.spec.containers[].volumeMounts[]`。
314
312
设置 `.spec.containers[].volumeMounts[].readOnly=true` 并将
315
313
` .spec.containers[].volumeMounts[].mountPath` 设置为一个未使用的目录名,
@@ -349,8 +347,8 @@ own `volumeMounts` block, but only one `.spec.volumes` is needed per ConfigMap.
349
347
-->
350
348
你希望使用的每个 ConfigMap 都需要在 `spec.volumes` 中被引用到。
351
349
352
- 如果 Pod 中有多个容器,则每个容器都需要自己的 `volumeMounts` 块,但针对
353
- 每个 ConfigMap,你只需要设置一个 `spec.volumes` 块。
350
+ 如果 Pod 中有多个容器,则每个容器都需要自己的 `volumeMounts` 块,但针对每个
351
+ ConfigMap,你只需要设置一个 `spec.volumes` 块。
354
352
355
353
<!--
356
354
# ### Mounted ConfigMaps are updated automatically
@@ -367,7 +365,7 @@ the [KubeletConfiguration struct](/docs/reference/config-api/kubelet-config.v1be
367
365
kubelet 组件会在每次周期性同步时检查所挂载的 ConfigMap 是否为最新。
368
366
不过,kubelet 使用的是其本地的高速缓存来获得 ConfigMap 的当前值。
369
367
高速缓存的类型可以通过
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/).
371
369
的 `ConfigMapAndSecretChangeDetectionStrategy` 字段来配置。
372
370
373
371
<!--
@@ -380,8 +378,8 @@ propagation delay, where the cache propagation delay depends on the chosen cache
380
378
-->
381
379
ConfigMap 既可以通过 watch 操作实现内容传播(默认形式),也可实现基于 TTL
382
380
的缓存,还可以直接经过所有请求重定向到 API 服务器。
383
- 因此,从 ConfigMap 被更新的那一刻算起,到新的主键被投射到 Pod 中去,这一
384
- 时间跨度可能与 kubelet 的同步周期加上高速缓存的传播延迟相等。
381
+ 因此,从 ConfigMap 被更新的那一刻算起,到新的主键被投射到 Pod 中去,
382
+ 这一时间跨度可能与 kubelet 的同步周期加上高速缓存的传播延迟相等。
385
383
这里的传播延迟取决于所选的高速缓存类型
386
384
(分别对应 watch 操作的传播延迟、高速缓存的 TTL 时长或者 0)。
387
385
@@ -391,6 +389,14 @@ ConfigMaps consumed as environment variables are not updated automatically and r
391
389
以环境变量方式使用的 ConfigMap 数据不会被自动更新。
392
390
更新这些数据需要重新启动 Pod。
393
391
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
+
394
400
<!--
395
401
A container using a ConfigMap as a [subPath](/docs/concepts/storage/volumes#using-subpath) volume mount will not receive ConfigMap updates.
396
402
-->
@@ -412,8 +418,8 @@ individual Secrets and ConfigMaps as immutable. For clusters that extensively us
412
418
data has the following advantages :
413
419
-->
414
420
Kubernetes 特性 _不可变更的 Secret 和 ConfigMap_ 提供了一种将各个
415
- Secret 和 ConfigMap 设置为不可变更的选项。对于大量使用 ConfigMap 的
416
- 集群 (至少有数万个各不相同的 ConfigMap 给 Pod 挂载)而言,禁止更改
421
+ Secret 和 ConfigMap 设置为不可变更的选项。对于大量使用 ConfigMap 的集群
422
+ (至少有数万个各不相同的 ConfigMap 给 Pod 挂载)而言,禁止更改
417
423
ConfigMap 的数据有以下好处:
418
424
419
425
<!--
@@ -422,8 +428,8 @@ ConfigMap 的数据有以下好处:
422
428
closing watches for ConfigMaps marked as immutable.
423
429
-->
424
430
- 保护应用,使之免受意外(不想要的)更新所带来的负面影响。
425
- - 通过大幅降低对 kube-apiserver 的压力提升集群性能,这是因为系统会关闭
426
- 对已标记为不可变更的 ConfigMap 的监视操作。
431
+ - 通过大幅降低对 kube-apiserver 的压力提升集群性能,
432
+ 这是因为系统会关闭对已标记为不可变更的 ConfigMap 的监视操作。
427
433
428
434
<!--
429
435
This feature is controlled by the `ImmutableEphemeralVolumes`
@@ -432,8 +438,8 @@ You can create an immutable ConfigMap by setting the `immutable` field to `true`
432
438
For example :
433
439
-->
434
440
此功能特性由 `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。
437
443
例如:
438
444
439
445
` ` ` yaml
@@ -454,8 +460,7 @@ to the deleted ConfigMap, it is recommended to recreate these pods.
454
460
-->
455
461
一旦某 ConfigMap 被标记为不可变更,则 _无法_ 逆转这一变化,,也无法更改
456
462
` data` 或 `binaryData` 字段的内容。你只能删除并重建 ConfigMap。
457
- 因为现有的 Pod 会维护一个对已删除的 ConfigMap 的挂载点,建议重新创建
458
- 这些 Pods。
463
+ 因为现有的 Pod 会维护一个对已删除的 ConfigMap 的挂载点,建议重新创建这些 Pods。
459
464
460
465
# # {{% heading "whatsnext" %}}
461
466
@@ -466,6 +471,6 @@ to the deleted ConfigMap, it is recommended to recreate these pods.
466
471
separating code from configuration.
467
472
-->
468
473
* 阅读 [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/) 来了解将代码和配置分开的动机。
471
476
0 commit comments