部署
部署控制器为 Pod 和副本集提供声明式升级。您可以在部署对象中描述一个期望状态,部署控制器会以受控速率将实际状态变更为期望状态。一个部署运行着应用程序的几个副本,它会自动替换宕机或故障的实例。因此,部署能够确保应用实例可用,处理用户请求。
有关更多信息,请参见 Kubernetes 官方文档。
准备工作
您需要创建一个企业空间、一个项目和一个帐户 (project-regular
),务必邀请该帐户到项目中并赋予 operator
角色。有关更多信息,请参见创建企业空间、项目、帐户和角色。
创建部署
步骤 1:打开仪表板
以 project-regular
身份登录控制台。转到项目的应用负载,选择工作负载,点击部署选项卡下面的创建。
步骤 2:输入基本信息
为该部署指定一个名称(例如 demo-deployment
),点击下一步继续。
步骤 3:设置镜像
设置镜像前,请点击容器组副本数量中的加号或减号图标来定义 Pod 的副本数量,该参数显示在清单文件中的
.spec.replicas
字段。提示
您可以启用右上角的编辑模式,查看 YAML 格式的部署清单文件。KubeSphere 使您可以直接编辑清单文件创建部署,或者您可以按照下列步骤使用仪表板创建部署。
点击添加容器镜像。
输入镜像名称,该镜像可以来自公共 Docker Hub,也可以来自您指定的私有仓库。例如,在搜索栏输入
nginx
然后按回车键。备注
- 在搜索栏输入镜像名称后,请记得按键盘上的回车键。
- 如果想使用您的私有镜像仓库,您应该先通过配置中心下面的密钥创建镜像仓库密钥。
根据您的需求设置 CPU 和内存的资源请求和限制。有关更多信息,请参见容器镜像设置中关于资源请求和资源限制的内容。
点击使用默认端口以自动填充端口设置,或者您可以自定义协议、名称和容器端口。
在下拉菜单中选择镜像拉取策略。有关更多信息,请参见容器镜像设置中关于镜像拉取策略的内容。
对于其他设置(健康检查器、启动命令、环境变量、容器 Security Context 以及同步主机时区),您也可以在仪表板上配置它们。有关更多信息,请参见容器镜像设置中对这些属性的详细说明。操作完成后,点击右下角的 √ 继续。
在下拉菜单中选择更新策略。建议您选择滚动更新。有关更多信息,请参见更新策略。
选择部署模式。有关更多信息,请参见部署模式。
完成容器镜像设置后,点击下一步继续。
步骤 4:挂载存储卷
您可以直接添加存储卷或者挂载 ConfigMap 或密钥,或者直接点击下一步跳过该步骤。有关存储卷的更多信息,请访问存储卷。
备注
部署无法使用存储卷模板,而有状态副本集可以使用。
步骤 5:配置高级设置
您可以在该部分设置节点调度策略并添加元数据。完成操作后,点击创建完成创建部署的整个流程。
设置节点调度策略
您可以让 Pod 副本在指定节点上运行。该参数在
nodeSelector
字段中指定。添加元数据
为资源进行额外的元数据设置,例如标签和注解。
查看部署详情
详情页面
部署创建后会显示在下方的列表中。您可以点击右边的三个点,在弹出菜单中选择操作,修改您的部署。
- 编辑:查看并编辑基本信息。
- 编辑配置文件:查看、上传、下载或者更新 YAML 文件。
- 重新部署:重新部署该部署。
- 删除:删除该部署。
点击部署名称可以进入它的详情页面。
点击更多操作,显示您可以对该部署进行的操作。
- 版本回退:选择要回退的版本。
- 弹性伸缩:根据 CPU 和内存使用情况自动伸缩副本。如果 CPU 和内存都已指定,则在满足任一条件时会添加或删除副本。
- 编辑配置模板:配置更新策略、容器和存储卷。
- 编辑配置文件:查看、上传、下载或者更新 YAML 文件。
- 重新部署:重新部署该部署。
- 删除:删除该部署并返回部署列表页面。
点击资源状态选项卡,查看该部署的端口和 Pod 信息。
副本运行状态:点击图像中的箭头增加或减少 Pod 副本数量。
Pod 详情
- Pod 列表中显示了 Pod 详情(运行状态、节点、Pod IP 以及资源使用情况)。
- 您可以点击 Pod 条目查看容器信息。
- 点击容器日志图标查看容器的输出日志。
- 您可以点击 Pod 名称查看 Pod 详情页面。
版本记录
修改工作负载的资源模板后,会生成一个新的日志并重新调度 Pod 进行版本更新。默认保存 10 个最近的版本。您可以根据修改日志进行重新部署。
元数据
点击元数据选项卡以查看部署的标签和注解。
监控
点击监控选项卡以查看部署的 CPU 使用量、内存使用量、网络流出速率和网络流入速率。
点击右上角的下拉菜单以自定义时间范围和时间间隔。
点击右上角的 / 以开始或停止数据自动刷新。
点击右上角的 以手动刷新数据。
环境变量
点击环境变量选项卡以查看部署的环境变量。
事件
点击事件选项卡以查看部署的事件。