菜单

复制命令(ROBOCOPY)

2019年4月5日 - UNIXSolaris

      //  其他大于八的值表示在复制操作时期至少有1个告负。

为力保订阅服务器上的多少1致性,日志读取代理暗中同意景况下不会将发表数据库中的事务拆分成四个工作存放到分发数据库(能够修改日志读取代理中的马克斯CmdsInTran暗中同意值来拆分大事务)

     找到想要的取舍之后 ,按 CT牧马人L + C 来终止就足以了。

PS:设置代理参数ReadBatchThreshold来决定单个处理周期读取最大的命令数(作者没在生养服务器上安装过,但意识一片关于这些设置的篇章:http://connect.microsoft.com/SQLServer/feedback/details/478792/using-the-readbatchthreshold-parameter-in-logreader-agent-leads-to-slow-performance)

 

 

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

起来时间: 二〇一八年六月113日 一柒:4九:45
源: 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/分钟。
得了时间: 二零一八年2月二3日 一柒:4九:5三

 

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

    参数:  

      min-max
:文件的十分的小到最大,单位是(byte)

 

     

    //
在钦命时间起始复制:

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

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

 


对复制平昔属于挂一漏万庸庸碌碌的情状,仅知道有些浮泛,对广大细节尚未深远学习过,

 

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

    分选多得记不住,所以就直接复制得了:

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

    robocopy
的归来代码:**
  **

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

 

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

  // 描述:

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

 

PollingInterval: polling_interval
暗许配置值:伍秒
对日记举行已复制业务查询的效能(以秒计)。

 

MaxCmdsInTran:number_of_commands
默认值:0
点名在日记读取器将指令写入到分发数据库时可分组到2个事务中的语句的最大数量。
要是运用此参数,在文告服务器上的大事务(包括众多限令)应用于订阅服务器时,日志读取器代理和散发代理可将那一个大事务拆分为多少个较小的政工。
钦定此参数可以减去分发服务器的争用难点并收缩公布服务器与订阅服务器之间的滑坡时间。
由于开端工作是以较小的单元应用的,订阅服务器能够在始发工作停止以前访问四个较大的逻辑公布服务器业务的行,由此会破坏事务的原子性。
暗许值为 0,那将有限协理发布服务器的政工边界。

  //  语法:

==============================================================
分发复制代理相关配置
BcpBatchSize:bcp_batch_size
默认值:2147473647
在3次大容积复制操作中发送的行数。 执行 bcp in
操作时,批的高低为要作为三个工作发送到服务器的行数,并且也是散发代理记录
bcp 进程音信在此以前必须发送的行数。 当执行 bcp out 操作时,将动用一定批大小
一千。

    // 复战胜务器中前几日的的数目到移动硬盘上:

MaxBcpThreads:number_of_threads
默许值:处理器数目标 2 倍,最大值为 八。
点名能够并行执行的大体量复制操作的数额。 同时设有的线程和 ODBC
连接的最大数量为 马克斯BcpThreads
或映未来散发数据库中联手事务中的大容积复制请求数中较小的这几个。
马克斯BcpThreads 的值必须大于 0,并且不设有任何硬编码的上限。
应用于接纳并发快速照相选项在揭发服务器上扭转的快速照相时,不管为 马克斯BcpThreads
钦赐了何等数值,都将选取1个线程。

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

PollingInterval:polling_interval
默认值:5 秒。

  // 选项:

(PS:从上海体育场合中不难看出,在checkpoint时会记录复制相关的消息)

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

私下认可日志读取代理配置中,日志读取代理会以间隔5秒的频率查询公布库日志(PollingInterval),各个处理周期从表露数据库的工作日志中读取至多500条工作。当发布服务器上运转大事务时,会招致单个处理周期读取过多工作日志,因而应尽量幸免对揭橥库做大事务修改(PS:大事务对订阅数据库也会导致影响)

    
 那要用的时候如何是好呢?先记几个常用的就足以了,其余的一向在命令行下查就好了:

 

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

--=====================================
--插入一条数据,生成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

值     说明
0    未有复制文件。 未有遭逢其余故障。
未有公文不合营。 文件已存在于目的目录中; 因而,跳过了复制操作。
一    全数文件都已成功复制。
二    指标目录中有1对别样文件在源目录中不存在。
未有复制文件。
3    复制了有的文件。 其余文件存在。
没有赶上任何故障。
伍    复制了有的文书。 有个别公文差异盟。
未有遇上任何故障。
陆    存在别的文件和不包容的公文。
未有复制文件,也从未遇上其余故障。
那代表文件已存在于目的目录中。
柒    
 文件被复制,存在文件不相配,并且设有任何文件。
八    多少个公文并未有复制。

MaxDeliveredTransactions:number_of_transactions
默认值:0
贰遍联袂时期选取于订阅服务器的推送事务或请求事务的最大数目。 值为
0,表示最大值为无穷四个事情。
订阅服务器可利用其余值收缩从揭露服务器请求的联合的持续时间。
假如马克斯DeliveredTransactions设置为非0,尽管订阅配置为连日来运转,在传递钦定数量的工作后,分发代理便会终止运转,必要再行手动运行。

 

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

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

图片 1

      xcopy、copy
是单线程的,robocopy是二10十二线程的,但是和局地正经的复制软件相比速度照旧要差1些。

*以下探讨的依照事务复制,不思量共同存款和储蓄进度的图景

  //
注意事项:

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

 惯例依旧是阿妹

图片 2

 

图片 3

图片 4

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

 

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

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

  // 实例:

ReadBatchThreshold:number_of_commands
默认值:0
在复制命令由分发代理发送给订阅服务器从前,从业务日志读取的复制命令的数量。
假诺未钦定此参数,日志读取器代理会一向读取完此日志,可能读取到
-ReadBatchSize 中钦赐的数字(事务数)甘休。

ROBOCOPY :: Windows 的保证文件复制

 

初叶时间: Fri Aug 17 1陆:56:52 201八

 

源: 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:20180八一七  则象征日期。而不是天意。

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

  

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

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

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

始于时间: 二〇一八年十二月一二10四日 1柒:3陆:二1
源: 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月1101二十五日 一柒:3陆:二5

 

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

 

    // 复制不供给的公文:

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

    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


假如发表数据库上中国人民解放军海军事工业程高校业作变更相比频仍时,能够修改PollingInterval参数的值来下滑复制延迟(Paddy_张充在生产服务器上布署过)。过小的PollingInterval值会加重宣布服务器负荷。

    

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

日记文件: d:\backup.txt

 

 

当发布数据库上的事体日志被日志读取代理读取后,日志便足以由checkpoint或日志备份截断。

ROBOCOPY :: Windows 的笃定文件复制

 

始发时间: 二〇一八年五月123日 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:清理作业不会清楚最终一条工作工作及其有关命令)

      robocopy /? | more

 


图片 5

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

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

### 注意:

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

::
:: 复制选项:
::
/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 将跳过
复制会话简要源目录和目标目录中具有该名称的任何文件或目录。

=====================================================================
日志读取器代理相关布置

ROBOCOPY 命令:

MSDN 火速通道

    对比较 xcopy、copy
来说,复制的法力就强大很多,

对此复制业务和复制命令,分发代理依据铺排参数CommitBatchSize(暗中认可100)和CommitBatchThreshold(暗许1000)来将业务打包成3个bacth提交给订阅服务器(肖磊如是说:同时钦命CommitBatchSize和CommitBatchThreshold时,也会并发不到命令数和事务数就交由给订阅服务器),分发代理作业依照钦赐的调度运营。

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

ReadBatchSize:number_of_transactions
默认值:500
种种处理周期从揭橥数据库的事务日志中读取的最大事情数目。代理不断读取批次中的事务,直到从该日志中读取全部工作甘休。
Oracle 发表服务器不援助该参数。

相关文章

发表评论

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

网站地图xml地图