Kopieren in ein NTFS-Dateisystem auf einem Remote-Computer bei gleichzeitiger Verwendung von Metadaten
535
Lemming
Ich möchte eine Reihe von Dateien auf eine NTFS-Partition auf einem Remote-Computer kopieren, während die Dateidaten vorbelegt werden. Das Beibehalten von Metadaten auf einer lokalen Kopie ist auf einem NTFS-Dateisystem bereits schwierig:
$ cp -p testfile /windows/c/ cp: die Zeiten für '/windows/c/testfile' werden beibehalten: Vorgang nicht zulässig
(Übersetzt: "Zeiten bewahren ist nicht zulässig")
Es funktioniert nur beim Kopieren als root:
$ sudo cp -p testfile /windows/c/
Das ist schon seltsam, aber ich kenne bisher keine bessere Lösung.
Aber wie kopiere ich auf einen entfernten Rechner? Ich möchte zu tun:
$ scp -p testdir root@remote:/windows/c/
Die Remote-Maschine hat jedoch nur "sudo", keinen Kennwortzugriff für "root". Ich möchte es so lassen. Ich könnte:
$ tar testdir | ssh remote sudo tar x --directory=/windows/c
Ich kann das Sudo-Passwort jedoch nicht auf diese Weise eingeben. Ich habe es auch versucht
aber auf dem entfernten Rechner passiert nichts. Vielleicht unterstützt sshfs keine FIFOs? Ich habe keine Ahnung mehr.
2 Antworten auf die Frage
1
Lemming
Der Pipe-Trick scheint lokal auf dem Remote-Computer zu funktionieren. SSHFS scheint der Blocker zu sein. Ohne SSHFS habe ich einen funktionierenden Weg gefunden:
remote$ mkfifo /tmp/channel.tar remote$ sudo tar xf /tmp/channel.tar --directory=/windows/c $ tar c testdir | ssh remote dd of=/tmp/channel.tar
0
user2629074
Die Verwendung von tar als Container zum Speichern der Dateiinformationen ist eine gute Idee.
Wenn Kennwörter keine Option sind, können Sie dem Root-Konto auf dem Remote-Computer immer einen ssh-Schlüssel hinzufügen und eine zertifikatbasierte Authentifizierung durchführen.