RoboCopy mit sichern von gelöschten Dateien
13.12.2010
10:39:25 Uhr5807 Aufrufe
4 Antworten
10:39:25 Uhr
4 Antworten
Hilfreich +1
ich sichere mit RoboCopy in regelmäßigen Abständen meine Daten. Da jedoch durch die Option /MIR oder /PURGE versehentlich gelöschte Daten oder Verzeichnisse auch in der Sicherung gelöscht werden habe ich dieses Script geschrieben um gelöschte Daten in ein eigenes Verzeichnis zu verschieben.
Die Sicherung erfolgt zuerst mit RoboCopy ohne /MIR bzw. /PURGE Option. Dabei muss allerdings eine Logdatei mit speziellem Aufbau generiert werden. Die dazu benötigten Optionen sind:
/BYTES (Dateigröße immer in Bytes, da ansonsten zusätzliche Leerzeichen die Auswertung erschweren)
/FP (komplette Dateipfade loggen)
/LOG:file (Dateiname muss im Script eingetragen werden)
Im Script selbst braucht dann nur noch der Name des Logfiles sowie das gewünschte Sicherungsverzeichnis festgelegt werden.
Ich habe das Script mit englischem und mit deutschem Betriebssystem getestet und es funktioniert bei beiden.
/BYTES (Dateigröße immer in Bytes, da ansonsten zusätzliche Leerzeichen die Auswertung erschweren)
/FP (komplette Dateipfade loggen)
/LOG:file (Dateiname muss im Script eingetragen werden)
Im Script selbst braucht dann nur noch der Name des Logfiles sowie das gewünschte Sicherungsverzeichnis festgelegt werden.
01.
@echo off 02.
REM 03.
REM Job zum Auswerten des Logfiles von Robocopy und verschieben der gelöschten Dateien in ein Sicherungsverzeichnis 04.
REM 05.
06.
REM "Hilfsprogramme" ausführen 07.
if "%1" == "-CHECK-" GOTO DoCheck 08.
if "%1" == "-COPYF-" GOTO DoCopyFile 09.
if "%1" == "-COPYD-" GOTO DoCopyDir 10.
11.
REM Hier die gewünschten Parameter eintragen: 12.
REM COPY_DIR: Verzeichnis in welches die gelöschten Daten verschoben werden 13.
REM LogFile: RoboCopy Logdatei 14.
SET COPY_DIR=Deleted\%date%_%time:~0,2%_%time:~3,2%_%time:~6,2% 15.
SET LogFile=Sicherung.log 16.
17.
REM Logdatei durcharbeiten 18.
FOR /F "tokens=1,2,3,*" %%i in (%LogFile%) DO CALL %0 -CHECK- %%i %%j %%k "%%l" 19.
goto Fertig 20.
21.
REM Prüfen einer Log-Zeile 22.
:DoCheck 23.
REM %2 %3 %4 %5 24.
REM *ZUS. Verz. -1 D:\test\robo\d\u1\ 25.
REM *EXTRA Datei 1875110 D:\test\robo\d\cygwin1.dll 26.
27.
SET iii=%2 28.
IF "%iii:~0,1%"=="*" ( 29.
echo %2 %3 %4 %5 30.
IF "%4"=="-1" ( 31.
CALL %0 -COPYD- %5 32.
) ELSE ( 33.
CALL %0 -COPYF- %5 34.
) 35.
ECHO. 36.
) 37.
goto end 38.
39.
40.
REM Datei verschieben 41.
:DoCopyFile 42.
IF NOT EXIST "%COPY_DIR%\%~p2" ( 43.
ECHO MD "%COPY_DIR%\%~p2" 44.
MD "%COPY_DIR%\%~p2" 45.
) 46.
ECHO CopyFile: %2 to "%COPY_DIR%\%~pnx2" 47.
move %2 "%COPY_DIR%\%~pnx2" 48.
goto end 49.
50.
REM Verzeichnis verschieben 51.
:DoCopyDir 52.
IF NOT EXIST "%COPY_DIR%\%~pnx2" ( 53.
ECHO MD "%COPY_DIR%\%~pnx2" 54.
MD "%COPY_DIR%\%~pnx2" 55.
) 56.
ECHO CopyDir: "%~2*.*" TO "%COPY_DIR%\%~pnx2" 57.
FOR /R %2 %%f IN (*.*) DO MOVE %f "%COPY_DIR%\%~pnx2" 58.
rem XCOPY "%~2*.*" "%COPY_DIR%\%~pnx2" 59.
goto end 60.
61.
:Fertig 62.
63.
:endIch habe das Script mit englischem und mit deutschem Betriebssystem getestet und es funktioniert bei beiden.
r1chy2 schreibt am 21.01.2011 um 12:35:06 Uhr
Hallo,
vielen Dank für diese Anleitung. Genau das was ich gesucht habe!
Aber ich habe ja ein kleines Problem beim Alltagstest festgestellt:
Nachdem ich eine Datei vom Quellverzeichnis gelöscht habe, verschiebt das Skript diese Datei in den "Deleted"-Ordner (...\Deleted\%Datum_Zeit%\Pseudopfad\Datei).
Wenn ich dann aber dann das Skript noch einmal ausführe, egal ob Dateien verändert/gelöscht/erstellt wurden oder nicht, dann wird (unter anderem) der oben genannte Ordner noch einmal erstellt (mit neuem Zeitstempel).
PS: Mit ist aufgefallen, dass diese Zeile im Sicherung.log erhalten bleibt:
*EXTRA Dir -1 C:\J\Deleted\
vielen Dank für diese Anleitung. Genau das was ich gesucht habe!
Aber ich habe ja ein kleines Problem beim Alltagstest festgestellt:
Nachdem ich eine Datei vom Quellverzeichnis gelöscht habe, verschiebt das Skript diese Datei in den "Deleted"-Ordner (...\Deleted\%Datum_Zeit%\Pseudopfad\Datei).
Wenn ich dann aber dann das Skript noch einmal ausführe, egal ob Dateien verändert/gelöscht/erstellt wurden oder nicht, dann wird (unter anderem) der oben genannte Ordner noch einmal erstellt (mit neuem Zeitstempel).
PS: Mit ist aufgefallen, dass diese Zeile im Sicherung.log erhalten bleibt:
*EXTRA Dir -1 C:\J\Deleted\
bernhard.h schreibt am 21.01.2011 um 13:40:59 Uhr
Hallo r1chy2,
sollte mit folgender Änderung (ab Zeile 58) behoben sein:
FOR /R %2 %%f IN (*.*) DO MOVE %f "%COPY_DIR%\%~pnx2"
REM Ordner nach verschieben löschen
rd %2
goto end
lg
Bernhard
sollte mit folgender Änderung (ab Zeile 58) behoben sein:
FOR /R %2 %%f IN (*.*) DO MOVE %f "%COPY_DIR%\%~pnx2"
REM Ordner nach verschieben löschen
rd %2
goto end
lg
Bernhard
r1chy2 schreibt am 21.01.2011 um 14:33:48 Uhr
Hallo Bernhard,
danke für die Antwort. Ich hab das Skript korrigiert, aber der Fehler ist nach wie vor vorhanden.
Ich hab mich mal mit dem Code und der Systematik beschäftigt und mir ist folgendes aufgefallen:
%4 ist dann -1, wenn der Ordner/die Datei im Zielverzeichnis vorhanden ist, nicht aber im Quellverzeichnis.
Demnach erkennt das Skript Ordner/Dateien, die gelöscht wurden und verschiebt es im Zielverzeichnis entsprechend in den Delete-Ordner.
Da der Delete-Ordner und dessen Inhalt aber auch nicht im Quellverzeichnis vorhanden ist, bekommt er im Sicherung.log ebenfalls die Markierung -1 (bei %4).
Wenn es möglich wäre, eine if-else-Bedingung reinzuprogrammieren, die prüft ob %5 das Verzeichnis ist, in das die gelöschten Daten verschoben wurden (also: Deleted\%date%_%time:~0,2%_%time:~3,2%_%time:~6,2%). Und wenn ja, dann diese Zeile/diesen Ordner ignoriert, dann könnte es ja funktionieren.
Ich kann leider Batch nicht so gut programmieren.
Danke!
danke für die Antwort. Ich hab das Skript korrigiert, aber der Fehler ist nach wie vor vorhanden.
Ich hab mich mal mit dem Code und der Systematik beschäftigt und mir ist folgendes aufgefallen:
%4 ist dann -1, wenn der Ordner/die Datei im Zielverzeichnis vorhanden ist, nicht aber im Quellverzeichnis.
Demnach erkennt das Skript Ordner/Dateien, die gelöscht wurden und verschiebt es im Zielverzeichnis entsprechend in den Delete-Ordner.
Da der Delete-Ordner und dessen Inhalt aber auch nicht im Quellverzeichnis vorhanden ist, bekommt er im Sicherung.log ebenfalls die Markierung -1 (bei %4).
Wenn es möglich wäre, eine if-else-Bedingung reinzuprogrammieren, die prüft ob %5 das Verzeichnis ist, in das die gelöschten Daten verschoben wurden (also: Deleted\%date%_%time:~0,2%_%time:~3,2%_%time:~6,2%). Und wenn ja, dann diese Zeile/diesen Ordner ignoriert, dann könnte es ja funktionieren.
Ich kann leider Batch nicht so gut programmieren.
Danke!
bernhard.h schreibt am 21.01.2011 um 16:36:19 Uhr
Hallo r1chy2,
ich habe leider erst jetzt gesehen was das eigentliche Problem ist:
du schiebst die gelöschen Dateien in ein Unterverzeichnis des Zielordners. Das ist so nicht vorgesehen. Der Ordern für die gelöschten Dateien sollte nicht im Zielverzeichnis liegen!!
verwende nicht C:\J\Deleted\ sondern C:\Deleted\.
lg
Bernhard
ich habe leider erst jetzt gesehen was das eigentliche Problem ist:
du schiebst die gelöschen Dateien in ein Unterverzeichnis des Zielordners. Das ist so nicht vorgesehen. Der Ordern für die gelöschten Dateien sollte nicht im Zielverzeichnis liegen!!
verwende nicht C:\J\Deleted\ sondern C:\Deleted\.
lg
Bernhard





