1. 程式人生 > >linux目錄比對

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 }'` #更改文件為目錄層級文件

技術分享圖片

linux目錄比對