本章节介绍如何在测试 Kubernetes 集群中部署 Doris Operator 与 Doris 集群。 部署操作如下:

  1. 创建 Kubernetes 测试集群
  2. 部署 Doris Operator
  3. 部署 Doris 集群
  4. 连接访问 Doris 集群

第 1 步:创建 Kubernetes 测试集群

此步骤简述在没有 k8s 集群的情况下如何快速搭建一套单节点 k8s 集群,如果已有 k8s 集群,此步骤请跳过。
Kind 是目前比较通用的创建本地 Kubernetes 测试环境的方案。Kind 使用 Docker 容器作为节点,在本地创建和运行 Kubernetes 集群。

  1. 部署前置条件 部署前需要确保环境中具有以下组件:
组件版本要求
Docker>= 18.09
kubectl>=1.19
kind>=0.8.0
  1. 使用 kind 部署 Kubernetes 集群 本例中使用 kind 0.10.0 版本安装 Kubernetes 集群,命令如下:

    1. kind create cluster --image kindest/node:v1.20.2 --name test-doris

    期望输出结果:

    1. Creating cluster "test-doris" ...
    2. Ensuring node image (kindest/node:v1.20.2)
    3. Preparing nodes
    4. Writing configuration
    5. Starting control-plane
    6. Installing CNI
    7. Installing StorageClass
    8. Set kubectl context to "kind-test-doris"
    9. You can now use your cluster with:
  2. 检查 Kubernetes 集群状态 使用以下命令检查 Kubernete 集群状态:

    1. kubectl cluster-info --context kind-test-doris

    以下是期望输出结果:

    1. Kubernetes control plane is running at https://127.0.0.1:40075
    2. KubeDNS is running at https://127.0.0.1:40075/api/v1/namespaces/kube-system/services/kube-dns:dns/proxy
    3. To further debug and diagnose cluster problems, use 'kubectl cluster-info dump'.

第 2 步:部署 Doris Operator

部署 Doris Operator 分成安装定义和部署 operator 服务两部分:

  1. 安装 Doris Operator CRD 通过以下命令添加 Doris Operator 的自定义资源(CRD):

    1. kubectl apply -f https://raw.githubusercontent.com/selectdb/doris-operator/master/config/crd/bases/doris.selectdb.com_dorisclusters.yaml

    期望输出结果:

    1. customresourcedefinition.apiextensions.k8s.io/dorisclusters.doris.selectdb.com created
  2. 安装 Doris Operator 通过以下命令安装 Doris Operator :

    1. kubectl apply -f https://raw.githubusercontent.com/selectdb/doris-operator/master/config/operator/operator.yaml

    期望输出结果:

    1. namespace/doris created
    2. role.rbac.authorization.k8s.io/leader-election-role created
    3. rolebinding.rbac.authorization.k8s.io/leader-election-rolebinding created
    4. clusterrole.rbac.authorization.k8s.io/doris-operator created
    5. clusterrolebinding.rbac.authorization.k8s.io/doris-operator-rolebinding created
    6. serviceaccount/doris-operator created
    7. deployment.apps/doris-operator created
  3. 检查 Doris Operator 状态 通过以下命令检查 Doris Operator 的部署状态:

    1. kubectl get pods -n doris

    期望输出结果:

    1. NAME READY STATUS RESTARTS AGE
    2. doris-operator-7f578c86cb-nz6jn 1/1 Running 0 19m

    Doris Operator 相关配置以及其他部署方式可参考部署 operator 部分

第 3 步:部署 Doris 集群

  1. 下载模板 Doris 部署模板:

    1. curl -O https://raw.githubusercontent.com/apache/doris-operator/master/doc/examples/doriscluster-sample.yaml
  2. 根据集群配置章节按需进行定制化配置,配置完成后通过如下命令部署:

    1. kubectl apply -f doriscluster-sample.yaml
  3. 检查集群部署状态: 通过查看 pods 的状态检查集群的状态:

    1. kubectl get pods

    期望结果:

    1. NAME READY STATUS RESTARTS AGE
    2. doriscluster-sample-fe-0 1/1 Running 0 2m
    3. doriscluster-sample-be-0 1/1 Running 0 3m

    检查部署资源的状态:

    1. kubectl get dcr -n doris

    期望结果:

    1. NAME FESTATUS BESTATUS CNSTATUS BROKERSTATUS
    2. doriscluster-sample available available

第 4 步:连接访问 Doris 集群

在测试环境中快速部署的 Doris 集群,可以进入容器 FE 内部使用 MySQL Client 链接 Doris 进行测试操作。其他访问方式可参考集群访问章节配置使用。

  1. 获取 FE 容器名称:

    1. kubectl get pod -n doris | grep fe
    2. doriscluster-sample-fe-0 1/1 Running 0 16m

    在本例中,FE 容器名为 doriscluster-sample-fe-0。

  2. 进入 FE 容器内部:

    1. kubectl -n doris exec -it doriscluster-sample-fe-0 /bin/bash
  3. 在 FE 容器内部使用 MySQL Client 链接 Doris 集群:

    1. mysql -uroot -P9030 -h127.0.0.1