K8s中 备份数据 检查验证(三)--Redis备份验证

检查名为s1plat的Redis数据库。检查Redis中key数量的变化来判断备份数据是否异常。

现行k8s中的Redis状况检查;

status-redis-s1plat.sh

#!/bin/bash


rundir=$(cd $(dirname $0); pwd)
theday=`date +%F`

if [ ! -d "${rundir}/log" ]; then
        mkdir ${rundir}/log
fi


if [ "$*" ];then
        arg=$*
else
        arg="redis-0"
fi

echo -e "当前 s1plat-Redis 数据库的 key 的数量:" > ${rundir}/log/redis-s1plat-status-${theday}.txt

#kubectl exec -it s1plat-redis-0 -n s1plat redis-cli -- -a xxx --raw dbsize
kubectl exec -it s1plat-redis-0 -n s1plat redis-cli -- -a 访问密码 --raw dbsize \
>> ${rundir}/log/redis-s1plat-status-${theday}.txt 2>&1

#sed -n '$p' ${rundir}/log/redis-status-${theday}.txt
sed -i '/Defaulting/d' ${rundir}/log/redis-s1plat-status-${theday}.txt
sed -i '/Use/d' ${rundir}/log/redis-s1plat-status-${theday}.txt

cat ${rundir}/log/redis-s1plat-status-${theday}.txt

运行

验证Redis数据;

redis-check-s1plat.sh

#!/bin/bash

rundir=$(cd $(dirname $0); pwd)
theday=`date +%F`

echo -e "=======${theday} s1plat-Redis备份验证======="

#清除上次验证数据
dbtmpdir="${rundir}/dbtmp/redis"
rm -rf ${dbtmpdir} && mkdir ${dbtmpdir} -p

#如果没有参数则搜索当前运行目录下的
if [ "$1" ];then
        baktar=$1
else
        baktar=$(find ${rundir} -name "*s1plat*redis.tar" | sort -rn | head -1)
fi
if [ ! -e "${baktar}" ];then
        echo "没有找到备份*redis.tar!!!"
        exit 0
fi
echo -e "1.Redis备份文件是:\n ${baktar}"

echo -e "2.还原数据库的临时目录:\n ${dbtmpdir}"

echo -e "3.还原数据"
cp -rf ${baktar} ${dbtmpdir}/redis.tar
cd ${dbtmpdir}
tar -xvzf ${dbtmpdir}/redis.tar >> /dev/null 2>&1
echo -e " 还原的数据库:${dbtmpdir}/data"

#echo -e "\n======================================" >> ${rundir}/log/redis-check.txt
echo -e "=======${theday} s1plat-redis备份验证=======" >> ${rundir}/log/redis-check.txt
#echo -e "======================================" >> ${rundir}/log/redis-check.txt
echo -e "备份文件为:${baktar}" >> ${rundir}/log/redis-check.txt
echo -e "查询备份数据库的 key 的数量:" >> ${rundir}/log/redis-check.txt

echo -e "4.检验数据"

docker run --name redis-check -d -v ${dbtmpdir}/data:/data redis:3.2 redis-server \
>> /dev/null 2>&1

echo -e "等待redis服务启动完成,10秒..."
sleep 10;

docker exec -it redis-check redis-cli -c 'dbsize' \
>> ${rundir}/log/redis-check.txt

docker stop redis-check >> /dev/null 2>&1
docker rm redis-check >> /dev/null 2>&1

#sed -i 's///g' ${rundir}/log/etcd-check.txt
#sed -i '/^$/d' ${rundir}/log/etcd-check.txt

#cat ${rundir}/log/etcd-check.txt | tr -s "\n" > ${rundir}/log/etcd-check.txt

tail -n 4 ${rundir}/log/redis-check.txt
echo -e "验证结果输出:${rundir}/log/redis-check.txt"


运行

^C[root@k8smaster 2]# kubectl -n redis-server get pods -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES redis-master-966f8c49b-cfk65 0/1 Running 2 5m1s 10.244.0.13 k8smaster <none> <none> redis-slave1-547f7f4df5-7llz8 0/1 Running 2 5m1s 10.244.1.44 k8snode1 <none> <none> redis-slave2-88d55ddb9-n2mlj 0/1 Running 0 5m1s 10.244.2.26 k8snode2 <none> <none> [root@k8smaster 2]# kubectl -n redis-server get pv,pvc NAME CAPACITY ACCESS MODES RECLAIM POLICY STATUS CLAIM STORAGECLASS REASON AGE persistentvolume/mysql-master-pv 10Gi RWO Retain Bound mysql-server/mysql-master-pvc 3h7m persistentvolume/mysql-slave1-pv 10Gi RWO Retain Bound mysql-server/mysql-slave1-pvc 3h7m persistentvolume/mysql-slave2-pv 10Gi RWO Retain Bound mysql-server/mysql-slave2-pvc 3h7m persistentvolume/redis-master-pv 1Gi RWO Retain Bound redis-server/redis-master-pvc 5m13s persistentvolume/redis-slave1-pv 1Gi RWO Retain Bound redis-server/redis-slave1-pvc 5m13s persistentvolume/redis-slave2-pv 1Gi RWO Retain Bound redis-server/redis-slave2-pvc 5m13s NAME STATUS VOLUME CAPACITY ACCESS MODES STORAGECLASS AGE persistentvolumeclaim/redis-master-pvc Bound redis-master-pv 1Gi RWO 5m13s persistentvolumeclaim/redis-slave1-pvc Bound redis-slave1-pv 1Gi RWO 5m13s persistentvolumeclaim/redis-slave2-pvc Bound redis-slave2-pv 1Gi RWO 5m13s [root@k8smaster 2]# kubectl -n redis-server exec -it redis-master-7d5f8d5f76-2xq4z -- redis-cli -a redispass Error from server (NotFound): pods "redis-master-7d5f8d5f76-2xq4z" not found [root@k8smaster 2]# kubectl -n redis-server exec -it redis-master-966f8c49b-cfk65 -- redis-cli -a redispass Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe. AUTH failed: ERR AUTH <password> called without any password configured for the default user. Are you sure your configuration is correct? 127.0.0.1:6379> SET testkey "hello redis" OK 127.0.0.1:6379> exit [root@k8smaster 2]# kubectl -n redis-server exec -it redis-slave1-547f7f4df5-7llz8 -- redis-cli -a redispass GET testkey Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe. Could not connect to Redis at 127.0.0.1:6379: Connection refused command terminated with exit code 1
最新发布
10-15
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值