标签:ssi 集中 结果 oca 备份 bsp 个数 == 1.2
【应用场景】
假如一共10个数据库需要备份,但不想集中在一台机进行,一共有5台主机,想分别平摊备份任务,如何实现?
【解决思路】
1、将这10个数据库组成数组 ARRAY=(data1 data2 data3 data4 data5 data6 data7 data8 data9 data10)
2、将这5台机打标签如下:
1|192.168.1.1
2|192.168.1.2
3|192.168.1.3
4|192.168.1.4
5|192.168.1.5
组成数组 SessionList=(1|192.168.1.1 2|192.168.1.2 3|192.168.1.3 4|192.168.1.4 5|192.168.1.5)
将数据库数组循环,flag=0 每循环一次 let flag=flag+1,当满足以下条件时:
$((${flag}%${#SessionList[@]}))取余,再加上1的时候,就可以将结果与5台机的标签联系起来,达到获取IP的效果,代码如下:
ARRAY=(data1 data2 ... data10) SessionList=(1|192.168.1.1 ... 5|192.168.1.5) local flag=0 for i in ${ARRAY[@]};do let flag=flag+1 for j in ${SessionList[@]};do PRE=$(echo ${j} | awk -F "|" ‘{print $1)‘) SUF=$(echo ${j} | awk -F "|" ‘{print $2)‘) REST=`expr $((${flag}%${#SessionList[@]})) + 1` [[ ${REST} == ${PRE} ]] && { HOST=${SUF};break: } done echo ${HOST} done
标签:ssi 集中 结果 oca 备份 bsp 个数 == 1.2
原文地址:http://www.cnblogs.com/ithandonglin/p/8012026.html