Dies sind die Mängel von Unison:
Wenn Sie zwei Cygwin-Verzeichnisse unter Windows synchronisieren, werden die symbolischen Links, die Cygwin verwendet, und der Inhalt beschädigt:
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
Beachten Sie die Größenänderung und die Berechtigungen? Wenn auf dem Zielcomputer versucht wird, den Befehl auszuführen, schlägt der Befehl fehl:
Chloe@xps /usr/bin $ X bash: ./X: cannot execute binary file
Ich muss rsync verwenden, um die symbolischen Links korrekt zu kopieren.
$ rsync -arvz /cygdrive/c/cygwin/bin/ //xps/c/cygwin/bin sending incremental file list ./ X -> XWin.exe
Ein weiterer Fehler ist, dass Unison die geänderten Zeiten NICHT standardmäßig beibehält (es ist jedoch möglich, die -times
Option zu verwenden, um Änderungszeiten für unisonale Synchronisierung von Dateien festzulegen)! Wenn Sie synchronisieren, werden die geänderten Zeiten auf die Dateierstellungszeit am Ziel festgelegt:
$ 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
Theoretisch könnten Sie möglicherweise Daten verlieren, wenn Sie
- 2 synchronisierte Dateispeicherorte haben, Location1, Location2,
- Eine synchronisierte Kopie einer Datei am zweiten Speicherort ändern,
- Mit Unison zwischen dem 1. und dem 3. Standort synchronisiert,
- am dritten Ziel eine Datei mit einem neueren Änderungsdatum aufgrund von Unison erstellt,
- ein anderes Sync-Tool wie rsync oder SyncToy verwendet,
- dann das 3. Ziel erneut mit dem 2. Ort synchronisiert, der tatsächlich später als die 1. Quelle geändert wurde, jedoch vor dem Zeitpunkt der Erstellung der 3. Zieldatei,
- Das andere Synchronisierungstool stellt fest, dass der Zeitpunkt für den dritten Ort neuer ist, und überschreibt die Änderungen am zweiten Ort.
- Dabei Daten verlieren.