网页界面 (Dashboard)

    Dashboard 同时展示了 Kubernetes 集群中的资源状态信息和所有报错信息。

    默认情况下不会部署 Dashboard。可以通过以下命令部署:

    访问 Dashboard UI

    为了保护您的集群数据,默认情况下,Dashboard 会使用最少的 RBAC 配置进行部署。 当前,Dashboard 仅支持使用 Bearer 令牌登录。 要为此样本演示创建令牌,您可以按照上的指南进行操作。

    您可以使用 kubectl 命令行工具访问 Dashboard,命令如下:

    kubectl 会使得 Dashboard 可以通过 http://localhost:8001/api/v1/namespaces/kubernetes-dashboard/services/https:kubernetes-dashboard:/proxy/ 访问。

    UI 只能 通过执行这条命令的机器进行访问。更多选项参见 。

    注意: Kubeconfig 身份验证方法不支持外部身份提供程序或基于 x509 证书的身份验证。

    当访问空集群的 Dashboard 时,您会看到欢迎界面。页面包含一个指向此文档的链接,以及一个用于部署第一个应用程序的按钮。此外,您可以看到在默认情况下有哪些默认系统应用运行在 kube-system 中,比如 Dashboard 自己。

    Kubernetes Dashboard 欢迎页面

    部署容器化应用

    通过一个简单的部署向导,您可以使用 Dashboard 将容器化应用作为一个 Deployment 和可选的 Service 进行创建和部署。可以手工指定应用的详细配置,或者上传一个包含应用配置的 YAML 或 JSON 文件。

    点击任何页面右上角的 创建 按钮以开始。

    部署向导需要您提供以下信息:

    • 应用名称(必填):应用的名称。内容为的 会被添加到任何将被部署的 Deployment 和 Service。
    • pod 的数量(必填):您希望应用程序部署的 Pod 的数量。值必须为正整数。

    系统会创建一个 Deployment 用于保证集群中运行了期望的 Pod 数量。

    • 服务(可选):对于部分应用(比如前端),您可能想对外暴露一个 ,这个 Service(外部 Service)可能用的是集群之外的公网 IP 地址。对于外部 Service 的情况,需要开放一个或者多个端口来满足。更多信息请参考 这里

    其它只能对集群内部可见的 Service 称为内部 Service。

    不管哪种 Service 类型,如果您选择创建一个 Service,而且容器在一个端口上开启了监听(入向的),那么您需要定义两个端口。创建的 Service 会把(入向的)端口映射到容器可见的目标端口。该 Service 会把流量路由到您部署的 Pod。支持的协议有 TCP 和 UDP。这个 Service 的内部 DNS 解析名就是之前您定义的应用名称的值。

    如果需要,您可以打开 高级选项 部分,这里您可以定义更多设置:

    • 描述:这里您输入的文本会作为一个 添加到 Deployment,并显示在应用的详细信息中。

    • 标签:应用默认使用的 标签 是应用名称和版本。您可以为 Deployment、Service(如果有)定义额外的标签,比如 release(版本)、environment(环境)、tier(层级)、partition(分区) 和 release track(版本跟踪)。

    例子:

    • 命名空间:Kubernetes 支持多个虚拟集群依附于同一个物理集群。这些虚拟集群被称为 ,可以让您将资源划分为逻辑命名的组。

    Dashboard 通过下拉菜单提供所有可用的命名空间,并允许您创建新的命名空间。命名空间的名称最长可以包含 63 个字母或数字和中横线(-),但是不能包含大写字母。 命名空间的名称不能只包含数字。如果名字被设置成一个数字,比如 10,pod 就

    在 namespace 创建成功的情况下,默认会使用新创建的命名空间。如果创建失败,那么第一个命名空间会被选中。

    • 镜像拉取 Secret:如果要使用私有的 Docker 容器镜像,需要拉取 secret 凭证。

    Dashboard 通过下拉菜单提供所有可用的 secret,并允许您创建新的 secret。secret 名称必须遵循 DNS 域名语法,比如 new.image-pull.secret。secret 的内容必须是 base64 编码的,并且在一个 文件中声明。secret 名称最大可以包含 253 个字符。

    在镜像拉取 secret 创建成功的情况下,默认会使用新创建的 secret。如果创建失败,则不会使用任何 secret。

    • CPU 需求(核数)内存需求(MiB):您可以为容器定义最小的 资源限制。默认情况下,Pod 没有 CPU 和内存限制。

    • 环境变量:Kubernetes 通过 暴露 Service。您可以构建环境变量,或者将环境变量的值作为参数传递给您的命令。它们可以被应用用于查找 Service。值可以通过 $(VAR_NAME) 语法关联其他变量。

    Kubernetes 支持声明式配置。所有的配置都存储在遵循 Kubernetes API 架构的 YAML 或者 JSON 配置文件中。

    作为一种替代在部署向导中指定应用详情的方式,您可以在 YAML 或者 JSON 文件中定义应用,并且使用 Dashboard 上传文件:

    以下各节描述了 Kubernetes Dashboard UI 视图;包括它们提供的内容,以及怎么使用它们。

    当在集群中定义 Kubernetes 对象时,Dashboard 会在初始视图中显示它们。默认情况下只会显示 默认 命名空间中的对象,可以通过更改导航栏菜单中的命名空间筛选器进行改变。

    Dashboard 展示大部分 Kubernetes 对象,并将它们分组放在几个菜单类别中。

    管理概述

    集群和命名空间管理的视图, Dashboard 会列出节点、命名空间和持久卷,并且有它们的详细视图。节点列表视图包含从所有节点聚合的 CPU 和内存使用的度量值。详细信息视图显示了一个节点的度量值,它的规格、状态、分配的资源、事件和这个节点上运行的 Pod。

    负载

    显示选中的命名空间中所有运行的应用。视图按照负载类型(如 Deployment、ReplicaSet、StatefulSet 等)罗列应用,并且每种负载都可以单独查看。列表总结了关于负载的可执行信息,比如一个 ReplicaSet 的准备状态的 Pod 数量,或者目前一个 Pod 的内存使用量。

    工作负载的详情视图展示了对象的状态、详细信息和相互关系。例如,ReplicaSet 所控制的 Pod,或者 Deployment 关联的 新 ReplicaSet 和 Pod 水平扩展控制器。

    服务

    展示允许暴露给外网服务和允许集群内部发现的 Kubernetes 资源。因此,Service 和 Ingress 视图展示他们关联的 Pod、给集群连接使用的内部端点和给外部用户使用的外部端点。

    存储

    存储视图展示持久卷申领(PVC)资源,这些资源被应用程序用来存储数据。

    配置

    展示的所有 Kubernetes 资源是在集群中运行的应用程序的实时配置。通过这个视图可以编辑和管理配置对象,并显示那些默认隐藏的 secret。

    日志查看器

    Pod 列表和详细信息页面可以链接到 Dashboard 内置的日志查看器。查看器可以钻取属于同一个 Pod 的不同容器的日志。

    接下来

    更多信息,参见 Kubernetes Dashboard 项目页面.