白森 发表于 2019-2-18 08:14:25

linux目录比对

  起因:由于两地公司服务器互为备份,目录结构,文件应当一样,先发现部分目录数据不一致。查出不一致目录
  思路:将每层目录取出做统一处理,得到所有目录之后,统计目录下文件个数并输出到文件,将比对的两个文件目录的文件去除收个目录结构,数据对比,删除一致数据,返回一个不一致文件,并将文件重命名为目录结构文件
  处理方案(代码如下)
  #!/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 }'`                                                                                       #更改文件为目录层级文件
http://s1.运维网.com/images/20180511/1526014655213067.png



页: [1]
查看完整版本: linux目录比对