Solía cp -up --backup=t
copiar archivos desde mi computadora a la nube y revertirlos, pero a veces la fecha cambia durante unos minutos (o supongo que incluso segundos, ya que veo la misma marca de fecha del archivo) mientras comparo el archivo copiado y el de respaldo. Comparando el número de hash md5 de ambos archivos, son iguales. Entonces mi pregunta es si es posible para cada archivo, que en caso de que la fecha del archivo a copiar sea más reciente que la fecha del archivo en el destino, verifique primero si el número de hash md5 es diferente, antes de realizar la copia, y si ambos tienen el mismo número, no copiar el archivo.
Respuesta1
Úselo rsync
con la -c
bandera ( --checksum
), que compara archivos por suma de verificación en lugar de por tiempo y tamaño de modificación.
Ejemplo
root@node51 [/tmp]# mkdir source
root@node51 [/tmp]# mkdir destination
root@node51 [/tmp]# echo "version 1" > source/file.txt
root@node51 [/tmp]# sleep 1
root@node51 [/tmp]# echo "version 1" > destination/file.txt
Observe que creé dos archivos idénticos en dos momentos diferentes, pero sus sumas de verificación son idénticas:
root@node51 [/tmp]# md5sum */file.txt
81127ad129dd2249f5ab0667ca0aeb84 destination/file.txt
81127ad129dd2249f5ab0667ca0aeb84 source/file.txt
root@node51 [/tmp]# stat */file.txt
File: 'destination/file.txt'
Size: 10 Blocks: 1 IO Block: 512 regular file
Device: 15h/21d Inode: 674358 Links: 1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2016-08-10 13:14:12.710354355 -0500
Modify: 2016-08-10 13:14:12.710354355 -0500
Change: 2016-08-10 13:14:12.710354355 -0500
Birth: -
File: 'source/file.txt'
Size: 10 Blocks: 1 IO Block: 512 regular file
Device: 15h/21d Inode: 674234 Links: 1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2016-08-10 13:14:07.198447196 -0500
Modify: 2016-08-10 13:14:07.198447196 -0500
Change: 2016-08-10 13:14:07.198447196 -0500
Birth: -
Usando rsync -avcP
:
root@node51 [/tmp]# touch source/file.txt
root@node51 [/tmp]# rsync -avcP source/ destination/
sending incremental file list
./
sent 87 bytes received 22 bytes 218.00 bytes/sec
total size is 10 speedup is 0.09
El archivo no fue copiado.
Una ejecución diferente, usando rsync -avP
:
root@node51 [/tmp]# touch source/file.txt
root@node51 [/tmp]# rsync -avP source/ destination/
sending incremental file list
file.txt
10 100% 0.00kB/s 0:00:00 (xfr#1, to-chk=0/2)
sent 123 bytes received 35 bytes 316.00 bytes/sec
total size is 10 speedup is 0.06
El archivo fue copiado.