升级NebulaGraph集群Graph
本文介绍如何升级通过Nebula Operator创建的NebulaGraph集群。
使用限制Graph
- 只支持使用Nebula Operator创建的NebulaGraph集群。
- 只支持升级NebulaGraph 2.5.x至2.6.x版本。
- 不支持升级通过0.8.0版Operator创建的集群。
使用Kubectl升级NebulaGraph集群Graph
前提条件Graph
已创建NebulaGraph集群。具体步骤,参见Graph。
本文示例中待升级的NebulaGraph版本为2.5.1,其YAML文件名为apps_v1alpha1_nebulacluster.yaml
。
操作步骤Graph
-
查看集群中服务的镜像版本。
kubectl get pods -l app.kubernetes.io/cluster=nebula -o jsonpath="{.items[*].spec.containers[*].image}" |tr -s '[[:space:]]' '\n' |sort |uniq -c
返回:
1 vesoft/nebula-graphd:v2.5.1 1 vesoft/nebula-metad:v2.5.1 3 vesoft/nebula-storaged:v2.5.1
-
编辑
apps_v1alpha1_nebulacluster.yaml
并将所有version
的值从v2.5.1修改至v2.6.0。修改后的YAML文件内容如下:
apiVersion: apps.nebula-graph.io/v1alpha1 kind: NebulaCluster metadata: name: nebula spec: graphd: resources: requests: cpu: "500m" memory: "500Mi" limits: cpu: "1" memory: "1Gi" replicas: 1 image: vesoft/nebula-graphd version: v2.6.0 //将值从v2.5.1修改至v2.6.0。 service: type: NodePort externalTrafficPolicy: Local logVolumeClaim: resources: requests: storage: 2Gi storageClassName: gp2 metad: resources: requests: cpu: "500m" memory: "500Mi" limits: cpu: "1" memory: "1Gi" replicas: 1 image: vesoft/nebula-metad version: v2.6.0 //将值从v2.5.1修改至v2.6.0。 dataVolumeClaim: resources: requests: storage: 2Gi storageClassName: gp2 logVolumeClaim: resources: requests: storage: 2Gi storageClassName: gp2 storaged: resources: requests: cpu: "500m" memory: "500Mi" limits: cpu: "1" memory: "1Gi" replicas: 3 image: vesoft/nebula-storaged version: v2.6.0 //将值从v2.5.1修改至v2.6.0。 dataVolumeClaim: resources: requests: storage: 2Gi storageClassName: gp2 logVolumeClaim: resources: requests: storage: 2Gi storageClassName: gp2 reference: name: statefulsets.apps version: v1 schedulerName: default-scheduler imagePullPolicy: Always
-
执行以下命令将版本升级的更新应用于集群CR中。
kubectl apply -f apps_v1alpha1_nebulacluster.yaml
-
等待约2分钟后,执行以下命令可查看到服务的镜像版本变更为v2.6.0。
kubectl get pods -l app.kubernetes.io/cluster=nebula -o jsonpath="{.items[*].spec.containers[*].image}" |tr -s '[[:space:]]' '\n' |sort |uniq -c
返回:
1 vesoft/nebula-graphd:v2.6.0 1 vesoft/nebula-metad:v2.6.0 3 vesoft/nebula-storaged:v2.6.0
使用Helm升级NebulaGraph集群Graph
前提条件Graph
已创建NebulaGraph集群。具体步骤,参见Graph。
操作步骤Graph
-
更新Helm仓库,拉取最新的仓库资源。
helm repo update
-
配置Helm的环境变量。
export NEBULA_CLUSTER_NAME=nebula # NebulaGraph集群的名字。 export NEBULA_CLUSTER_NAMESPACE=nebula # NebulaGraph集群所处的命名空间的名字。
-
升级NebulaGraph集群。
例如升级至v2.6.0NebulaGraph集群的命令如下。
helm upgrade "${NEBULA_CLUSTER_NAME}" nebula-operator/nebula-cluster \ --namespace="${NEBULA_CLUSTER_NAMESPACE}" \ --set nameOverride=${NEBULA_CLUSTER_NAME} \ --set nebula.version=v2.6.0
--set nebula.version
的值指需要升级集群的目标版本号。 -
执行以下命令查看集群状态及集群版本。
查看集群状态:
$ kubectl -n "${NEBULA_CLUSTER_NAMESPACE}" get pod -l "app.kubernetes.io/cluster=${NEBULA_CLUSTER_NAME}" NAME READY STATUS RESTARTS AGE nebula-graphd-0 1/1 Running 0 2m nebula-graphd-1 1/1 Running 0 2m nebula-metad-0 1/1 Running 0 2m nebula-metad-1 1/1 Running 0 2m nebula-metad-2 1/1 Running 0 2m nebula-storaged-0 1/1 Running 0 2m nebula-storaged-1 1/1 Running 0 2m nebula-storaged-2 1/1 Running 0 2m
查看集群版本:
$ kubectl get pods -l app.kubernetes.io/cluster=nebula -o jsonpath="{.items[*].spec.containers[*].image}" |tr -s '[[:space:]]' '\n' |sort |uniq -c 1 vesoft/nebula-graphd:v2.6.0 1 vesoft/nebula-metad:v2.6.0 3 vesoft/nebula-storaged:v2.6.0
最后更新: November 16, 2021