Docker 对象标签

标签是一种将元数据应用于 Docker 对象的机制,包括:

  • 镜像
  • 器皿
  • 本地守护程序
  • 网络
  • Swarm 节点
  • Swarm 服务

您可以使用标签来组织镜像、记录许可信息、注释 容器、卷和网络之间的关系,或者以任何使 sense 为您的业务或应用程序提供服务。

标签键和值

标签是一个键值对,存储为字符串。您可以指定多个标签 ,但每个键在对象中必须是唯一的。如果 为同一 key 提供多个值,最近写入的值将覆盖 所有以前的值。

关键格式建议

标签键是键值对的左侧。键是字母数字 可能包含句点 ()、下划线 ()、斜杠 () 和连字符 () 的字符串。大多数 Docker 用户使用 由其他组织创建的镜像,以下准则有助于 防止对象之间无意中重复标签,尤其是在您规划时 以使用标签作为自动化机制。._/-

  • 第三方工具的作者应为每个标签键添加 他们拥有的域的反向 DNS 表示法,例如 .com.example.some-label

  • 未经域所有者许可,请勿在标签键中使用域。

  • 、 和 命名空间是 由 Docker 保留供内部使用。com.docker.*io.docker.*org.dockerproject.*

  • 标签键应以小写字母开头和结尾,并且只应 包含小写字母数字字符、句点字符 () 和 连字符 ()。不允许使用连续的句点或连字符。.-

  • 句点字符 () 分隔命名空间 “fields”。标签键 命名空间保留供 CLI 使用,允许 CLI 用户以交互方式 使用较短的易于键入的字符串标记 Docker 对象。.

这些准则目前未强制执行,其他准则可能适用 到特定的用例。

价值准则

标签值可以包含任何可以表示为字符串的数据类型, 包括(但不限于)JSON、XML、CSV 或 YAML。唯一的要求是 首先将值序列化为字符串,使用特定于 结构的类型。例如,要将 JSON 序列化为字符串,您可以 使用 JavaScript 方法。JSON.stringify()

由于 Docker 不会反序列化该值,因此您不能将 JSON 或 XML document 作为嵌套结构进行查询或筛选,除非 您可以将此功能构建到第三方工具中。

管理对象上的标签

每种支持标签的对象类型都有用于添加和 管理它们并使用它们,因为它们与该类型的对象相关。这些链接 提供一个开始学习如何在 Docker 部署。

镜像、容器、本地守护程序、卷和网络上的标签是静态的 对象的生命周期。要更改这些标签,必须重新创建对象。 Swarm 节点和服务上的标签可以动态更新。