Jenkins 的高可用性方案¶
由于 Jenkins 本身的架构设计并不支持多节点的方式,因此不支持以横向扩展的方式来实现高可用。 依赖于 K8s 的故障转移机制,当 Jenkins Pod 发生故障时,可以通过 K8s 的调度机制将 Pod 调度到其他节点上,从而实现高可用。 因此 Jenkins 的高可用主要考虑得是数据存储层的高可用。
在 DCE 5.0 中,通过使用 HwameiStor 的存储层来实现 Jenkins 的高可用。 HwameiStor 支持使用 DRBD 的方式,可以将一份数据副本同时挂载到多个节点上。 当 Jenkins 所在节点宕机时,通过 K8s 的调度,可以将 Pod 调度到其他节点上,此时 Pod 依旧可以继续使用之前的数据,以此来实现高可用。
Tip
HwameiStor 基于 DRBD 方案实现了存储层的高可用,因此理论上只需要 CSI 能支持 DRBD 都能实现高可用,如 Linstor 等。
下面将介绍如何基于 HwameiStor 来实现 Jenkins 的高可用。
前置条件¶
- 安装 HwameiStor 请参阅 https://hwameistor.io/cn/docs/intro。 因为高可用至少需要两个节点,因此 node 数量至少为 2 个。
- 确保系统中有空闲的、干净的磁盘(磁盘中无数据,无分区信息),否则无法被 HwameiStor 使用。
可以通过
kubectl get ld
命令来查看系统中的磁盘信息。
安装步骤¶
-
确认有空闲的磁盘
输出类似于:
状态为 Available 为新加的硬盘,当添加完硬盘之后就能查到。
-
确认磁盘类型
输出类似于:
注意区分是 HDD 还是 SSD。
-
创建 LocalDiskClaim,将磁盘加入到 HwameiStor 的管理中。
> kubectl apply -f - <<EOF apiVersion: hwameistor.io/v1alpha1 kind: LocalDiskClaim metadata: name: controller-node-1 # 改为当前节点的名称 spec: nodeName: controller-node-1 # 改为当前节点的名称 (kubectl get node) owner: local-storage # owner 与 disk 类型是不同的,只有 lvm 类型的才支持 HA 和扩容。注意区分 lvm 和 disk 类型 description: diskType: HDD # 改为当前节点的磁盘类型 EOF
-
验证是否加入成功。
输出类似于:
apiVersion: hwameistor.io/v1alpha1 kind: LocalStorageNode metadata: name: controller-node-1 spec: hostname: controller-node-1 storageIP: 172.30.47.32 topogoly: region: default zone: default status: conditions: - lastTransitionTime: "2023-09-11T06:33:57Z" lastUpdateTime: "2023-09-11T06:33:57Z" message: Successfully to expand storage capacity reason: StorageExpandSuccess status: "True" type: ExpandSuccess poolExtendRecords: LocalStorage_PoolHDD: - description: diskType: HDD diskRefs: - apiVersion: hwameistor.io/v1alpha1 kind: LocalDisk name: localdisk-6285c10750cc3495c59e4cadf275621b resourceVersion: "24961890" uid: 3406c479-f4d9-4a94-8d84-69dd6f10f8d3 nodeName: controller-node-1 owner: local-storage pools: # (1) LocalStorage_PoolHDD: class: HDD disks: - capacityBytes: 42945478656 devPath: /dev/sdc state: InUse type: HDD freeCapacityBytes: 38650511360 freeVolumeCount: 999 name: LocalStorage_PoolHDD totalCapacityBytes: 42945478656 totalVolumeCount: 1000 type: REGULAR usedCapacityBytes: 4294967296 usedVolumeCount: 1 volumeCapacityBytesLimit: 42945478656 volumes: - pvc-26a63717-8b53-4c37-ad99-6d4394288192 state: Ready
- 出现以下内容代表加入成功
-
修改 Jenkins 的 storageClass
- 通过界面的方式安装的 Jenkins,可以在安装时设置 storageClass(存储类 hwameistor-storage-lvm-hdd-ha 。
- 通过 helm 安装时,可以设置 helm value.yaml 中的 storageClassName 改为 hwameistor-storage-lvm-hdd-ha 。
Note
- 在安装之前确认 storageClass 是否存在,可以通过
kubectl get sc
查看。 - 一般情况下在安装了 HwameiStor 之后,会自动创建 hwameistor-storage-lvm-hdd-ha 这个 storageClass。如果没有,请联系管理员。
- 根据添加的磁盘类型,也有可能是 hwameistor-storage-lvm-ssd-ha 。只需要指定为 ha 类型的 storageClass 即可。
部署完 Jenkins 后即可实现 Jenkins 的高可用功能。
Caution
不支持已有数据的 Jenkins 直接转为高可用模式,需要重新安装 Jenkins,请注意备份数据。