BackupPolicy
配置加密密钥
为了确保恢复的集群能够正常访问,KubeBlocks 在备份集群时会将集群的连接密码加密,并将其安全地存储在 Backup 对象的 Annotation 中。因此,为了保障您的数据安全,强烈建议谨慎分配备份对象的 Get/List 权限,并在安装或升级 KubeBlocks 时,务必指定加密密钥。这些措施将有助于确保你的数据得到妥善保护。
KubeBlocks v0.9.0 版本集成了 datasafed 的数据加密功能,目前已支持 AES-128-CFB
、AES-192-CFB
和 AES-256-CFB
等加密算法。在写入存储之前,备份数据会被加密。您的加密密钥不仅可以用于加密连接密码,还可以备份数据。用户可以根据实际需要,直接引用已有的 secret 对象,或给数据库集群创建不同的密钥,从而进行备份加密。
引用已有的 key
如果 Secret 对象已存在,您可以选择直接引用,而无需设置 dataProtection.encryptionKey
。KubeBlocks 提供了快速引用已有 encryptionKey
进行加密的方式。
举个例子,如果已经有一个名为 dp-encryption-key
的 Secret,其中包含一个名为 encryptionKey
的密钥。例如,通过以下命令创建了一个密钥:
kubectl create secret generic dp-encryption-key \
--from-literal=encryptionKey='S!B\*d$zDsb='
您可以在安装或升级 KubeBlocks 时引用该密钥。
- kbcli
- kubectl
kbcli kubeblocks install \
--set dataProtection.encryptionKeySecretKeyRef.name="dp-encryption-key" \
--set dataProtection.encryptionKeySecretKeyRef.key="encryptionKey"
# The above command is equivalent to:
# kbcli kubeblocks install --set dataProtection.encryptionKey='S!B\*d$zDsb='
helm install kubeblocks kubeblocks/kubeblocks --namespace kb-system --create-namespace --set dataProtection.encryptionKeySecretKeyRef.name="dp-encryption-key" \
--set dataProtection.encryptionKeySecretKeyRef.key="encryptionKey"
创建新的 key
如果无需默认开启备份加密,或者需要使用独立的 encryptionKey,您可以按照以下步骤创建一个 Secret 对象,手动开启备份加密。
-
创建 Secret,存储加密密钥。
kubectl create secret generic backup-encryption \
--from-literal=secretKey='your secret key' -
修改 BackupPolicy,开启备份加密。
在这里需要引用之前创建的密钥:
kubectl --type merge patch backuppolicy mysqlcluster-mysql-backup-policy \
-p '{"spec":{"encryptionConfig":{"algorithm":"AES-256-CFB","passPhraseSecretKeyRef":{"name":"backup-encryption","key":"secretKey"}}}}'
您也可以使用 kbcli
创建,操作更简单。
# 启用加密
kbcli cluster edit-backup-policy <backup-policy-name> --set encryption.algorithm=AES-256-CFB --set encryption.passPhrase="SECRET!"
# 禁用加密
kbcli cluster edit-backup-policy <backup-policy-name> --set encryption.disabled=true
配置完成。然后就可以照常执行备份和恢复操作了。
请不要修改或删除在第一步创建的 Secret,否则将来可能无法解密备份。
默认情况下,encryptionKey
仅用于加密连接密码。如果您想用它加密备份数据,请在上述命令中添加 --set dataProtection.enableBackupEncryption=true
。然后,所有新建的 DB cluster 都会默认开启备份加密。
创建集群
创建测试集群,用于后续备份教程使用。
# 创建 MySQL 集群
kbcli cluster create mysql mysql-cluster
# 查看 backupPolicy
kbcli cluster list-backup-policy mysql-cluster
>
NAME DEFAULT CLUSTER CREATE-TIME STATUS
mysql-cluster-mysql-backup-policy true mysql-cluster May 23,2023 19:53 UTC+0800 Available
mysql-cluster-mysql-backup-policy-hscale false mysql-cluster May 23,2023 19:53 UTC+0800 Available
如无特殊设置,所有备份都会保存在全局默认仓库中,可以执行如下命令查看所有 BackupRepo,其中 DEFAULT
字段为 true
,表示该 BackupRepo 为默认 BackupRepo。
# 查看 BackupRepo
kbcli backuprepo list
查看 BackupPolicy
使用 KubeBlocks 创建数据库集群后,对于支持备份的数据库,会自动为其创建一个备份策略(BackupPolicy),可以执行如下命令查看集群的备份策略:
- kbcli
- kubectl
kbcli cluster list-backup-policy mysql-cluster
>
NAME NAMESPACE DEFAULT CLUSTER CREATE-TIME STATUS
mysql-cluster-mysql-backup-policy default true mysql-cluster Oct 30,2023 14:34 UTC+0800 Available
mysql-cluster-mysql-backup-policy-hscale default false mysql-cluster Oct 30,2023 14:34 UTC+0800 Available
kubectl get backuppolicy | grep mycluster
>
mycluster-mysql-backup-policy Available 35m
mycluster-mysql-backup-policy-hscale Available 35m
备份策略中包含了该集群支持的备份方法,执行以下命令进行查看备份方法:
- kbcli
- kubectl
kbcli cluster describe-backup-policy mysql-cluster
>
kbcli cluster describe-backup-policy mysql-cluster
Summary:
Name: mysql-cluster-mysql-backup-policy
Cluster: mysql-cluster
Namespace: default
Default: true
Backup Methods:
NAME ACTIONSET SNAPSHOT-VOLUMES
xtrabackup xtrabackup-for-apecloud-mysql false
volume-snapshot volumesnapshot-for-apecloud-mysql true
kubectl get backuppolicy mycluster-mysql-backup-policy -o yaml
对于 MySQL 集群而言,默认支持两种备份方法:xtrabackup
和 volume-snapshot
,前者使用备份工具 xtrabackup
将 MySQL 数据备份至对象存储中;后者则使用云存储的卷快照能力,通过快照方式对数据进行备份。创建备份时,可以指定要使用哪种备份方法进行备份。