k8s备份namespace

发布于:2025-05-19 ⋅ 阅读:(25) ⋅ 点赞:(0)

在 Kubernetes 中备份 Namespace 有多种方法,以下是几种常见的备份方式:
1.使用 kubectl 命令备份
通过 kubectl 命令可以导出指定 Namespace 中的资源,生成 YAML 文件进行备份。
备份所有资源:

kubectl -n <namespace> get all -o yaml > <namespace>-backup.yaml

备份特定资源:
部署类资源:

kubectl get deployments,statefulsets,daemonsets,replicationcontrollers,replicasets --namespace=<namespace> -o yaml > deployments.yaml

服务类资源:

kubectl get services --namespace=<namespace> -o yaml > services.yaml

配置类资源:

kubectl get configmap,secret --namespace=<namespace> -o yaml > configmaps-secrets.yaml

存储类资源:

kubectl get pv,pvc --namespace=<namespace> -o yaml > pv-pvc.yaml

其他资源:

kubectl get ingress --namespace=<namespace> -o yaml > ingresses.yaml
kubectl get jobs,cronjobs --namespace=<namespace> -o yaml > jobs-cronjobs.yaml
kubectl get serviceaccounts,roles,rolebindings,clusterroles,clusterrolebindings --namespace=<namespace> -o yaml > rbac.yaml

使用 kubectl-neat 插件备份
kubectl-neat 是一个插件,可以导出更干净的配置文件。
安装插件:

kubectl krew install neat

导出配置:

NAMESPACE="<namespace-name>"
OUTPUT_DIR="k8s-export-clean-$NAMESPACE"
mkdir -p $OUTPUT_DIR

RESOURCE_TYPES=$(kubectl api-resources --namespaced=true --verbs=list -o name | sort | uniq)

for RESOURCE in $RESOURCE_TYPES; do
  echo "Exporting $RESOURCE..."
  kubectl get -n $NAMESPACE $RESOURCE -o yaml | kubectl neat > "$OUTPUT_DIR/$RESOURCE.yaml" 2>/dev/null
done

3.使用 Velero 备份
Velero 是一个专门用于 Kubernetes 集群备份和恢复的工具,支持将备份数据存储到对象存储中。
安装 Velero:

velero install \
  --provider <provider> \
  --bucket <bucket-name> \
  --secret-file <path-to-credentials-file> \
  --use-volume-snapshots=false \
  --namespace velero \
  --wait

创建备份:

velero backup create <backup-name> --include-namespaces <namespace>

下载备份(如果需要):

velero backup download <backup-name>

4.使用自定义脚本备份
可以编写一个 Bash 脚本来自动化备份过程。

#!/bin/bash

if [ -z "$1" ]; then
  echo "Please provide a namespace name"
  echo "Usage: $0 <Namespace>"
  exit 1
fi

NAMESPACE=$1
BACKUP_DIR="k8s_backup_${NAMESPACE}_$(date +%Y%m%d_%H%M%S)"
mkdir -p $BACKUP_DIR

RESOURCES=(
  "configmap"
  "secret"
  "deployment"
  "statefulset"
  "daemonset"
  "service"
  "ingress"
  "pvc"
  "job"
  "cronjob"
  "serviceaccount"
  "role"
  "rolebinding"
)

for RESOURCE in "${RESOURCES[@]}"; do
  echo "Backing up $RESOURCE..."
  kubectl get $RESOURCE --namespace=$NAMESPACE -o yaml > $BACKUP_DIR/$RESOURCE.yaml
done

使用 kustomize 备份
如果使用 kustomize 进行配置管理,也可以通过 kustomize 导出 Namespace 的定义。
导出命名空间定义:

cat <<EOF > kustomization.yaml
namespace: <namespace-name>
resources:
- namespace.yaml
EOF

kubectl get namespace <namespace-name> -o yaml > namespace.yaml

kubectl kustomize . > namespace-kustomize.yaml

网站公告

今日签到

点亮在社区的每一天
去签到