Usando md5sum e data para atualizar arquivos com cp

Usando md5sum e data para atualizar arquivos com cp

Eu costumo cp -up --backup=tcopiar arquivos do meu computador para a nuvem e reverter, mas às vezes a data muda por alguns minutos (ou acho que até segundos, pois vejo o mesmo carimbo de data do arquivo) enquanto comparo o arquivo copiado e o de backup. Comparando o número de hash md5 de ambos os arquivos, eles são iguais. Então minha dúvida é se é possível para cada arquivo, que caso a data do arquivo a ser copiado seja mais recente que a data do arquivo no destino, verifique primeiro se o número do hash md5 é diferente, antes de fazer a cópia, e se ambos tiverem o mesmo número, não copie o arquivo.

Responder1

Use rsynccom o -csinalizador ( --checksum), que compara arquivos por soma de verificação em vez de por hora e tamanho de modificação.

Exemplo

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 criei dois arquivos idênticos em dois momentos diferentes, mas suas somas de verificação são 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

O arquivo não foi copiado.

Uma execução 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

O arquivo foi copiado.

informação relacionada