Estas são as falhas do Unison:
Ao sincronizar dois diretórios do Cygwin no Windows, ele corrompe os links simbólicos que o Cygwin usa e corrompe o conteúdo:
C:\Program Files\Unison>"Unison-2.40.102 Text.exe" c:\cygwin socket://xps:4321/c:\cygwin -path bin
UNISON 2.40.102 started propagating changes at 03:32:12.55 on 28 Feb 2013
[BGN] Updating file bin/X from C:/cygwin to //xps/C:/cygwin
$ ls -l /bin/X //xps/c/cygwin/bin/X
-rwxr-xr-x+ 1 Administrators ???????? 19 Feb 28 03:32 //xps/c/cygwin/bin/X
lrwxrwxrwx 1 Chloe None 8 Jan 28 18:35 /bin/X -> XWin.exe
$ stat /bin/X //xps/c/cygwin/bin/X
File: '/bin/X' -> 'XWin.exe'
Size: 8 Blocks: 1 IO Block: 65536 symbolic link
Device: f8e5edb8h/4175818168d Inode: 1125899907027010 Links: 1
Access: (0777/lrwxrwxrwx) Uid: ( 1006/ Chloe) Gid: ( 513/ None)
Access: 2013-01-28 18:35:38.648870400 -0500
Modify: 2013-01-28 18:35:38.648870400 -0500
Change: 2013-01-28 18:35:38.648870400 -0500
Birth: 2013-01-28 18:35:38.648870400 -0500
File: '//xps/c/cygwin/bin/X'
Size: 19 Blocks: 1 IO Block: 65536 regular file
Device: 808a8f0bh/2156564235d Inode: 4222124650737757 Links: 1
Access: (0755/-rwxr-xr-x) Uid: ( 544/Administrators) Gid: (4294967295/????????)
Access: 2013-02-28 03:32:20.619899500 -0500
Modify: 2013-02-28 03:32:20.619899500 -0500
Change: 2013-02-28 03:32:20.629884400 -0500
Birth: 2013-02-26 13:21:32.963302500 -0500
Observe a mudança no tamanho e as permissões? Na máquina de destino, ao tentar executar o comando, ele falha:
Chloe@xps /usr/bin
$ X
bash: ./X: cannot execute binary file
Eu tenho que usar o rsync para copiar os links simbólicos corretamente.
$ rsync -arvz /cygdrive/c/cygwin/bin/ //xps/c/cygwin/bin
sending incremental file list
./
X -> XWin.exe
Outra falha é que o Unison NÃO mantém os tempos modificados por padrão (no entanto, é possível usar a opção -times
para sincronizar sincronicamente os tempos de modificação do arquivo)! Se você sincronizar, os horários modificados serão definidos para o horário de criação do arquivo no destino:
$ unison 'c:\Sites' '\xps\c\Sites'
...
new file ----> ruby-env.sh
...
[BGN] Copying ruby-env.sh from c:/Sites to //xps/c/Sites
[END] Copying ruby-env.sh
$ ls -l ruby-env.sh //xps/c/sites/ruby-env.sh
----------+ 1 ???????? ???????? 188 Feb 28 02:48 //xps/c/sites/ruby-env.sh
-rw-r--r--+ 1 Chloe None 188 Feb 27 03:06 ruby-env.sh
Teoricamente, você poderia perder dados se você
- Tem dois locais de arquivos sincronizados, Location1, Location2,
- Modifique uma cópia sincronizada de um arquivo na segunda localização,
- Sincronizado com o Unison entre a primeira localização e a terceira localização,
- criou um arquivo no terceiro destino com uma data de modificação mais recente devido ao Unison,
- usou uma ferramenta de sincronização diferente, como rsync ou SyncToy,
- em seguida, sincronizou o terceiro destino novamente com o segundo local, que na verdade foi modificado depois da primeira origem, mas antes do terceiro horário de criação do arquivo de destino,
- A outra ferramenta de sincronização notará que a 3ª hora da localização é mais recente e substitui as alterações na 2ª localização,
- Por meio da perda de dados.