Mam dwa takie same pliki, na komputerze lokalnym i zdalnym. Ich rozmiary są równe, a plik na komputerze lokalnym jest nowszy niż na komputerze zdalnym - ale rsync nadal próbuje skopiować plik.
Wzywam rsync w następujący sposób:
rsync -nv -e "ssh -p 2222" user@host:/data/file.fif data/file.fif
(jeśli nie użyję -n
opcji, inicjuje operację kopiowania)
Dokumenty Rsync wyraźnie stwierdzają, że tak nie powinno być:
Rsync finds files that need to be transferred using a "quick check" algorithm (by default) that looks for files that have changed in size or in last-modified time.
Wyjścia z stat
:
# remote file
File: `data/fif/Skovorodko_Olga_45_raw.fif'
Size: 1137551966 Blocks: 2221784 IO Block: 4096 regular file
Device: fd00h/64768d Inode: 286338 Links: 1
Access: (0664/-rw-rw-r--) Uid: ( 1037/ platon) Gid: ( 1047/ platon)
Access: 2013-08-08 18:40:16.907581658 +0400
Modify: 2013-07-16 12:01:09.158763284 +0400
Change: 2013-07-16 12:01:09.158763284 +0400
# local file
File: `data/fif/Skovorodko_Olga_45_raw.fif'
Size: 1137551966 Blocks: 2221792 IO Block: 4096 regular file
Device: 801h/2049d Inode: 12987232 Links: 1
Access: (0644/-rw-r--r--) Uid: ( 1005/ platon) Gid: ( 1003/ platon)
Access: 2013-08-08 19:02:57.146223369 +0400
Modify: 2013-08-08 19:02:57.146223369 +0400
Change: 2013-08-08 19:02:57.146223369 +0400
Dlaczego to się dzieje?
AKTUALIZACJA:
Wykonywanie rsync --size-only
pliku wyników nie jest kopiowane:
delta-transmission enabled
Skovorodko_Olga_45_raw.fif is uptodate
total: matches=0 hash_hits=0 false_alarms=0 data=0
sent 14 bytes received 114 bytes 85.33 bytes/sec
total size is 1137551966 speedup is 8887124.73 (DRY RUN)
-t
flagi, więc nie ustawiał właściwego czasu modyfikacji nowego pliku, a kolejne wywołania rsync próbowały zaktualizować nowszy plik. Dzięki!rsync -a
chyba że masz dobry powód, aby tego nie robić.-a
w tym przypadku doprowadziłoby to do innego problemu, a mianowicie do błęduskipping directory .
Przyczyną było to, że-a
zawiera-r
i myślę, że gdyby nie było katalogów w folderze daje ten błąd. Omówiono w tym poście na blogu-a
domyślnie, a następnie jawnie wyłączyć wszelkie zawarte w nim opcje, których nie chcesz, z--no-
prefiksem. W twoim przypadku byłobyrsync -a --no-r
.