关于


OpenShift Container Platform 4.6

OpenShift Container Platform 简介

摘要

本文档概述 OpenShift Container Platform 的功能。

第 1 章 OpenShift Container Platform 4.6 文档

欢迎使用官方 OpenShift Container Platform 4.6 文档,您可以在其中查找信息以帮助您了解 OpenShift Container Platform 并开始探索其功能。

要浏览 OpenShift Container Platform 4.6 文档,您可以:

  • 使用左侧导航条浏览文档或
  • 从此 Welcome 页面上的内容中选择您感兴趣的内容。

您可以从架构安全及合规性开始。然后,请参阅 发行注记

1.1. 集群安装程序操作

作为安装 OpenShift Container Platform 4.6 集群的人员,该文档可帮助您:

  • 在 Red Hat Virtualization (RHV) 上安装集群:您可以使用快速安装使用自定义的安装在 Red Hat Virtualization (RHV) 上安装集群。
  • 在受限网络中安装集群 :如果在 AWSGCPvSphere裸机上使用用户置备的基础架构的集群无法完全访问互联网,则可以 镜像 OpenShift Container Platform 安装镜像并在受限网络中安装集群。
  • 在现有网络中安装集群 :如果您使用 AWSGCP 中的一个现存的 Virtual Private Cloud (VPC),或使用 Azure 上的现存的 VNet,您可以安装集群。
  • 安装一个私有集群:如果集群不需要外部互联网访问,您可以在 AWSAzureGCP 上安装私有集群。要访问云 API 和安装介质时,仍需要访问互联网。
  • 检查安装日志 :检查安装日志,评估在 OpenShift Container Platform 4.6 安装过程中发生的问题。
  • 访问 OpenShift Container Platform:使用安装过程末尾的凭证输出,从命令行或 Web 控制台登录到 OpenShift Container Platform 集群。
  • 安装 Red Hat OpenShift Container Storage :您可以安装 Red Hat OpenShift Container Storage 作为 Operator,以便为容器提供高度集成和简化的持久性存储管理。

1.2. 开发人员活动

最终,OpenShift Container Platform 成为一个用于开发和部署容器化应用程序的平台。作为应用程序开发人员,OpenShift Container Platform 文档可帮助您:

使用 Topology 视图 来视觉化与应用程序、监控状态、连接和组组件进行交互,以及修改您的代码库。

  • 使用开发人员 CLI 工具(odo) :odo CLI 工具可让开发人员轻松创建单一或多组件应用程序,并自动执行部署、构建和服务路由配置。它提取了复杂的 Kubernetes 和 OpenShift Container Platform 概念,允许您专注于开发应用程序。
  • 创建 CI/CD 管道 :管道是无服务器、云原生、持续集成和在隔离容器中运行的持续部署系统。它们使用标准的 Tekton 自定义资源来实现部署自动化,并为处理基于微服务的架构的非中心化团队设计。
  • 部署 Helm chart:Helm 3 是一个软件包管理器,可帮助开发人员在 Kubernetes 中定义、安装和更新应用程序软件包。Helm Chart 是一个打包格式,用于描述可以使用 Helm CLI 部署的应用程序。
  • 了解 Operator:Operator 是为 OpenShift Container Platform 4.6 创建集群应用程序的首选方法。了解 Operator Framework 以及如何使用已安装的 Operator 部署到项目中。
  • 了解镜像构建 :从不同的构建策略(Docker、S2I、自定义和管道)中选择可以包括不同类型的源资料(Git 存储库、本地二进制输入和外部工件)。然后,请参阅从基本构建到高级构建的构建类型示例。
  • 创建容器镜像 :容器镜像是 OpenShift Container Platform(和 Kubernetes)应用程序中最基本的构建块。通过定义镜像流,在继续开发镜像时,可让您在一个位置保存镜像的多个版本。S2I 容器允许您将源代码插入到基本容器中,该容器被设置为运行特定类型的代码,如 Ruby、Node.js 或 Python。
  • 创建部署 :使用 DeploymentDeploymentConfig 对象对应用程序进行精细管理。使用 Workloads 页面或 oc CLI 管理部署。了解滚动、重新创建和自定义部署策略
  • 创建模板 :使用现有模板或创建自己的模板来描述应用的构建或部署方式。模板可以将镜像与描述、参数、副本、公开端口和其他定义如何运行或构建的内容相结合。
  • 创建 Operator :Operator 是为 OpenShift Container Platform 4.6 创建集群应用程序的首选方法。了解构建、测试和部署 Operator 的工作流。然后,基于 AnsibleHelm 创建自己的 Operator,或使用 Operator SDK 配置内置 Prometheus 监控
  • REST API 参考 :列出 OpenShift Container Platform 应用程序编程接口端点。

1.3. 集群管理员活动

OpenShift Container Platform 4.6 集群上的持续任务包括用于管理机器的各种活动,为用户提供服务,以及遵循监视集群的日志记录功能。作为集群管理员,本文档可帮助您:

1.3.1. 管理集群组件

1.3.2. 更改集群组件

  • 了解 OpenShift Update Service :了解如何安装和管理本地 OpenShift Update Service,以便在受限网络环境中推荐 OpenShift Container Platform 更新。

1.3.3. 监控集群

  • 使用集群日志记录 :了解集群日志记录和配置不同的集群日志记录类型,如 Elasticsearch、Fluentd、Kibana 和 Curator。
  • 监控集群:了解如何配置监控堆栈。配置了监控后,使用 Web UI 访问监控仪表板。除了基础架构指标外,您还可以提取和查看您自己的服务的指标。
  • 远程健康监控 :OpenShift Container Platform 会收集有关集群的匿名聚合信息,并通过 Telemetry 和 Insights Operator 向红帽报告。红帽利用这些信息便可改进 OpenShift Container Platform,并更快地对影响客户的问题做出反应。您可以查看远程健康监控收集的数据

第 2 章 关于 {oke}

从 2020 年 4 月 27 日,红帽决定将 Red Hat OpenShift Container Engine 重命名为 Red Hat OpenShift Kubernetes Engine,以更好地反映产品所提供的值。

Red Hat OpenShift Kubernetes Engine

Red Hat OpenShift Kubernetes Engine 是红帽的一个产品,可让您使用企业级 Kubernetes 平台作为启动容器的生产环境平台。下载和安装 OpenShift Container Platform 的方式与 OpenShift Container Platform 相同,但 OpenShift Kubernetes Engine 只提供了 OpenShift Container Platform 所提供的功能的一个子集。

2.1. 相同和不同的地方

您可以在下表中看到 OpenShift Kubernetes Engine 和 OpenShift Container Platform 之间的相似性和不同之处:

表 2.1. OpenShift Kubernetes Engine 和 OpenShift Container Platform 的产品比较
 OpenShift Kubernetes EngineOpenShift Container Platform

完全自动化安装程序

无线智能升级

企业集安全 Kubernetes

kubectl 和 oc 自动命令行

Operator Lifecycle Manager (OLM)

管理员 Web 控制台

OpenShift Virtualization

用户工作负载监控

 

Metering 和成本管理 SaaS 服务

 

平台日志记录

 

开发人员 Web 控制台

 

开发人员应用程序目录

 

Source to Image 和 Builder Automation (Tekton)

 

OpenShift Service Mesh(Kiali、Jaeger 和 OpenTracing)

 

OpenShift Serverless (Knative)

 

OpenShift Pipelines (Jenkins 和 Tekton)

 

IBM Cloud Pak 和 RHT MW Bundles 的嵌入式组件

 

2.1.1. 核心 Kubernetes 和容器编配

OpenShift Kubernetes Engine 提供了对一个企业级 Kubernetes 环境的完整访问权限,该环境易于安装,并提供了您的数据中心中可能使用的许多软件元素的广泛兼容性测试。

OpenShift Kubernetes Engine 提供与 OpenShift Container Platform 相同的服务级别协议、错误修复和常见漏洞和错误保护。OpenShift Kubernetes Engine 包括了一个 Red Hat Enterprise Linux (RHEL) Virtual Datacenter 和 Red Hat Enterprise Linux CoreOS (RHCOS) 权利,可让您使用集成的 Linux 操作系统与来自相同技术供应商的容器运行时。

OpenShift Kubernetes Engine 订阅与 Red Hat OpenShift support for Windows Containers 订阅兼容。

2.1.2. 企业级就绪配置

OpenShift Kubernetes Engine 使用与 OpenShift Container Platform 相同的安全选项和默认设置。默认安全性上下文约束、Pod 安全策略、最佳实践网络和存储设置、服务帐户配置、SELinux 集成、HAproxy 边缘路由配置以及 OpenShift Container Platform 提供的所有其他标准保护。OpenShift Kubernetes Engine 提供对 OpenShift Container Platform 使用的集成监控解决方案的完整访问权限,该解决方案基于 Prometheus,并为常见 Kubernetes 问题提供深入的覆盖范围和警报。

OpenShift Kubernetes Engine 使用与 OpenShift Container Platform 相同的安装和升级自动化。

2.1.3. 标准基础架构服务

通过 OpenShift Kubernetes Engine 订阅,您可以获得 OpenShift Container Platform 支持的所有存储插件支持。

在网络方面,OpenShift Kubernetes Engine 完全支持对 Kubernetes Container Network Interface (CNI) 的访问,因此您可以使用任何支持 OpenShift Container Platform 的第三方 SDN。它还允许您使用提供的 Open vSwitch 软件定义网络来进行完整扩展。OpenShift Kubernetes Engine 允许您充分利用在 OpenShift Container Platform 中支持的 OVN Kubernetes overlay、Musus 和 Multus 插件。OpenShift Kubernetes Engine 允许用户使用 Kubernetes 网络策略在集群上部署的应用程序服务之间创建微分段。

您还可以使用 OpenShift Container Platform 中发现的 Route API 对象,包括其与 HAproxy 边缘路由层集成在一起的 Kubernetes Ingress Controller。

2.1.4. 核心用户体验

OpenShift Kubernetes Engine 用户对 Kubernetes Operator、pod 部署策略、Helm 和 OpenShift Container Platform 模板具有完全访问权限。OpenShift Kubernetes Engine 用户可以使用 ockubectl 命令行界面。OpenShift Kubernetes Engine 还提供基于 Web 的管理员控制台,它显示了部署容器服务的所有方面并提供容器即服务体验。OpenShift Kubernetes Engine 授予对 Operator 生命周期管理器的访问权限,以帮助您控制您使用的集群和支持生命周期的服务中的内容。使用 OpenShift Kubernetes Engine 订阅,您可以访问 Kubernetes 命名空间、OpenShift Project API 对象和集群级 Prometheus 监控指标和事件的访问权限。

2.1.5. 维护和策展的内容

使用 OpenShift Kubernetes Engine 订阅,您可从红帽生态系统目录和红帽 Connect ISV 市场访问 OpenShift Container Platform 内容。您可以访问 OpenShift Container Platform 生态环境所提供的所有维护和策展的内容。

2.1.6. 兼容 OpenShift Container Storage

OpenShift Kubernetes Engine 与 OpenShift Container Storage 兼容并提供支持。

2.1.7. Red Hat Middleware 兼容

OpenShift Kubernetes Engine 与独立的 Red Hat Middleware 产品解决方案兼容并提供支持。包括 OpenShift 的 Red Hat Middleware Bundles 仅包含 OpenShift Container Platform。

2.1.8. OpenShift Serverless

OpenShift Kubernetes Engine 不包括对 OpenShift Serverless 的支持。请使用 OpenShift Container Platform 进行这个支持。

2.1.9. Quay 集成兼容

OpenShift Kubernetes Engine 兼容并支持 Red Hat Quay。

2.1.10. OpenShift Virtualization

OpenShift Kubernetes Engine 包括对来自 kubevirt.io 开源项目提供的红帽产品产品支持。

2.1.11. 高级集群管理

OpenShift Kubernetes Engine 与您额外购买的 {rh-rhacm-first} for Kubernetes 兼容。OpenShift Kubernetes Engine 订阅不提供集群范围的日志聚合解决方案,或支持 Elasticsearch、Fluentd 或基于 Kibana 的日志记录解决方案。同样,OpenShift Container Platform 或 console.redhat.com Cost Management SaaS 服务中的计费功能也不支持 OpenShift Kubernetes Engine。OpenShift Kubernetes Engine 不支持来自开源 istio.io 和 kiali.io 项目的 Red Hat Service Mesh 功能,为 OpenShift Container Platform 上的容器化服务提供 OpenTracing 可观察性。

2.1.12. 高级网络

OpenShift Container Platform 中的标准网络解决方案支持 OpenShift Kubernetes Engine 订阅。OpenShift Container Platform 的 Kubernetes CNI 插件可用于自动化 OpenShift Container Platform 项目之间的多租户网络分段。OpenShift Kubernetes Engine 提供对集群中应用程序服务使用的源 IP 地址的所有细粒度控制。这些出口 IP 地址控制可以与 OpenShift Kubernetes Engine 搭配使用。当没有通过 OpenShift Container Platform 中的 VIP pod 使用的公共云供应商时,OpenShift Container Platform 在集群服务上提供入口路由。OpenShift Kubernetes Engine 支持该入口解决方案。OpenShift Kubernetes Engine 用户支持 Kubernetes ingress 控制对象,它提供与公共云提供商的集成。OpenShift Kubernetes Engine 不支持来自 istio.io 开源项目的 Red Hat Service Mesh。另外,OpenShift Kubernetes Engine 不支持 OpenShift Serverless 中找到的 Kourier Ingress Controller。

2.1.13. 开发者体验

在 OpenShift Kubernetes Engine 中,不支持以下功能:

  • CodeReady 开发人员体验工具,如 CodeReady Workspaces。
  • OpenShift Container Platform 的管道功能将启用 Kubernetes 的简化 Jenkins 和 Tekton 体验整合到用户的项目空间中。
  • OpenShift Container Platform 的 source-to-image 功能,可让您在集群中轻松部署源代码、dockerfiles 或容器镜像。
  • 用于最终用户容器部署的构建策略、构建器 Pod 或 Tekton。
  • odo developer 命令行。
  • OpenShift Container Platform Web 控制台中的开发人员用户角色。

2.1.14. 功能概述

下表是 OpenShift Kubernetes Engine 和 OpenShift Container Platform 中功能可用性的摘要。

表 2.2. OpenShift Kubernetes Engine 和 OpenShift Container Platform 中的功能

功能

OpenShift Kubernetes Engine

OpenShift Container Platform

Operator 名称

完全自动化安装程序 (IPI)

包括

包括

N/A

可自定义的安装程序 (UPI)

包括

包括

N/A

断开连接的安装

包括

包括

N/A

Red Hat Enterprise Linux (RHEL) 或 Red Hat Enterprise Linux CoreOS (RHCOS) 权利

包括

包括

N/A

将现有 RHEL 手动附加到集群 (BYO)

包括

包括

N/A

CRIO 运行时

包括

包括

N/A

无线智能升级和 Operating System (RHCOS) 管理

包括

包括

N/A

企业集安全 Kubernetes

包括

包括

N/A

kubectl 和 oc 自动命令行

包括

包括

N/A

Auth Integrations, RBAC, SCC, Multi-Tenancy Admission 控制器

包括

包括

N/A

Operator Lifecycle Manager (OLM)

包括

包括

N/A

管理员 Web 控制台

包括

包括

N/A

OpenShift Virtualization

包括

包括

OpenShift Virtualization Operator

红帽提供的 Compliance Operator

包括

包括

Compliance Operator

File Integrity Operator

包括

包括

File Integrity Operator

Gatekeeper Operator

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

Gatekeeper Operator

Klusterlet

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

N/A

由红帽提供的 kube Descheduler Operator

包括

包括

kube Descheduler Operator

由红帽提供的本地存储

包括

包括

Local Storage Operator

红帽提供的节点功能发现

包括

包括

Node Feature Discovery Operator

Performance Add-on Operator

包括

包括

Performance Add-on Operator

红帽提供的 PTP Operator

包括

包括

PTP Operator

红帽提供的 Service Telemetry Operator

包括

包括

Service Telemetry Operator

Cluster Network Operator

包括

包括

Cluster Network Operator

Vertical Pod Autoscaler

包括

包括

Vertical Pod Autoscaler

集群监控 (Prometheus)

包括

包括

集群监控

设备管理器(例如 GPU)

包括

包括

N/A

日志转发(使用 fluentd)

包括

包括

Red Hat OpenShift Logging Operator(用于带有 fluentd 的日志转发)

Telemeter 和 Insights 连接体验

包括

包括

N/A

功能

OpenShift Kubernetes Engine

OpenShift Container Platform

Operator 名称

OpenShift Cloud Manager SaaS Service

包括

包括

N/A

OVS 和 OVN SDN

包括

包括

N/A

MetalLB

包括

包括

MetalLB Operator

HAProxy Ingress Controller

包括

包括

N/A

Red Hat OpenStack Platform (RHOSP) Kuryr 集成

包括

包括

N/A

Ingress 集群范围的防火墙

包括

包括

N/A

Egress Pod 和命名空间颗粒控制

包括

包括

N/A

Ingress 非标准端口

包括

包括

N/A

Multus 和 Available Multus 插件

包括

包括

N/A

网络策略

包括

包括

N/A

IPv6 单栈和双栈

包括

包括

N/A

CNI 插件 ISV 兼容性

包括

包括

N/A

CSI 插件 ISV 兼容性

包括

包括

N/A

按需购买 RHT 和 IBM 中间件(没有包括在 OpenShift Container Platform 或 OpenShift Kubernetes Engine 中)

包括

包括

N/A

ISV 或合作伙伴的 Operator 和容器兼容性(没有包括在 OpenShift Container Platform 或 OpenShift Kubernetes Engine 中)

包括

包括

N/A

嵌入式 OperatorHub

包括

包括

N/A

嵌入式市场

包括

包括

N/A

Quay 兼容性(不包含)

包括

包括

N/A

RHEL Software Collections 和 RHT SSO Common Service(包括)

包括

包括

N/A

嵌入式 Registry

包括

包括

N/A

Helm

包括

包括

N/A

用户工作负载监控

未包含

包括

N/A

Metering 和成本管理 SaaS 服务

未包含

包括

N/A

平台日志记录

未包含

包括

Red Hat OpenShift Logging Operator

红帽提供的 OpenShift Elasticsearch Operator

未包含

无法独立运行

N/A

开发人员 Web 控制台

未包含

包括

N/A

开发人员应用程序目录

未包含

包括

N/A

Source to Image 和 Builder Automation (Tekton)

未包含

包括

N/A

OpenShift Service Mesh

未包含

包括

OpenShift Service Mesh Operator

Service Binding Operator

未包含

包括

Service Binding Operator

功能

OpenShift Kubernetes Engine

OpenShift Container Platform

Operator 名称

Red Hat OpenShift Serverless

未包含

包括

OpenShift Serverless Operator

红帽提供的 Web 终端

未包含

包括

Web Terminal Operator

红帽提供的 Jenkins Operator

未包含

包括

Jenkins Operator

Red Hat OpenShift Pipelines Operator

未包含

包括

OpenShift Pipelines Operator

IBM Cloud Pak 和 RHT MW Bundles 的嵌入式组件

未包含

包括

N/A

Red Hat OpenShift GitOps

未包含

包括

OpenShift GitOps

Red Hat CodeReady Workspaces

未包含

包括

CodeReady Workspaces

Red Hat CodeReady Containers

未包含

包括

N/A

红帽提供的 Quay Bridge Operator

未包含

包括

Quay Bridge Operator

红帽提供的 Quay Container Security

未包含

包括

Quay Operator

Red Hat OpenShift distributed tracing Platform

未包含

包括

Red Hat OpenShift 分布式跟踪平台 Operator

Red Hat OpenShift Kiali

未包含

包括

Kiali Operator

由红帽提供的 metering(已弃用)

未包含

包括

N/A

Containers Operator 的 Migration Toolkit

未包含

包括

Containers Operator 的 Migration Toolkit

OpenShift 的成本管理

不包括

包括

N/A

Red Hat JBoss Web Server

不包括

包括

JWS Operator

红帽构建的 Quarkus

不包括

包括

N/A

Kourier Ingress 控制器

不包括

包括

N/A

RHT Middleware Bundles Sub 兼容性(不包括在 OpenShift Container Platform 中)

不包括

包括

N/A

IBM Cloud Pak Sub 兼容性(不包括在 OpenShift Container Platform 中)

不包括

包括

N/A

OpenShift Do (odo)

不包括

包括

N/A

Source to Image 和 Tekton Builders

不包括

包括

N/A

OpenShift Serverless FaaS

不包括

包括

N/A

IDE 集成

不包括

包括

N/A

Windows Machine Config Operator

包括的社区 Windows Machine Config Operator - 不需要订阅

包括的 Red Hat Windows Machine Config Operator - 需要单独的订阅

Windows Machine Config Operator

Red Hat Quay

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

Quay Operator

Red Hat Advanced Cluster Management

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

Advanced Cluster Management for Kubernetes

Red Hat Advanced Cluster Security

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

N/A

OpenShift Container Storage

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

OpenShift Container Storage

功能

OpenShift Kubernetes Engine

OpenShift Container Platform

Operator 名称

Ansible Automation Platform Resource Operator

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

Ansible Automation Platform Resource Operator

红帽提供的业务自动化

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

Network Automation Operator

由红帽提供的数据网格

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

Data Grid Operator

由红帽提供的 Red Hat Integration

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

Red Hat Integration Operator

Red Hat Integration - 由红帽提供的 3Scale

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

3scale

Red Hat Integration - 由红帽提供的 3Scale APICast 网关

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

3scale APIcast

Red Hat Integration - AMQ Broker

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

AMQ Broker

Red Hat Integration - AMQ Broker LTS

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

 

Red Hat Integration - AMQ Interconnect

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

AMQ Interconnect

Red Hat Integration - AMQ Online

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

 

Red Hat Integration - AMQ Streams

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

AMQ Streams

Red Hat Integration - Camel K

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

Camel K

Red Hat Integration - Fuse Console

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

Fuse 控制台

Red Hat Integration - Fuse Online

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

Fuse Online

Red Hat Integration - Service Registry Operator

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

Service Registry

红帽提供的 API Designer

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

API Designer

红帽提供的 JBoss EAP

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

JBoss EAP

红帽提供的 JBoss Web Server

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

JBoss Web Server

Smart Gateway Operator

未包括 - 需要单独的订阅

未包括 - 需要单独的订阅

Smart Gateway Operator

2.2. 订阅限制

OpenShift Kubernetes Engine 是一个订阅产品,它提供了 OpenShift Container Platform 中的一组有限的功能,其价格较低。OpenShift Kubernetes Engine 和 OpenShift Container Platform 是相同的产品,所有软件和功能都会在这两个服务中提供。因此,它们使用同一个下载 - OpenShift Container Platform。OpenShift Kubernetes Engine 使用 OpenShift Container Platform 文档并支持服务和程序错误修复。

第 3 章 Kubernetes 概述

Kubernetes 是由 Google 开发的开源容器编排工具。您可以使用 Kubernetes 运行和管理基于容器的工作负载。最常见的 Kubernetes 用例是部署一系列互联微服务,以云原生方式构建应用。您可以创建 Kubernetes 集群,跨越内部部署、公共云、私有云或混合云中的主机。

传统上,应用程序部署在单一操作系统之上。通过虚拟化,您可以将物理主机分成几个虚拟主机。在共享资源中使用虚拟实例并非是实现运行效率和可扩展性的最佳选择。因为虚拟机 (VM) 和物理主机一样会消耗尽可能多的资源,因此为虚拟机提供资源(如 CPU、RAM 和存储)的成本会比较高。另外,您可能会看到,因为使用共享资源,导致虚拟实例中运行的应用程序的性能下降。

图 3.1. 用于类部署的容器技术的演进

247 OpenShift Kubernetes 概述

要解决这个问题,您可以使用容器化技术,在一个容器化环境中隔离应用程序。与虚拟机类似,容器具有自己的文件系统、vCPU、内存、进程空间、依赖项等。容器与底层基础架构分离,可跨云和操作系统分布移植。与一个功能齐全的操作系统相比,容器是一个更加轻量的系统,它会在操作系统上隔离进程。虚拟机的启动速度较慢,它是物理硬件的抽象概念。虚拟机在一台机器上运行,由一个虚拟机监控程序(hypervisor)处理。

您可以使用 Kubernetes 执行以下操作:

  • 共享资源
  • 在多个主机间编排容器
  • 安装新的硬件配置
  • 运行健康检查和自我修复应用程序
  • 扩展容器化应用程序

3.1. Kubernetes 组件

表 3.1. Kubernetes 组件
组件用途

kube-proxy

在集群的每个节点上运行,并维护 Kubernetes 资源之间的网络流量。

kube-controller-manager

监管集群的状态。

kube-scheduler

将 pod 分配给节点。

etcd

存储集群数据。

kube-apiserver

验证并配置 API 对象的数据。

kubelet

在节点上运行并读取容器清单。确保定义的容器已启动且正在运行。

kubectl

您可以定义如何运行工作负载。使用 kubectl 命令与 kube-apiserver 进行交互。

节点

节点是 Kubernetes 集群中的物理机器或虚拟机。控制平面(control plane)管理每个节点,并在 Kubernetes 集群中的节点之间调度 pod。

容器运行时

容器运行时在主机操作系统上运行容器。您必须在每个节点上安装容器运行时,以便 pod 能够在该节点上运行。

持久性存储

即便在设备关闭后也存储数据。Kubernetes 使用持久性卷来存储应用程序数据。

container-registry

存储和访问容器镜像。

Pod

pod 是 Kubernetes 中的最小逻辑单元。pod 包含一个或多个在 worker 节点上运行的容器。

3.2. Kubernetes 资源

自定义资源是 Kubernetes API 的扩展。您可以使用自定义资源自定义 Kubernetes 集群。Operator 是一个软件扩展,它通过自定义资源来管理应用程序及其组件。当您希望在处理集群资源时具有固定的结果,则 Kubernetes 会使用声明性模型。通过使用 Operator,Kubernetes 以声明性方式定义其状态。您可以使用必需命令修改 Kubernetes 集群资源。Operator 充当控制循环,它可以持续将所需的资源状态与资源的实际状态进行比较,并将操作与所需的状态保持一致。

图 3.2. Kubernetes 集群概述

247 OpenShift Kubernetes 概述 1
表 3.2. Kubernetes 资源
资源用途

Service

Kubernetes 使用服务在一组 pod 上公开正在运行的应用程序。

ReplicaSet

Kubernetes 使用 ReplicaSet 来维护恒定的 pod 号。

Deployment

维护应用程序生命周期的资源对象。

Kubernetes 是 OpenShift Container Platform 的核心组件。您可以使用 OpenShift Container Platform 开发和运行容器化应用程序。OpenShift Container Platform 以 Kubernetes 为基础,为大规模电信、流视频、游戏、银行和其他应用提供引擎技术。您可以使用 OpenShift Container Platform 将容器化应用程序扩展至内部和多云环境中的容器化应用程序。

图 3.3. Kubernetes 构架

247 OpenShift Kubernetes 概述 2

集群是一个计算单元,由云环境中的多个节点组成。Kubernetes 集群包含一个 control plane 和 worker 节点。您可以在各种机器和环境中运行 Kubernetes 容器。control plane 节点控制和维护集群的状态。您可以使用 worker 节点运行 Kubernetes 应用程序。您可以使用 Kubernetes 命名空间来区分集群中的集群资源。命名空间范围适用于资源对象,如部署、服务和 pod。您不能将命名空间用于集群范围的资源对象,如存储类、节点和持久性卷。

3.3. Kubernetes 概念指南

在 OpenShift Container Platform 入门前,请考虑以下 Kubernetes 概念指南:

  • 从一个或多个 worker 节点开始,以运行容器工作负载。
  • 从一个或多个 control plane 节点管理这些工作负载的部署。
  • 将容器嵌套到名为 pod 的部署单元中。使用 pod 可以为容器提供额外的元数据,并可在单个部署实体中对多个容器进行分组。
  • 创建特殊种类的资产。例如,服务由一组 pod 及定义了访问方式的策略来表示。此策略可使容器连接到所需的服务,即便容器没有用于服务的特定 IP 地址。复制控制器(replication controller)是另一种特殊资产,用于指示一次需要运行多少个 pod 副本。您可以使用此功能来自动扩展应用程序,以适应其当前的需求。OpenShift Container Platform 集群的 API 是 100% Kubernetes。在任何 Kubernetes 上运行的容器之间没有变化,并在 OpenShift Container Platform 上运行。没有对应用的更改。OpenShift Container Platform 提供附加值功能,为 Kubernetes 提供企业级的增强。OpenShift Container Platform CLI 工具(oc)与 kubectl 兼容。虽然 Kubernetes API 100% 可在 OpenShift Container Platform 中使用,但 kubectl 命令行缺少了很多用户友好的功能。OpenShift Container Platform 提供了一组功能和命令行工具,如 oc。虽然 Kubernetes 擅长管理应用程序,但它并未指定或管理平台级要求或部署过程。强大而灵活的平台管理工具和流程是 OpenShift Container Platform 具备的重要优势。您必须将身份验证、网络、安全、监控和日志管理添加到容器化平台中。
Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

© 2024 Red Hat, Inc.