使用aws cli为EBS自动创建快照
用AWS CLI命令行来自动创建EBS的快照,这里给大家提供了一个参考示例。
-- D.C
aws cli命令创建快照
- 使用aws cli ec2命令中的create-snapshot即可。
语法: create-snapshot [--description <value>] --volume-id <value> [--dry-run | --no-dry-run] [--cli-input-json <value>] [--generate-cli-skeleton <value>]
如给EBS卷ID 为 vol-1234567890abcdef 创建快照并添加描述.
$ aws ec2 create-snapshot --volume-id vol-1234567890abcdef --description "This is my root volume snapshot."
{ "Description": "This is my root volume snapshot.", "Tags": [], "VolumeId": "vol-1234567890abcdef0", "State": "pending", "VolumeSize": 8, "StartTime": "2014-02-28T21:06:01.000Z", "OwnerId": "012345678910", "SnapshotId": "snap-066877671789bd71b" }
用脚本自动管理快照
- EBS snapshot可以直接做全量备份,因为EBS快照策略是增量备份,所以不需要删除原来的快照。
以下脚本实现对ec2实例轮询,查询到每个ec2的ebs卷,并获取到每个ec2的tag,将标签的tag打给做的快照。全量备份策略如下:
1、每周一次ebs快照,每个ebs仅保留两周(两个)快照;
2、每个快照打上标签,标签为 ec2 Name标签+卷ID+备份时间
3、每个快照描述为: 备份时间+UTC create snapshot for ec2 标签 卷 ID by awscli用户 on host: 执行命令用户@执行命令服务器名 。
4、删除已不存在卷(实例删除,卷删除)的历史自动快照,不影响手动快照。
#!/bin/bash
#create ec2 ebs snapshot per week.
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
#init awscli
#yum install -y python-pip
#pip install awscli
#aws configure
log_dir=/tmp/ec2-snapshot/
[ -d ${log_dir} ] || mkdir -p ${log_dir}
aws_user=$(aws iam get-user | awk -F\" '/UserName/{print $4}')
#获取实例id
for instance_id in $(aws ec2 describe-instances | awk -F\" '/InstanceId/{print $4}') ; do
#获取实例标签名
tag=$(aws ec2 describe-instances --instance-ids ${instance_id} | grep -C1 "\"Key\": \"Name\"" | awk -F\" '/Value/{print $4}')
#通过实例id获取该实例挂载的卷id
volumes=$(aws ec2 describe-instances --instance-ids ${instance_id} | awk -F\" '/VolumeId/{print $4}')
#通过卷id创建快照
for volume in $volumes ; do
aws ec2 create-snapshot \
--volume-id $volume \
--description "$(date +%F\ %T) UTC create snapshot for $tag $volume by $aws_user on host: $(whoami)@$(hostname)" \
&>> ${log_dir}create-snapshot-history.log
#获取快照id
snap_shotId=$(tail -11 ${log_dir}create-snapshot-history.log | awk -F\" '/SnapshotId/{print $4}')
sleep 10
#创建快照标签名字,实例标签_时期
aws ec2 create-tags --resources ${snap_shotId} --tags Key=Name,Value=${tag}_${volume}_$(date +%Y%m%d)
echo ${snap_shotId} >> ${log_dir}$volume.log
#判断每个卷的快照数,大于3个,删除超过3个的最久的快照
num_snap=$(wc -l ${log_dir}$volume.log | awk '{print $1}')
if [ ${num_snap} -gt 3 ] ;then
old_snapshotid=$(head -$[${num_snap}-3] ${log_dir}$volume.log)
for delid in ${old_snapshotid} ;do
aws ec2 delete-snapshot --snapshot-id ${delid} 2>> ${log_dir}del-snapshot-error.log
sed -i '/'"$delid"'/d' ${log_dir}$volume.log
done
fi
done
done
#删除已不存在卷的历史自动快照,不影响手动快照
#获取现有卷列表
vol_n=$(aws ec2 describe-instances | awk -F\" '/VolumeId/{print $4}')
cd ${log_dir}
for vol_log in vol-*.log ; do
#历史卷id
vol_id=${vol_log%.log}
#判断历史卷id是否在现有卷列表中,不存在则删除这个卷的所有快照
if [ "${vol_n}" == "${vol_n/${vol_id}/#}" ] ; then
while read sanp_his ; do
aws ec2 delete-snapshot --snapshot-id ${sanp_his} 2>> ${log_dir}del-snapshot-error.log
done < ${vol_log}
rm -f ${vol_log}
fi
done
- 登录ec2,或者配置过aws configure的本地服务器,运行脚本, LOOK!
学而时习之,高手在民间。