web-dev-qa-db-ja.com

Robocopy-宛先のファイルが新しい場合を除いて、すべてのファイルを上書きします

タイトルはそれをかなり要約します。

最近、バックアップからファイル共有を復元しました。約1日の本番環境のユーザーの後に、いくつかのファイルが破損していることに気付き始めました。これらのファイルをバックアップから再度プルすると、バックアップが実際にそのまま残っていることがわかります。ただし、ユーザーは今後ファイルを変更しています。

Robocopyを使用して、宛先の新しいファイルをスキップして、この共有のすべてのファイルを上書きできますか?つまり、ユーザーが共有上のファイルに変更を加えていない限り、基本的にすべてを再コピーしたいと思います。

/ isフラグは興味深いようですが、新しいタイムスタンプでファイルを上書きするかどうかは不明です。

そして洞察をいただければ幸いです。

6
cvidal

https://docs.Microsoft.com/en-us/windows-server/administration/windows-commands/robocopy

/ xo古いファイルを除外します。

それが必要です。

7
BaronSamedi1958

活用:

  • /MON:1[〜#〜] mon [〜#〜] itorソース; n以上の変更が見られたときに再度実行する
  • /XN:e [〜#〜] x [〜#〜]除外[〜#〜] n [〜#〜] = ewerファイル
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%:ソースディレクトリ
  • RoboCopy:
    • %log%:ロギングオプション。次の形式でログファイルを出力しますYYYY.MM.DD_HHMMSS.log
      • /V:スキップされたファイルを示す詳細出力を生成します
      • /TEE:コンソールウィンドウへの出力とログファイル
        • 時々端末から実行する必要がある場合に役立ちます
      • /TS:出力にソースファイルのタイムスタンプを含める
      • /LOG::ステータスをLOGファイルに出力(既存のログを上書き)
        • %dtime%が含まれている場合は上書きされません
    • %options%:RoboCopyオプション
      • /TBD:共有名を待つ[〜#〜] t [〜#〜] o [〜#〜] b [〜#〜 ] e [〜#〜] d [〜#〜]定義済み
    • %what%:何をコピーするか
      • /COPY:DAT:対象[〜#〜] copy [〜#〜]ファイルの場合(デフォルトは/COPY:DAT
        • フラグのコピー:[〜#〜] d [〜#〜]= Data、[〜#〜] a [〜#〜]= Attributes、[ 〜#〜] t [〜#〜]=タイムスタンプ
      • /DCOPY:DAT:ディレクトリを除いて、上記と同じ
      • /E[〜#〜] e [〜#〜] mpty onesを含むサブディレクトリをコピーします
      • /XD:E [〜#〜] x [〜#〜]除外[〜#〜] d [〜#〜] =指定された名前/パスに一致するirectories
        • ログディレクトリがソースディレクトリに格納されている場合は必須
      • /XN:e [〜#〜] x [〜#〜]除外[〜#〜] n [〜#〜] = ewerファイル
      • /MON:1[〜#〜] mon [〜#〜] itorソース; n個を超える変更が見られたときに再度実行する
    • /SAVE[〜#〜] 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>
1
JW0914