起因:由于两地公司服务器互为备份,目录结构,文件应当一样,先发现部分目录数据不一致。查出不一致目录

思路:将每层目录取出做统一处理,得到所有目录之后,统计目录下文件个数并输出到文件,将比对的两个文件目录的文件去除收个目录结构,数据对比,删除一致数据,返回一个不一致文件,并将文件重命名为目录结构文件

处理方案(代码如下)

#!/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 }'`                                                                                       #更改文件为目录层级文件

linux目录比对_第1张图片