The examples in this topic focus on the following Sync Framework types:

Understanding File Synchronization

 

Sync Framework implements a synchronization provider that can be used to synchronize files and subfolders that are contained in a folder on a file system.

This provider exposes several configurable settings to give a finer degree of control over exactly how synchronization occurs and which items are synchronized.

To synchronize files between two folders, an application completes the following basic steps:

  1. Creates an FileSyncProvider object to represent each folder.

  2. Passes the two providers to an SyncOrchestrator object, and specifies one as the source provider and the other as the destination provider.

  3. Calls Synchronize to start the synchronization session.

For more information about synchronizing files, see Synchronizing Files.

Example

The example code in this section is from a console application that synchronizes two directories, including the subdirectories and files in those directories.

The example code shows the following tasks:

  • How to set synchronization options.

  • How to explicitly perform change detection for a replica复制品.

  • How to specify a filter that controls which items are included in synchronization.

  • How to handle conflicts that can occur during synchronization.

  • How to synchronize two replicas.

After showing these code examples, we include the complete code for the application so that you can build and run it.

Setting Synchronization Options

The FileSyncOptions object enables you to set several options for file synchronization, including how to detect changes and whether to delete items during synchronization or move them to the Recycle Bin.

The following code example sets four options, three of which are related to item deletes.

The option ExplicitDetectChanges means that Sync Framework will not perform change detection unless the application explicitly callsDetectChanges.

This is explained in the next section "Performing Change Detection".

Performing Change Detection

By default, Sync Framework performs change detection at both replicas whenever Synchronize is called.

Change detection enables Sync Framework to determine which items should be sent from the source to the destination and which items, if any, are in conflict.

By specifyingExplicitDetectChanges, you can control when change detection is performed.

The following code example calls change detection for each replica before Synchronize is ever called.

This example is meant to illustrate DetectChanges, but it does have the benefit of having one change detection pass rather than the two that would occur when we perform bidirectional synchronization later in the application.

Specifying a Static Filter

Static filters can be set to exclude files by name (including wildcard通配符 names) and by attribute属性.

Static filters can also be set to exclude the contents of whole subfolders.

Or, an explicit list of file names to include (including wildcard names) can be specified.

To be included in the scope, a file or a folder must pass all filters.

For example, if all files that have a .txt extension are excluded from the scope and MyFile.txt is specified in the list of files to explicitly include in the scope, MyFile.txt will be excluded because of its .txt extension.

The following code example uses the FileSyncScopeFilter object to create a filter that excludes all *.lnk files.

A filter has no relationship to its creating provider.

To connect a filter to a provider, pass the filter to one of the constructors for FileSyncProvider or by setting the ScopeFilterproperty.

In the sample application, we do this in the DetectChangesOnFileSystemReplica() method because the filter is relevant only for change detection.

Because the filter is independent of the provider, only one filter should be created per synchronization session;

providers should not use different filters, because this can lead to non-convergence of data.

In addition to static filters, you can also exclude files during synchronization by handling an event raised by the provider.

For more information, see Controlling Which Files Are Synchronized.

Handling Conflicts

Sync Framework detects and resolves决定 concurrency并发 conflicts and constraint约束 conflicts for files and folders.

A concurrency conflict occurs when the same item is changed at both replicas since the last synchronization session between those replicas.

A constraint conflict occurs if a file or folder with the same name is added to both replicas.

Conflicts are resolved by keeping the file or folder with the most recent change and deleting (or moving) the file or folder with the older change.

For files, you also have the option of specifying that the source or destination should win the conflict, regardless of which change occurred first.

The following code example registers event handlers for the ItemConflicting and ItemConstraintevents that are available through the SyncCallbacks object.

The methods that are called resolve all conflicts in favor of有利于 the source and write information to the console.

Synchronizing Two Replicas

After options and filters are set, the application synchronizes the two replicas by instantiating a SyncOrchestrator, and calling the Synchronizemethod.

The following code example specifies the provider for each replica, sets options, registers event handlers, specifies a synchronization direction of Upload, and calls Synchronize.

The method is called twice to perform bidirectional synchronization between the replicas.

Complete Code Example

The following code is the complete code for this example. The previous examples in this section were taken from this code.

To run this code:

  • Create a console application project, and add the code to the project.

  • Add references to Microsoft.Synchronzation.dll and Microsoft.Synchronzation.Files.dll.

  • Build the project to create an executable.

  • Run the executable from the command line to synchronize the files and subdirectories of two replica directories: MyExeName.exe \path\to\directoryA \path\to\directoryB.

In the Visual Basic example, the code explicitly sets the MTAThread attribute on the Main() method.

File synchronization provider requires applications to use the multithreaded apartment (MTA) threading model.

How to: Synchronize Files by Using Managed Code的更多相关文章

  1. Optimize Managed Code For Multi-Core Machines

    Parallel Performance Optimize Managed Code For Multi-Core Machines Daan Leijen and Judd Hall This ar ...

  2. Passing JavaScript Objects to Managed Code

    Silverlight If the target managed property or input parameter is strongly typed (that is, not typed ...

  3. 不要忽视Managed code stripping的副作用

    0x00 前言 Unity 2018.3之后,新的“Managed Stripping Level”选项将替换 player settings 中原有的“Stripping Level”选项. 这个新 ...

  4. C#中的文件同步

    How to: Synchronize Files by Using Managed Code FileSyncProvider Class File Synchronization Provider ...

  5. Oracle管理文件OMF (oracle managed files)

    简化dba的管理操作 1:启用 omf 23:16:04 SYS@orcl> show parameter DB_CREATE_FILE_DEST NAME TYPE VALUE ------- ...

  6. [转]Passing Managed Structures With Strings To Unmanaged Code Part 3

    1. Introduction. 1.1 In part 1 of this series of blogs we studied how to pass a managed structure (w ...

  7. [转]Passing Managed Structures With Strings To Unmanaged Code Part 2

    1. Introduction. 1.1 In part 1 of this series of blogs we studied how to pass a managed structure (w ...

  8. [转]Passing Managed Structures With Strings To Unmanaged Code Part 1

    1. Introduction. 1.1 Managed structures that contain strings are a common sight. The trouble is that ...

  9. Getting Started Synchronizing Files

    https://msdn.microsoft.com/en-US/library/bb902813(v=sql.110).aspx Sync Framework includes a file syn ...

随机推荐

  1. 【Ural】【1519】Formula 1

    插头DP 本题为CDQ<基于连通性状态压缩的动态规划的……(我忘了)>里的例题!(嗯就是这样……) 先膜拜一下ccy大神……http://blog.sina.com.cn/s/blog_5 ...

  2. jQuery(Keep for myself)

    jQuery API : http://www.w3cschool.cc/manual/jquery/ 1. jQuery是一个JavaScript函数库. jQuery是一个轻量级的"写的 ...

  3. lua与 object-C 通信

    IOS中如何调用LUA,以及LUA如何调用IOS中的功能 下面将讲解一下如何在iOS里调用Lua函数,以及Lua函数如何调用iOS本地函数. 转载请注明出处.原文出处 http://www.cnblo ...

  4. Windows7 64位安装配置Apache2.4+PHP5.4+MySQL5.5+Xdebug

    PHP更新已经到了5.4.7了,之前是用PHPstudy安装的PHP5.2.13版本,今天有空,就把之前的集成安装卸载了.换上了新一代PHP,记录一下.. 环境:Windows7 64位(内部版本76 ...

  5. 【中国互联网不眠夜】Struts2漏洞百出,OneRASP鼎力相助

    Struts2是一款优秀的网站框架,在互联网上有十分广泛的应用,近期apache官方发布了高危漏洞通告Apache Struts 任意代码执行漏洞(CVE-2016-3081,S2-032),该漏洞风 ...

  6. Android activity属性

    android:allowTaskReparenting 是否允许activity更换从属的任务,比如从短信息任务 切换到浏览器任务. android:alwaysRetainTaskState 是否 ...

  7. C#中的可空类型

    public class Person { public DateTime birth; public DateTime? death; string name; public TimeSpan Ag ...

  8. Dev 统计GridControl界面上当前选中的一行的值

    private void gridView1_CellValueChanged(object sender, DevExpress.XtraGrid.Views.Base.CellValueChang ...

  9. MongoDB的安装,配置与开机自启动

    关于简介不多说百度去吧少年.. MongoDB详细安装: 1.进入官网,点击DOWNLOAD MONGODB,下载所需要的版本.. 我这里把下载的文件放在d\MongoDB文件夹下,点击下载的官方镜像 ...

  10. WebSocket 是什么原理?为什么可以实现持久连接

    你可以把 WebSocket 看成是 HTTP 协议为了支持长连接所打的一个大补丁,它和 HTTP 有一些共性,是为了解决 HTTP 本身无法解决的某些问题而做出的一个改良设计.在以前 HTTP 协议 ...