在 Oracle OKE 上部署 KubeSphere

本文演示在 Oracle Kubernetes Engine 上部署 KubeSphere 的步骤。

创建 Kubernetes 集群

  1. 在 OKE 上创建一个标准的 Kubernetes 集群是安装 KubeSphere 的前提条件。在导航栏中,请参考下图创建集群。

    创建集群

  2. 在弹出窗口中,选择快速创建并点击启动工作流

    快速创建

    备注

    本示例演示快速创建,Oracle Cloud 通过此模式会为集群自动创建所必需的资源。如果您选择定制创建,您需要自己创建所有资源(例如 VCN 和负载均衡器子网)。

  3. 接下来,您需要为集群设置基本信息(可参考以下图例)。完成后,请点击下一步

    集群基本信息

    备注

    • KubeSphere 3.0.0 所支持的 Kubernetes 版本:1.15.x, 1.16.x, 1.17.x, 1.18.x。
    • 建议您在可见性类型中选择公共,即每个节点会分配到一个公共 IP 地址,此地址之后可用于访问 KubeSphere Web 控制台。
    • 在 Oracle Cloud 中,配置定义了一个实例会分配到的 CPU 和内存等资源量,本示例使用 VM.Standard.E2.2 (2 CPUs and 16G Memory)。有关更多信息,请参见 Standard Shapes
    • 本示例包含 3 个节点,可以根据需求自行添加节点(尤其是生产环境)。
  4. 检查集群信息,确认无需修改后点击创建集群

    完成创建集群

  5. 集群创建后,点击关闭

    集群创建完成

  6. 确保集群状态为活动后,点击访问集群

    访问集群

  7. 在弹出窗口中,选择 Cloud Shell 访问权限。点击启动 Cloud Shell,并将 Oracle Cloud 所提供的命令复制到 Cloud Shell。

    启动Cloud-shell

  8. 在 Cloud Shell 中,粘贴该命令以便之后可以执行 KubeSphere 安装命令。

    cloud-shell-oke

    警告

    如果不在 Cloud Shell 中执行该命令,您无法继续进行以下操作。

在 OKE 上安装 KubeSphere

  1. 使用 kubectl 安装 KubeSphere。直接输入以下命令会默认执行 KubeSphere 的最小化安装。

    1. kubectl apply -f https://github.com/kubesphere/ks-installer/releases/download/v3.0.0/kubesphere-installer.yaml
    2. kubectl apply -f https://github.com/kubesphere/ks-installer/releases/download/v3.0.0/cluster-configuration.yaml
  2. 检查安装日志:

    1. kubectl logs -n kubesphere-system $(kubectl get pod -n kubesphere-system -l app=ks-install -o jsonpath='{.items[0].metadata.name}') -f
  3. 安装完成后会输出以下信息:

    1. #####################################################
    2. ### Welcome to KubeSphere! ###
    3. #####################################################
    4. Console: http://10.0.10.2:30880
    5. Account: admin
    6. Password: P@88w0rd
    7. NOTES
    8. 1. After logging into the console, please check the
    9. monitoring status of service components in
    10. the "Cluster Management". If any service is not
    11. ready, please wait patiently until all components
    12. are ready.
    13. 2. Please modify the default password after login.
    14. #####################################################
    15. https://kubesphere.io 20xx-xx-xx xx:xx:xx

访问 KubeSphere 控制台

KubeSphere 安装完成后,您可以通过 NodePortLoadBalancer 的模式访问 KubeSphere 的 Web 控制台。

  1. 通过以下命令查看 KubeSphere 控制台的服务状态。

    1. kubectl get svc -n kubesphere-system
  2. 输出如下,将类型修改为 LoadBalancer,从而暴露外部 IP 地址。

    console-nodeport

    提示

    在上图中,ks-console 服务通过 NodePort 的类型暴露,即您可以通过 NodeIP:NodePort 的方式直接访问 Web 控制台(任意节点的公共 IP 都可用),值得注意的是需要在防火墙中提前开启端口 30880。

  3. 执行以下命令编辑服务配置。

    1. kubectl edit svc ks-console -o yaml -n kubesphere-system
  4. type 字段所对应的值修改为 LoadBalancer,然后保存配置。

    change-svc-type

  5. 再次执行以下命令,可以看到 IP 地址现已暴露(如下图)。

    1. kubectl get svc -n kubesphere-system

    console-service

  6. 访问此外部 IP 地址并通过默认的账号和密码 (admin/P@88w0rd) 登录 Web 控制台。在集群管理页面,您可以看到集群概览。

    概览页面

启用可拔插组件(可选)

上面的示例演示了默认的最小安装过程,要在 KubeSphere 中启用其他组件,请参阅启用可插拔组件