复制命令(ROBOCOPY)

 

MSDN 飞快通道

 

 

  // 实例:

在散发服务器上,复制清理作业暗中认可依据每拾分钟一遍的频率执行,查找移除那多少个无需保存的作业和下令。复制业务和复制命令会依照分发服务器品质设置中内定“事务保持期”来存放,当跨越最大工作保持期后,复制业务和复制命令会被免去,未共同的订阅会被标记为“过期”。

    robocopy
的回来代码:**
  **

对复制一贯属于一知半解无所作为的情况,仅知道某个浮泛,对许多细节尚未长远学习过,

ROBOCOPY :: Windows 的可信赖文件复制

 

始于时间: Fri Aug 一七 1陆:5陆:5二 2018

 

源: S:\用友备份\机关备份\ZT017\
目标: \\tsclient\G\备份\ERP\ZT017\

 

文件: *.*

 

选项: *.* /TEE /S /E /COPY:DAT /MAXAGE:1 /R:3 /W:30

 


 

0 S:\用友备份\机动备份\ZT017\
2 S:\用友备份\自动备份\ZT017\20180808\
2 S:\用友备份\自行备份\ZT017\20180809\
2 S:\用友备份\机关备份\ZT017\20180810\
2 S:\用友备份\电动备份\ZT017\20180811\
2 S:\用友备份\机动备份\ZT017\20180812\
2 S:\用友备份\自动备份\ZT017\20180813\
2 S:\用友备份\自行备份\ZT017\20180814\
2 S:\用友备份\活动备份\ZT017\20180815\
2 S:\用友备份\机关备份\ZT017\20180816\
新目录 2 S:\用友备份\电动备份\ZT017\20180817\
100% 新文件 2.0 g UFDATA.BAK
100% 新文件 345 UfErpAct.Lst

 


 

总数 复制 跳过 不匹配 失败
其他
目录: 11 1 10 0 0 0
文件: 20 2 18 0 0 0
字节: 20.823 g 2.094 g 18.729 g 0 0 0
时间: 0:08:22 0:08:21 0:00:00 0:00:01

 

速度: 4484937 字节/秒。
速度: 256.630 MB/分钟。

 

结束: Fri Aug 17 17:05:14 2018

    ———————————————————————————————————–

    参数表达:

      /e:
      包括空目录和子目录。

      /tee: 
  在复制时在控制弗罗茨瓦夫能够见到详细的出口消息,包括进程的百分比。那一个比较好。

      /maxage:  最大的流年,约等于前有个别天。要是数值高于一九零零,则用表示日期。如:
/maxage:20180817  则意味着日期。而不是天机。

      /log+:   把出口追加到日志文件。

  

   // 复制内定的文件类型:

    ————————————————————————————————————-

    C:\Users\Administrator>robocopy “d:\Lofter”
“d:\a” *.txt *.xls  /e /tee

起来时间: 二零一八年一月130日 壹七:3陆:二一
源: d:\Lofter\
目标: d:\a\

 

文件: *.txt
*.xls

 

选项: /TEE /S /E /DCOPY:DA /COPY:DAT /R:1000000 /W:30

 ……………………………………….

 ……………………………………….

总数 复制 跳过 不匹配 失败 其他
目录: 198 197 1 0 0 4
文件: 58 58 0 0 0 3
字节: 182.6 k 182.6 k 0 0 0 3.9 k
时间: 0:00:03 0:00:00 0:00:00 0:00:02

速度: 286880 字节/秒。
速度: 16.415 MB/分钟。
结束时间: 二〇一八年2月1十五日 1七:3陆:2伍

 

    ————————————————————————————————————-

 

    // 复制不需求的文书:

    ————————————————————————————————————-

    C:\Users\Administrator>robocopy “d:\a”
“d:\b”  /e /xf *.tmp *.exe *.gif

    ————————————————————————————————————-

 

    //
复制内定文件大小的公文:
  

    ————————————————————————————————————-

C:\Users\Administrator>robocopy “d:\a” “d:\b” /e /min:1000
/max:5000


对此复制业务和复制命令,分发代理根据布署参数CommitBatchSize(暗中认可100)和CommitBatchThreshold(默许一千)来将事情打包成3个bacth提交给订阅服务器(肖磊如是说:同时钦定CommitBatchSize和CommitBatchThreshold时,也会油但是生不到命令数和事务数就付给给订阅服务器),分发代理作业遵照钦命的调度运营。

     找到想要的取舍之后 ,按 CT福睿斯L + C 来终止就足以了。

*以下研讨的基于事务复制,不思考共同存款和储蓄进度的事态

日志文件: d:\backup.txt

MaxBcpThreads:number_of_threads
默许值:处理器数目的 2 倍,最大值为 八。
点名能够并行执行的大体积复制操作的数目。 同时设有的线程和 ODBC
连接的最大数量为 马克斯BcpThreads
或出示在散发数据库中联合事务中的大容积复制请求数中较小的那多少个。
马克斯BcpThreads 的值必须高于 0,并且不设有别的硬编码的上限。
应用于选拔并发快照选项在发表服务器上生成的快速照相时,不管为 马克斯BcpThreads
钦点了怎么数值,都将利用2个线程。

  // 描述:

 

    
 那要用的时候如何是好吧?先记多少个常用的就可以了,别的的第二手在命令行下查就好了:

标记为‘REPLICATE’的日志会被日志读取代理器读取,转换来复制业务和下令,然后写入到分发库中的表dbo.MSrepl_transactions和dbo.MSrepl_commands。

    robocopy <source>
<destination> [<file> [ … ]]
[<optoins>]

 

     
 —————————————

PollingInterval:polling_interval
默认值:5 秒。

  //
注意事项:

ReadBatchThreshold:number_of_commands
默认值:0
在复制命令由分发代理发送给订阅服务器从前,从工作日志读取的复制命令的数额。
假若未内定此参数,日志读取器代理会平昔读取完此日志,或然读取到
-ReadBatchSize 中钦点的数字(事务数)结束。

      //  任何大于八的值表示在复制操作期间至少有三个破产。

当公布数据库上的工作日志被日志读取代理读取后,日志便能够由checkpoint或日志备份截断。

  // 为啥未有代码 四 ???

 

::
:: 复制选项:
::
/S :: 复制子目录,但不复制空的子目录。
/E :: 复制子目录,包括空的子目录。
/LEV:n :: 仅复制源目录树的前 n 层。


/Z :: 在可重新启动模式下复制文件。
/B :: 在备份模式下复制文件。
/ZB :: 使用可重新启动模式;如果拒绝访问,请使用备份模式。
/J :: 复制时使用未缓冲的 I/O (推荐在复制大文件时使用)。
/EFSRAW :: 在 EFS RAW 模式下复制所有加密的文件。


/COPY:复制标记:: 要复制的文件内容(默认为 /COPY:DAT)。
(复制标记: D=数据,A=属性,T=时间戳)。
(S=安全=NTFS ACL,O=所有者信息,U=审核信息)。



/SEC :: 复制具有安全性的文件(等同于 /COPY:DATS)。
/COPYALL :: 复制所有文件信息(等同于 /COPY:DATSOU)。
/NOCOPY :: 不复制任何文件信息(与 /PURGE 一起使用)。
/SECFIX :: 修复所有文件的文件安全性,即使是跳过的文件。
/TIMFIX :: 修复所有文件的文件时间,即使是跳过的文件。


/PURGE :: 删除源中不再存在的目标文件/目录。
/MIR :: 镜像目录树(等同于 /E 加 /PURGE)。


/MOV :: 移动文件(复制后从源中删除)。
/MOVE :: 移动文件和目录(复制后从源中删除)。


/A+:[RASHCNET] :: 将给定的属性添加到复制的文件。
/A-:[RASHCNET] :: 从复制的文件中删除给定的属性。


/CREATE :: 仅创建目录树和长度为零的文件。
/FAT :: 仅使用 8.3 FAT 文件名创建目标文件。
/256 :: 关闭超长路径(> 256 个字符)支持。


/MON:n :: 监视源;发现多于 n 个更改时再次运行。
/MOT:m :: 监视源;如果更改,在 m 分钟时间后再次运行。


/RH:hhmm-hhmm :: 可以启动新的复制时运行的小时数 - 时间。
/PF :: 基于每个文件(而不是每个步骤)来检查运行小时数。


/IPG:n :: 程序包间的间距(ms),以释放低速线路上的带宽。


/SL :: 对照目标复制符号链接。


/MT[:n] :: 使用 n 个线程进行多线程复制(默认值为 8)。
n 必须至少为 1,但不得大于 128。
该选项与 /IPG 和 /EFSRAW 选项不兼容。
使用 /LOG 选项重定向输出以便获得最佳性能。


/DCOPY:复制标记:: 要复制的目录内容(默认为 /DCOPY:DA)。
(复制标记: D=数据,A=属性,T=时间戳)。


/NODCOPY :: 不复制任何目录信息(默认情况下,执行 /DCOPY:DA)。


/NOOFFLOAD :: 在不使用 Windows 复制卸载机制的情况下复制文件。


::
:: 文件选择选项:
::
/A :: 仅复制具有存档属性集的文件。
/M :: 仅复制具有存档属性的文件并重置存档属性。
/IA:[RASHCNETO] :: 仅包含具有任意给定属性集的文件。
/XA:[RASHCNETO] :: 排除具有任意给定属性集的文件。


/XF 文件[文件]... :: 排除与给定名称/路径/通配符匹配的文件。
/XD 目录[目录]... :: 排除与给定名称/路径匹配的目录。


/XC :: 排除已更改的文件。
/XN :: 排除较新的文件。
/XO :: 排除较旧的文件。
/XX :: 排除多余的文件和目录。
/XL :: 排除孤立的文件和目录。
/IS :: 包含相同文件。
/IT :: 包含已调整的文件。


/MAX:n :: 最大的文件大小 - 排除大于 n 字节的文件。
/MIN:n :: 最小的文件大小 - 排除小于 n 字节的文件。


/MAXAGE:n :: 最长的文件存在时间 - 排除早于 n 天/日期的文件。
/MINAGE:n :: 最短的文件存在时间 - 排除晚于 n 天/日期的文件。
/MAXLAD:n :: 最大的最后访问日期 - 排除自 n 以来未使用的文件。
/MINLAD:n :: 最小的最后访问日期 - 排除自 n 以来使用的文件。
(If n < 1900 then n = n days, else n = YYYYMMDD date)。


/XJ :: 排除接合点和符号链接。(默认情况下通常包括)。


/FFT :: 假设 FAT 文件时间(2 秒粒度)。
/DST :: 弥补 1 小时的 DST 时间差。


/XJD :: 排除目录的接合点和符号链接。
/XJF :: 排除文件的符号链接。


::
:: 重试选项:
::
/R:n :: 失败副本的重试次数: 默认为 1 百万。
/W:n :: 两次重试间的等待时间: 默认为 30 秒。


/REG :: 将注册表中的 /R:n 和 /W:n 保存为默认设置。


/TBD :: 等待定义共享名称(重试错误 67)。


::
:: 日志记录选项:
::
/L :: 仅列出 - 不复制、添加时间戳或删除任何文件。
/X :: 报告所有多余的文件,而不只是选中的文件。
/V :: 生成详细输出,同时显示跳过的文件。
/TS :: 在输出中包含源文件的时间戳。
/FP :: 在输出中包含文件的完整路径名称。
/BYTES :: 以字节打印大小。


/NS :: 无大小 - 不记录文件大小。
/NC :: 无类别 - 不记录文件类别。
/NFL :: 无文件列表 - 不记录文件名。
/NDL :: 无目录列表 - 不记录目录名称。


/NP :: 无进度 - 不显示已复制的百分比。
/ETA :: 显示复制文件的预期到达时间。


/LOG:文件 :: 将状态输出到日志文件(覆盖现有日志)。
/LOG+:文件 :: 将状态输出到日志文件(附加到现有日志中)。


/UNILOG:文件 :: 以 UNICODE 方式将状态输出到日志文件(覆盖现有日志)。
/UNILOG+:文件 :: 以 UNICODE 方式将状态输出到日志文件(附加到现有日志中)。


/TEE :: 输出到控制台窗口和日志文件。


/NJH :: 没有作业标头。
/NJS :: 没有作业摘要。


/UNICODE :: 以 UNICODE 方式输出状态。


::
:: 作业选项 :
::
/JOB:作业名称 :: 从命名的作业文件中提取参数。
/SAVE:作业名称 :: 将参数保存到命名的作业文件
/QUIT :: 处理命令行后退出(以查看参数)。
/NOSD :: 未指定源目录。
/NODD :: 未指定目标目录。
/IF :: 包含以下文件。


::
:: 备注:
::
以前在卷的根目录上使用 /PURGE 或 /MIR 导致
robocopy 也对“系统卷信息”目录内的
文件应用所请求的操作。现在不再是这种情形;如果
指定了任何一项,则 robocopy 将跳过
复制会话简要源目录和目标目录中具有该名称的任何文件或目录。

CommitBatchSize:commit_batch_size
默认值:100
发生 COMMIT 语句前要发给订阅服务器的事务数。

ROBOCOPY :: Windows 的可相信文件复制

初阶时间: 二〇一八年11月一二十13日 一7:4玖:4伍
源: d:\a\
目标: d:\b\

文件: *.*

选项: *.* /S /E /DCOPY:DA /COPY:DAT /MAX:5000 /MIN:1000 /R:1000000
/W:30

  ………………………………………..

  ………………………………………..

总数 复制 跳过 不匹配 失败 其他
目录: 391 232 159 0 0 0
文件: 2465 249 2216 0 0 0
字节: 91.03 m 633.1 k 90.41 m 0 0 0
时间: 0:00:07 0:00:01 0:00:00 0:00:06

速度: 405969 字节/秒。
速度: 23.229 MB/分钟。
告竣作时间间: 二零一八年十二月1三1013日 17:4九:5叁

 

    ————————————————————————————————————-

    参数:  

      min-max
:文件的纤维到最大,单位是(byte)

 

     

    //
在钦点时间初始复制:

    ————————————————————————————————————-

C:\Users\Administrator> robocopy “d:\a” “d:\b” *.txt /e
/rh:1830-1900

 


链接:http://msdn.microsoft.com/zh-cn/library/bb522755.aspx

ROBOCOPY :: Windows 的可信赖文件复制

 

发端时间: 二零一八年十二月12日 1⑧:00:四7
源: d:\a\
目标: d:\b\

 

文件: *.txt

 

选项: /S /E /DCOPY:DA /COPY:DAT /RH:1830-1900 /R:1000000 /W:30

 


 

小时: 在 18:00 时始于暂停,直到 1八:30…


 

    

    

    

    

  

若果创设揭橥时未选拔“登时早先化”(公布属性immediate_sync为false)时,复制业务和复制命令已传递给所有订阅,且存放时间超越最小“事务保持期”,复制业务和复制命令便能够被复制清理作业删除。(PS:清理作业不会理解最终一条工作工作及其有关命令)

       
 —————————————

 

### 注意:

(PS:从上海教室中简单看出,在checkpoint时会记录复制相关的音信)

    ———————————————————————————————————–

–===============================================

    

CommitBatchThreshold:commit_batch_threshold
默认值:1000
发生 COMMIT 语句前要发给订阅服务器的复制命令数。

    相对而言较 xcopy、copy
来说,复制的效率就强劲很多,

暗中认可日志读取代理配置中,日志读取代理会以间隔5秒的频率查询发布库日志(PollingInterval),每一种处理周期从透露数据库的业务日志中读取至多500条工作。当布告服务器上运行大事务时,会导致单个处理周期读取过多工作日志,由此应尽量制止对发表库做大事务修改(PS:大事务对订阅数据库也会促成影响)

    // 复克制务器中明天的的数目到移动硬盘上:

MaxDeliveredTransactions:number_of_transactions
默认值:0
二次联合时期选取于订阅服务器的推送事务或请求事务的最大数目。 值为
0,表示最大值为无穷八个业务。
订阅服务器可使用任何值收缩从透露服务器请求的1块儿的持续时间。
假诺马克斯DeliveredTransactions设置为非0,就算订阅配置为一而再运维,在传递钦命数量的业务后,分发代理便会告壹段落运作,须要再行手动运行。

 

--=====================================
--插入一条数据,生成16条复制命令
INSERT INTO [TestDemo].[dbo].[TB5](C1,C2)
SELECT REPLICATE('AC',10000),1
--查看生成的复制事务和命令
SELECT * FROM dbo.MSrepl_transactions
SELECT * FROM dbo.MSrepl_commands T
WHERE T.xact_seqno=0x00000100000002BA0020

      robocopy /? | more

–===================================================================

 

当宣布数据库上产生多少修改(增加和删除改)时,会将相关操作写入日志,以保障数据1致性,而对宣布表上聚集索引的改动的日志会被标记为‘REPLICATE’。


=====================================================================
日记读取器代理相关配置

值     说明
0    未有复制文件。 未有赶上任何故障。
没有公文不相配。 文件已存在于目的目录中; 由此,跳过了复制操作。
1    全数文件都已成功复制。
二    指标目录中有壹对其余文件在源目录中不设有。
未有复制文件。
三    复制了壹部分文书。 其余文件存在。
未有赶上其余故障。
伍    复制了有的文件。 有个别公文不协作。
未有赶上任何故障。
陆    存在任何文件和不包容的文件。
没有复制文件,也未有赶上任何故障。
那意味文件已存在于目的目录中。
七    
 文件被复制,存在文件不一样盟,并且存在别的文件。
八    多少个文件并未复制。

1旦不对之处,请各位大神批评指正。

    
 当然其参数也是最多的,想记都记不住 –_– ~

针对工作中修改的每壹行数据生成一条或多条复制命令,尤其是对varchar(max)+xml+text等大字段操作(再一次谢谢肖磊)。

    挑选多得记不住,所以就径直复制得了:

为保证订阅服务器上的数码一致性,日志读取代理暗许情形下不会将布告数据库中的事务拆分成多少个业务存放到分发数据库(能够修改日志读取代理中的马克斯CmdsInTran私下认可值来拆分大事务)

  // 选项:

对散发数据库进行已复制业务查询的效能(以秒计)。

 惯例依然是阿妹

图片 1

 

图片 2

图片 3

      xcopy、copy
是单线程的,robocopy是多线程的,不过和一部分规范的复制软件相比速度如故要差壹些。

ReadBatchSize:number_of_transactions
默认值:500
每种处理周期从表露数据库的作业日志中读取的最大事情数目。代理不断读取批次中的事务,直到从该日志中读取全数工作截至。
Oracle 公布服务器不辅助该参数。

  //  语法:

图片 4

 

MaxCmdsInTran:number_of_commands
默认值:0
点名在日记读取器将指令写入到分发数据库时可分组到2个事情中的语句的最大数目。
假设采纳此参数,在发布服务器上的大事务(包涵众多命令)应用于订阅服务器时,日志读取器代理和散发代理可将这几个大事务拆分为多少个较小的工作。
钦点此参数能够减小分发服务器的争用难题并减少发布服务器与订阅服务器之间的落后时间。
由于开头工作是以较小的单元应用的,订阅服务器能够在起来工作甘休从前访问二个较大的逻辑公布服务器业务的行,由此会破坏事务的原子性。
暗中认可值为 0,那将保险发表服务器的作业边界。

 

图片 5

C:\Users\Administrator>robocopy “S:\用友备份\自动备份\ZT017”
“\\tsclient\G\备份\ERP\ZT017″  /e /maxage:1 /r:3 /tee
/log+:”d:\backup.txt”

PollingInterval: polling_interval
暗许配置值:五秒
对日记进行已复制业务查询的频率(以秒计)。

 

PS:设置代理参数ReadBatchThreshold来控制单个处理周期读取最大的命令数(笔者没在生产服务器上安装过,但发现一片关于那些设置的稿子:http://connect.microsoft.com/SQLServer/feedback/details/478792/using-the-readbatchthreshold-parameter-in-logreader-agent-leads-to-slow-performance)

ROBOCOPY 命令:

只要公布数据库上中国人民解放军海军事工业程大学业作变更比较频仍时,能够修改PollingInterval参数的值来下滑复制延迟(Paddy_张充在生育服务器上安排过)。过小的PollingInterval值会加重宣布服务器负荷。

==============================================================
分发复制代理相关配置
BcpBatchSize:bcp_batch_size
默认值:2147473647
在贰遍大体积复制操作中发送的行数。 执行 bcp in
操作时,批的轻重为要作为三个作业发送到服务器的行数,并且也是散发代理记录
bcp 进程新闻以前务必发送的行数。 当执行 bcp out 操作时,将使用固定批大小
1000。

–===============================================

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图