Esiste uno strumento Linux come diff che confronterà in modo ricorsivo file e directory, ma con l'aggiunta del confronto: attributi estesi, acl, se contesti?
Esiste uno strumento Linux come diff che confronterà in modo ricorsivo file e directory, ma con l'aggiunta del confronto: attributi estesi, acl, se contesti?
Risposte:
L'ho fatto prima di usare il rsync -aHAX --delete
ricordare di aggiungere i flag -n
e -i
.
Questo è leggermente controintuitivo, ma abbi pazienza. Il rsync
comando principale è quello di cui avresti bisogno per sincronizzare le due directory insieme. Ma -n -i
fa sì che NON si sincronizzi (cioè esegua una corsa a secco) e semplicemente stampi cosa avrebbe fatto e perché. Non è fantastico analizzarlo, ma è possibile estrarre facilmente il nome file e reindirizzare ls
o simili.
Questo esaminerà tutto, compresi mtime, date ecc., Oltre a non seguire su nodi dispositivo, socket, named pipe ecc. La riga di comando sopra esamina ACL e anche attributi estesi. È possibile regolare ciò che si sta visualizzando modificando le opzioni in rsync
, limitandolo a un dispositivo con -x
, modificando il comportamento dei collegamenti soft e hard ecc. Ecc.
Janos ha già detto cosa fare:
find /a -exec stat -c '%A %C %F %g %u %s %Y %n' {} \; >a
find /b -exec stat -c '%A %C %F %g %u %s %Y %n' {} \; >b
diff -u a b
E man 1 stat
dice:
%A access rights in human readable form
%C SELinux security context string
%F file type
%g group ID of owner
%u user ID of owner
%s total size, in bytes
%Y time of last modification, seconds since Epoch
%n file name
Per confrontare il contenuto del file è possibile utilizzare:
find -type f -exec md5sum '{}' ';' | sort | uniq --all-repeated=separate -w 33 | cut -c 35-
as described here: http://www.commandlinefu.com/commands/view/3555/find-duplicate-files-based-on-size-first-then-md5-hash
find
ha le funzionalità di GNU stat
integrate (e precede le statistiche GNU di decenni). Ti consigliamo anche di ordinare l'output prima di diffing. E in caso (cd /a && find . ...)
contrario è necessario che tutte le righe differiscano a causa di /a
vs /b
nel percorso del file.
Ecco un breve script bash che ho scritto per confrontare gli attributi estesi. Stampa ogni nome di file e quindi eventuali differenze negli attributi:
cd a
export relpath=[path/to/b/from/a]
for filename in $(find .);
do
echo $filename;
diff <(xattr -l $filename) <(xattr -l $relpath/$filename);
done
Prendendo in prestito da un'altra risposta, possiamo modificarlo per usarlo al stat
posto di xattr
:
for filename in $(find .);
do
echo $filename;
diff <(stat -c '%A %C %F %g %u %s %Y' $filename) <(stat -c '%A %C %F %g %u %s %Y' $relpath/$filename);
done