跳到主要内容

创建并连接到 Redis 集群

本文档展示如何创建并连接到一个 Redis 集群。

创建 Redis 集群

开始之前

  • 如果您想通过 kbcli 创建并连接 MongoDB 集群,请先安装 kbcli

  • 安装 KubeBlocks

  • 确保 Redis 引擎已启用。如果未启用,请先启用该引擎

    kubectl get addons.extensions.kubeblocks.io redis
    >
    NAME TYPE VERSION PROVIDER STATUS AGE
    redis Helm Enabled 61m
  • 查看可用于创建集群的数据库类型和版本。

    kubectl get clusterdefinition redis
    >
    NAME TOPOLOGIES SERVICEREFS STATUS AGE
    redis replication,replication-twemproxy,standalone Available 16m
    kubectl get clusterversions -l clusterdefinition.kubeblocks.io/name=redis
    >
    NAME CLUSTER-DEFINITION STATUS AGE
    redis-7.0.6 redis Available 16m
    redis-7.2.4 redis Available 16m
  • 为了保持隔离,本文档中创建一个名为 demo 的独立命名空间。

    kubectl create namespace demo
    >
    namespace/demo created

创建集群

KubeBlocks 支持创建两种 Redis 集群:单机版(Standalone)和主备版(Replication)。Redis 单机版仅支持一个副本,适用于对可用性要求较低的场景。 对于高可用性要求较高的场景,建议创建主备版集群,以支持自动故障切换。为了确保高可用性,所有的副本都默认分布在不同的节点上。如果您只有一个节点可用于部署多副本集群,可设置 spec.schedulingPolicyspec.componentSpecs.schedulingPolicy,具体可参考 API 文档。但生产环境中,不建议将所有副本部署在同一个节点上,因为这可能会降低集群的可用性。

  1. 创建 Redis 集群。

    KubeBlocks 通过 Cluster 定义集群。以下是创建 Redis 集群的示例。

    cat <<EOF | kubectl apply -f -
    apiVersion: apps.kubeblocks.io/v1
    kind: Cluster
    metadata:
    name: mycluster
    namespace: demo
    spec:
    terminationPolicy: Delete
    clusterDef: redis
    topology: replication
    componentSpecs:
    - name: redis
    serviceVersion: "7.2.4"
    disableExporter: false
    replicas: 2
    resources:
    limits:
    cpu: '0.5'
    memory: 0.5Gi
    requests:
    cpu: '0.5'
    memory: 0.5Gi
    volumeClaimTemplates:
    - name: data
    spec:
    storageClassName: ""
    accessModes:
    - ReadWriteOnce
    resources:
    requests:
    storage: 20Gi
    - name: redis-sentinel
    replicas: 3
    resources:
    limits:
    cpu: '0.5'
    memory: 0.5Gi
    requests:
    cpu: '0.5'
    memory: 0.5Gi
    volumeClaimTemplates:
    - name: data
    spec:
    storageClassName: ""
    accessModes:
    - ReadWriteOnce
    resources:
    requests:
    storage: 20Gi
    EOF
    字段定义
    spec.terminationPolicy集群终止策略,有效值为 DoNotTerminateDeleteWipeOut。具体定义可参考 终止策略
    spec.clusterDef指定了创建集群时要使用的 ClusterDefinition 的名称。注意请勿更新此字段。创建 Redis 集群时,该值必须为 redis
    spec.topology指定了在创建集群时要使用的 ClusterTopology 的名称。
    spec.componentSpecs集群 component 列表,定义了集群 components。该字段支持自定义配置集群中每个 component。
    spec.componentSpecs.serviceVersion定义了 component 部署的服务版本。有效值为 [7.0.6,7.2.4]。
    spec.componentSpecs.disableExporter定义了是否在 component 无头服务(headless service)上标注指标 exporter 信息,是否开启监控 exporter。有效值为 [true, false]。
    spec.componentSpecs.replicas定义了 component 中 replicas 的数量。
    spec.componentSpecs.resources定义了 component 的资源要求。
    spec.componentSpecs.volumeClaimTemplatesPersistentVolumeClaim 模板列表,定义 component 的存储需求。
    spec.componentSpecs.volumeClaimTemplates.name引用了在 componentDefinition.spec.runtime.containers[*].volumeMounts 中定义的 volumeMount 名称。
    spec.componentSpecs.volumeClaimTemplates.spec.storageClassName定义了 StorageClass 的名称。如果未指定,系统将默认使用带有 storageclass.kubernetes.io/is-default-class=true 注释的 StorageClass。
    spec.componentSpecs.volumeClaimTemplates.spec.resources.storage可按需配置存储容量。

    您可参考 API 文档,查看更多 API 字段及说明。

    监控 Cluster CRD 并创建集群和全部依赖资源。您可执行以下命令获取集群创建的所有资源信息。

    kubectl get all,secret,rolebinding,serviceaccount -l app.kubernetes.io/instance=mycluster -n demo

    执行以下命令,查看已创建 Redis 集群的 YAML 文件。

    kubectl get cluster mycluster -n demo -o yaml
  2. 验证集群是否创建成功。

    kubectl get cluster mycluster -n demo

连接到 Redis 集群

使用 kubectl exec 命令进入 Pod 并连接到数据库。

KubeBlocks operator 会创建一个名为 mycluster-conn-credential 的新的 Secret 来存储 MySQL 集群的连接凭证。该 Secret 包含以下 key:

  • username:Redis 集群的根用户名。
  • password:根用户的密码。
  • port:Redis 集群的端口。
  • host:Redis 集群的主机。
  • endpoint:Redis 集群的终端节点,与 host:port 相同。
  1. 获取用于 kubectl exec 命令的 usernamepassword

    kubectl get secrets -n demo mycluster-conn-credential -o jsonpath='{.data.username}' | base64 -d
    >
    default

    kubectl get secrets -n demo mycluster-conn-credential -o jsonpath='{.data.password}' | base64 -d
    >
    5bv7czc4
  2. 使用用户名和密码,进入 Pod mycluster-redis-0 并连接到数据库。

    kubectl exec -ti -n demo mycluster-redis-0 -- bash

    root@mycluster-redis-0:/# redis-cli -a 5bv7czc4 --user default

有关详细的数据库连接指南,请参考连接数据库