您正在查看 KubeSphere 版本的文档:v3.0.0

KubeSphere v3.0.0 版本的文档已不再维护。您现在看到的版本来自于一份静态的快照。如需查阅最新文档,请点击 最新版本

启用可插拔组件

本教程演示如何在安装前或安装后启用 KubeSphere 的可插拔组件。KubeSphere 具有以下列出的十个可插拔组件。

配置项功能组件描述
alertingKubeSphere 告警系统使用户能够自定义告警策略,及时向接收器发送告警信息。支持自定义告警信息发送间隔以及告警级别。
auditingKubeSphere 审计日志系统KubeSphere 审计日志系统提供了一套与安全相关并按时间顺序排列的记录,记录了平台上不同租户的活动。
devopsKubeSphere DevOps 系统基于 Jenkins 提供开箱即用的 CI/CD 功能,提供一站式 DevOps 方案,内置 Jenkins 流水线与 B2I & S2I。
eventsKubeSphere 事件系统提供一个图形化的 Web 控制台,用于导出、过滤和警告多租户 Kubernetes 集群中的 Kubernetes 事件。
loggingKubeSphere 日志系统在统一的控制台中提供灵活的日志查询、收集和管理功能。可以添加第三方日志收集器,例如 Elasticsearch、Kafka 和 Fluentd。
metrics_serverHPA根据设定指标对 Pod 数量进行动态伸缩,使运行在上面的服务对指标的变化有一定的自适应能力。
networkpolicy网络策略可以在同一个集群内部之间设置网络策略(比如限制或阻止某些实例 Pod 之间的网络请求)。
notificationKubeSphere 通知系统允许用户将 Alertmanager 发送出来的告警通知到不同渠道,包括电子邮件、企业微信和 Slack(最新版本的 Notification Manager 支持钉钉和 Webhook)。
openpitrixKubeSphere 应用商店基于 Helm 的应用程序商店,允许用户管理应用的整个生命周期。
servicemeshKubeSphere 服务网格 (基于 Istio)支持灰度发布、流量拓扑、流量治理、流量跟踪。

有关每个组件的更多信息,请参见启用可插拔组件概述

备注

  • 如果您使用 KubeKey 在 Linux 上安装 KubeSphere,默认情况下,除了 metrics_server 之外,不会启用上述组件。但是,如果在现有的 Kubernetes 集群上安装 KubeSphere,metrics_server 则默认禁用。这是因为您的环境可能已经安装了该组件,特别是对于云托管的 Kubernetes 集群。
  • multicluster 不在本教程中介绍。如果要启用此功能,则需要为 clusterRole 设置相应的值。有关详细信息,请参见多集群管理
  • 在安装前,请确保您的机器符合硬件要求。如果想启用所有的可插拔组件,请参考推荐机器配置:CPU ≥ 8 Core,内存 ≥ 16 G,磁盘空间 ≥ 100 G。

在安装前启用可插拔组件

在 Linux 上安装

在 Linux 上安装 KubeSphere 时,需要创建一个配置文件,该文件列出所有 KubeSphere 组件。

  1. 在 Linux 上安装 KubeSphere 时,您需要创建一个默认文件名为 config-sample.yaml 的配置文件。通过执行以下命令来修改文件:

    vi config-sample.yaml
    

    备注

    如果采用 All-in-one 模式安装,您无需创建 config-sample.yaml 文件,因为 all-in-one 模式可以通过一条命令直接创建集群。通常,all-in-one 模式适用于刚接触 KubeSphere 并希望快速上手该系统的用户。如果要在此模式下启用可插拔组件(例如,出于测试目的),请参考在安装后启用可插拔组件
  2. 在此文件中,将 enabled 的值从 false 改为 true。这是完整文件供您参考,修改完成后保存文件。

  3. 使用该配置文件创建集群:

    ./kk create cluster -f config-sample.yaml
    

在 Kubernetes 上安装

在已有 Kubernetes 集群上安装 KubeSphere 时,需要部署 ks-installer 的两个 YAML 文件。

  1. 首先下载 cluster-configuration.yaml 文件,然后打开编辑。

    vi cluster-configuration.yaml
    
  2. 在该本地文件 cluster-configuration.yaml 中,将对应组件 enabled 的值从 false 改为 true

  3. 编辑完成后保存文件,执行以下命令开始安装:

    kubectl apply -f https://github.com/kubesphere/ks-installer/releases/download/v3.0.0/kubesphere-installer.yaml
    
    kubectl apply -f cluster-configuration.yaml
    

无论是在 Linux 上还是在 Kubernetes 上安装 KubeSphere,安装后都可以在 KubeSphere 的 Web 控制台中检查已启用组件的状态。转到服务组件,可以看到类似如下图片:

服务组件

在安装后启用可插拔组件

用户可以使用 KubeSphere Web 控制台查看和操作不同的资源。要在安装后启用可插拔组件,只需要在控制台中进行略微调整。对于那些习惯使用 Kubernetes 命令行工具 kubectl 的人来说,由于该工具已集成到控制台中,因此使用 KubeSphere 将毫无困难。

  1. admin 身份登录控制台。点击左上角的平台管理 ,然后选择集群管理

    集群管理

  2. 点击自定义资源 CRD,然后在搜索栏中输入 clusterconfiguration,点击搜索结果进入其详情页面。

    CRD

    信息

    自定义资源定义 (CRD) 允许用户在不增加额外 API 服务器的情况下创建一种新的资源类型,用户可以像使用其他 Kubernetes 原生对象一样使用这些自定义资源。
  3. 资源列表中,点击 ks-installer 右侧的三个点,然后选择编辑配置文件

    编辑配置文件

  4. 在该配置文件中,将对应组件 enabledfalse 更改为 true,以启用要安装的组件。完成后,点击更新以保存配置。

    启用组件

  5. 执行以下命令,使用 Web kubectl 来检查安装过程:

    kubectl logs -n kubesphere-system $(kubectl get pod -n kubesphere-system -l app=ks-install -o jsonpath='{.items[0].metadata.name}') -f
    

    提示

    您可以通过点击控制台右下角的锤子图标来找到 Web kubectl 工具。
  6. 如果组件安装成功,输出将显示以下消息。

    #####################################################
    ###              Welcome to KubeSphere!           ###
    #####################################################
    
    Console: http://192.168.0.2:30880
    Account: admin
    Password: P@88w0rd
    
    NOTES:
      1. After logging into the console, please check the
        monitoring status of service components in
        the "Cluster Management". If any service is not
        ready, please wait patiently until all components
        are ready.
      2. Please modify the default password after login.
    
    #####################################################
    https://kubesphere.io             20xx-xx-xx xx:xx:xx
    #####################################################
    
  7. 登录 KubeSphere 控制台,在服务组件中可以查看不同组件的状态。

    服务组件

    提示

    如果在上图中看不到相关组件,可能是一些 Pod 尚未启动完成,可以通过 kubectl 执行 kubectl get pod --all-namespaces 来查看 Pod 的状态。