起因:由于两地公司服务器互为备份,目录结构,文件应当一样,先发现部分目录数据不一致。查出不一致目录
思路:将每层目录取出做统一处理,得到所有目录之后,统计目录下文件个数并输出到文件,将比对的两个文件目录的文件去除收个目录结构,数据对比,删除一致数据,返回一个不一致文件,并将文件重命名为目录结构文件
处理方案(代码如下)
#!/bin/bash
rm -rf /mnt/1.txt /mnt/2.txt /mnt/3.txt /mnt/4.txt /mnt/5.txt /mnt/6.txt #删除上次数据
read -p "your contents1: " content1 #读取目录
ls -lR $content1 | grep / |awk -F : '{print $1}' > /mnt/1.txt #所有将目录的输出
read -p "your contents2: " content2 #读取比对目录
ls -lR $content2 | grep / |awk -F : '{print $1}' > /mnt/2.txt
for i in `cat /mnt/1.txt` #统计每层目录下的个数
do
echo $i'#'`ls -l $i/ | wc -l` >> 3.txt
done
for i in `cat /mnt/2.txt`
do
echo $i'#'`ls -l $i/ | wc -l` >> 4.txt
done
sed -i "s#/#;#g" /mnt/3.txt #替换/为;
sed -i "s#/#;#g" /mnt/4.txt
awk -F ';hds' '{print $2}' /mnt/4.txt >> /mnt/5.txt #按初级目录做分隔
awk -F ';adba' '{print $2}' /mnt/3.txt >> /mnt/6.txt
for i in `cat /mnt/5.txt` #数据比对
do
for y in `cat /mnt/6.txt`
do
if [ $i == $y ];then
sed -i "/$i/d" /mnt/6.txt
fi
done
done
sed -i 's#;#/#g' /mnt/6.txt #将;切回/以便观察
sed -i s#^#/adba#g /mnt/6.txt #加回初级目录
mv /mnt/6.txt `echo $content1 | awk -F / '{print $2"_"$3"_"$4"_"$5"_"$6"_"$7"_"$8 }'` #更改文件为目录层级文件