首页 > 其他 > 详细

Bash:- 用脚本模拟自动实现轮询效果?

时间:2017-12-09 17:27:37      阅读:222      评论:0      收藏:0      [点我收藏+]

【应用场景】

假如一共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

 

Bash:- 用脚本模拟自动实现轮询效果?

原文:http://www.cnblogs.com/ithandonglin/p/8012026.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!