Quiq::Rsync - Aufruf von rsync von Perl aus
Quiq::Object
use Quiq::Rsync; # /src/dir => /dest/dir (gleicher Verzeichnisname) Quiq::Rsync->exec('/src/dir','/dest'); Quiq::Rsync->exec('/src/dir/','/dest/dir'); # /src/dir1 => /dest/dir2 (unterschiedlicher Verzeichnisname) Quiq::Rsync->exec('/src/dir1/','/dest/dir2'); # Änderungen anzeigen, aber nicht durchführen Quiq::Rsync->exec($src,$dest,-dryRun=>1);
Führe rsync(1) unter Kontrolle von Perl aus. Die Klasse stützt sich auf die Klasse File::Rsync ab und stellt gegenüber dieser eine spezialisierte, einfachere Schnittstelle zur Verfügung. Eigenschaften:
der Aufruf von exec() ohne Optionen entspricht der "Standard-Nutzung" von rsync
im Fehlerfall wird eine Exception geworfen
eine Ausgabe findet nur im Fehlerfall und bei Änderungen statt, die statistische Ausgabe von rsync unterbleibt
$output = $class->exec($src,$dest,@opt); ($output,$cmd) = $class->exec($src,$dest,@opt);
Quell-Pfad
Ziel-Pfad
Füge die Option --dry-run zur Kommandozeile hinzu, d.h. das rsync-Kommando wird ausgeführt, ohne dass Änderungen vorgenommen werden.
Liefere die Ausgabe des rsync-Kommandos nicht nur zurück, sondern gib sie auch auf STDOUT aus.
Ausgabe des rsync-Kommandos, Beschreibung siehe oben (String). Im List-Kontext liefere zusätzlich das ausgeführte rsync-Kommando (String, String).
Führe rsync(1) für Quellpfad $src und Zielpfad $dest aus. Ohne Angabe von Optionen wird als Kommandozeile ausgeführt:
rsync --archive --verbose --delete SRC DEST
D.h. $src und $dest werden als Verzeichnisse angesehen, wobei Verzeichnis $dest auf exakt den gleichen Stand wie $src gebracht wird.
Schlägt das Kommando fehl, wird eine Exception geworfen.
Die Ausgabe des rsync-Kommandos wird zurück geliefert, wobei einige Zeilen entfernt werden, so dass eine Ausgabe nur dann erscheint, wenn Änderungen durchgeführt wurden, d.h. die Zeilen über und unter PROTOKOLL werden entfernt:
sending incremental file list PROTOKOLL sent X bytes received X bytes X.00 bytes/sec total size is X speedup is X.X
Im Dry-Run-Modus wird am Ende (DRY RUN) angezeigt.
1.192
Frank Seitz, http://fseitz.de/
Copyright (C) 2020 Frank Seitz
This code is free software; you can redistribute it and/or modify it under the same terms as Perl itself.
To install Quiq, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Quiq
CPAN shell
perl -MCPAN -e shell install Quiq
For more information on module installation, please visit the detailed CPAN module installation guide.