Название в значительной степени подводит итог.
Недавно я восстановил общую папку из резервной копии. Придя и узнав, что примерно через день эксплуатации пользователей мы начали замечать, что некоторые файлы были повреждены. Повторное извлечение этих файлов из резервной копии показывает, что резервные копии фактически не повреждены. Однако в дальнейшем пользователи изменяют файлы.
Могу ли я с помощью robocopy перезаписать все файлы в этом общем ресурсе, пропуская новые файлы в месте назначения? Другими словами, я в основном хочу скопировать все заново, если пользователь не внес изменения в файл в общей папке.
Флаг / is кажется интригующим, но не уверен, что он перезапишет файл с более новой меткой времени.
И понимание было бы весьма признательно.
https://docs.microsoft.com/en-us/windows-server/administration/windows-commands/robocopy
/ xo Исключает старые файлы.
Вот что тебе нужно.
Использовать:
/MON:1
: ПНисточник itor; бежать снова, когда больше чем n
заметные изменения/XN
: eИксвключать Nкувшинные файлыrobocopy D:\Source\Sync \\ShareName\Sync /TBD /E /XN /MON:1 /LOG+:"\\ShareName\Sync\Logs\Sync.log" /V /TEE /TS /XD Logs
Следующий сценарий будет отслеживать исходный каталог на предмет любых изменений и регистрировать каждый раз, когда файл копируется в целевой каталог.
Сценарий: File-Sync.cmd
::
::[[--- RoboCopy File Sync Script ---]]::
::=========================================================================
@echo off
:: Parameters ::
::-------------------------------------------------------------------------
:: Set Variables ::
:: Date:
set Date=%date:~0,4%%date:~5,2%%date:~8,2%
:: Time:
:: Hour:
set Hour=%time:~0,2%
if "%hour:~0,1%" == " " set HH=0%hour:~1,1%
:: Minute:
set MM=%time:~3,2%
:: Seconds
set SS=%time:~6,2%
set Dtime=%HH%%mm%%ss%
:: Destination:
set Dest=\\ShareName\Sync
:: Log:
set LogDir=\\Sharename\Sync\Logs
:: Source:
set Src=D:\Source\Sync
:: RoboCopy:
:: Log:
set Log=/V /TEE /TS /LOG:"%LogDir%\%date%_%dtime%.log"
:: Options:
set Options=/TBD
:: What to Copy:
set What=/COPY:DAT /DCOPY:DAT /E /XD Logs /XN /MON:1
:: Save Job:
set Save=/SAVE:C:\ProgramData\Scripts\Robocopy\File-Sync
:: Sync ::
::-------------------------------------------------------------------------
RoboCopy %Src% %Dest% %What% %Options% %Log% %Save%
%date%
: Вывод даты в следующем формате: yyyy.MM.dd
%dtime%
: Выводит время в следующем формате: HHmmss
%Dest%
: Каталог назначения%LogDir%
: Каталог журналов%Src%
: Исходный каталог%log%
: Параметры ведения журнала, выводит файл журнала в следующем формате YYYY.MM.DD_HHMMSS.log
/V
: Выводить подробный вывод с отображением пропущенных файлов/TEE
: Вывод в окно консоли, а также в файл журнала /TS
: Включить метки времени исходного файла в вывод/LOG:
: Выводить статус в файл журнала (перезаписать существующий журнал) %dtime%
Включено %options%
: Параметры RoboCopy /TBD
: ждать общих имен То Bе Dопределен%what%
: Что копировать /COPY:DAT
: что КОПИРОВАТЬ для файлов (по умолчанию /COPY:DAT
) /DCOPY:DAT
: То же, что и выше, за исключением каталогов/E
: копировать подкаталоги, включая Eпустые/XD
: EИксвключать Dкаталоги, соответствующие заданным именам / путям /XN
: eИксвключать Nкувшинные файлы/MON:1
: ПНисточник itor; запустить снова, когда будет замечено более n изменений/SAVE
: СПАСТИ параметры в указанный файл задания C:\ProgramData\Scripts\Robocopy\File-Sync.rcj
Запускать скрипт без звука: NoShell-RoboCopy.vbs
'
'::[[--- Run RoboCopy File Sync Silently ---]]::'
'=========================================================================
If WScript.Arguments.Count >= 1 Then
ReDim arr(WScript.Arguments.Count-1)
For i = 0 To WScript.Arguments.Count-1
Arg = WScript.Arguments(i)
If InStr(Arg, " ") > 0 Then Arg = """" & Arg & """"
arr(i) = Arg
Next
RunCmd = Join(arr)
CreateObject("Wscript.Shell").Run RunCmd, 0, True
End If
Выполнить:
wscript "C:\ProgramData\Scripts\Robocopy\NoShell-RoboCopy.vbs" "C:\ProgramData\Scripts\Robocopy\File-Sync.cmd"
Расписание задач: File-Sync.xml
(запускается через 30 секунд после входа пользователя в систему)
<?xml version="1.0" encoding="UTF-16"?>
<Task version="1.4" xmlns="http://schemas.microsoft.com/windows/2004/02/mit/task">
<RegistrationInfo>
<Date>2018-10-25T07:45:58.952588</Date>
<Author>Windows\User</Author>
<Description>Task to synchronize local disk to network backup</Description>
<URI>\Backup\Network File Sync</URI>
</RegistrationInfo>
<Triggers>
<LogonTrigger>
<Enabled>true</Enabled>
<Delay>PT30S</Delay>
</LogonTrigger>
</Triggers>
<Settings>
<MultipleInstancesPolicy>IgnoreNew</MultipleInstancesPolicy>
<DisallowStartIfOnBatteries>false</DisallowStartIfOnBatteries>
<StopIfGoingOnBatteries>true</StopIfGoingOnBatteries>
<AllowHardTerminate>false</AllowHardTerminate>
<StartWhenAvailable>true</StartWhenAvailable>
<RunOnlyIfNetworkAvailable>false</RunOnlyIfNetworkAvailable>
<IdleSettings>
<StopOnIdleEnd>true</StopOnIdleEnd>
<RestartOnIdle>false</RestartOnIdle>
</IdleSettings>
<AllowStartOnDemand>true</AllowStartOnDemand>
<Enabled>true</Enabled>
<Hidden>false</Hidden>
<RunOnlyIfIdle>false</RunOnlyIfIdle>
<DisallowStartOnRemoteAppSession>false</DisallowStartOnRemoteAppSession>
<UseUnifiedSchedulingEngine>true</UseUnifiedSchedulingEngine>
<WakeToRun>false</WakeToRun>
<ExecutionTimeLimit>PT0S</ExecutionTimeLimit>
<Priority>7</Priority>
<RestartOnFailure>
<Interval>PT1M</Interval>
<Count>3</Count>
</RestartOnFailure>
</Settings>
<Actions Context="Author">
<Exec>
<Command>%WinDir%\system32\wscript.exe</Command>
<Arguments>"C:\ProgramData\Scripts\Robocopy\NoShell-RoboCopy.vbs" "C:\ProgramData\Scripts\Robocopy\File-Sync.cmd"</Arguments>
</Exec>
</Actions>
</Task>