经过了多个版本的测试,Microsoft Sync Framework 2.0 RTW(以下简称MSF 2.0)正式发布了。
着急下载的朋友,请点击这里: Microsoft Sync Framework 2.0 Software Development Kit (SDK)
与先前的CTP1、CTP2相比,正式版并没有增加更多的特性,主要修正了测试版中的BUG,使整个产品的稳定性有所提高。
概括来说,Sync Framework 2.0 RTW 主要扩展了以下功能:
1. 增加了新的特性,用于实现新的场景:在以前版本中实现困难的场景,在MSF 2.0中可以轻松实现(下面将会详细介绍)。
2. 改进了Provider的代码编写方法:在MSF 2.0中,开发人员实现一个新的Provider更为简单(即:使用更少的代码,即可实现上一版本中的复杂功能。)。
3. 支持更多的数据源(Data Source):MSF 2.0内置了新的Provider,用于实现更多数据源的同步。
同时,MSF 2.0 RTW 对内核组件进行了改进,并增加了以下新的特性:
1. 新增的以SQL CE 和SQL 为基础的数据库Provider - SqlCeSyncProvider 和SqlSyncProvider,均支持P2P同步模式。
2. 新增的Management API,自动产生SQL语句,实现与 SQL Server 的同步。
3. 使用新增的API,可以备份和恢复一个同步数据库,并且不会损失同步元数据(Metadata) 。
4. 支持0代码实现批次同步。
5. 使用Snapshot模式,可从一个现存的SQL CE 客户端数据库,初始化出一个新客户端。
6. 改进SQL CE数据库的同步性能
以下是Sync Framework 2.0 RTW 新特性及新功能的详细介绍:
1. Simple Provider
在MSF 1.0 编写过Provider的朋友,应该会有一些感触:开发一个好用的Provider并非易事,需要考虑的方面很多并且开发难度不低。MSF开发组收到用户反馈后,积极寻求解决办法,并针对于此问题推出 Simple Provider组件。
Simple Provider组件的目的是:减轻开发人员的工作量,使编写一个Provider所必须得工作大大降低,特别是针对那些没有同步相关能力的Data Source(数据源),例如:Provider所对应的Data Source不具备 Change Tracking(更改后的追踪)能力,使用Simple Provider组件可以帮助开发人员完成大部分工作,而这些工作在以前是必须的。
· Simple Provider的设计目标是:让编写Provider变得容易起来,而不再像以前那些,如果完成一个Provider,你不得不成为一个同步专家。:)
· Simple Provider所作的主要工作是:负责并实现与DataSource的交换,使用Simple Provider后,你只负责实现逻辑代码即可。
Simple Provider同时支持以下更为复杂场景:
· 支持过滤条件
· 支持并发同步操作
· 支持冲突、以及约束冲突处理
· 基于锚点(Anchor)的枚举处理
· 基于单元变化的过滤器(Change Unit Filters)
· 自定义过滤器(Custom Filters)
以及MSF1.0就已经存在的- 基于项目的过滤器(Item Filter),MSF 2.0 总共支持3个过滤器。
这些过滤器有什么用呢?举例说明:在手机设备中,由于存储容量的限制,联系人一项,或许只会存储“姓名”和“电话号码”,然后余下的项目存储于桌面电脑中。使用自定义过滤器(Custom Filters)能够让你自由定义过滤条件,并且根据不同的情况(手机环境或桌面环境),你可以随时将某些项目在你的过滤条件种划入或划出,从而提高了过滤的灵活性。
新的MSF2.0支持在Source Provider与Destination Provider中传递过滤器的内容,开辟专门的传递通道 - 通过sync Session进行传递。从而达到更为实用的目的。
在冲突管理方面,MSF 2.0 增加了一些新特性,帮助我们更容易的处理各种冲突(Conlfict),主要改进为以下三个方面:
· 约束冲突处理(Constraint conflicts)
· 使用日志方式管理冲突(Managing Logged conflicts)
· 以及“最后一次更新为准”的冲突解决方案(Resolving conflicts by using a last-writer-wins policy)
MSF 2.0 能够支持约束冲突的处理,无论约束冲突发生在Iteam或Change Units中。
处理的流程为:目标Provider(Destination Provider)能够识别并报告一个约束冲突给sync Framework,并且自动调用Sync Framework中的相关组件解决相应冲突。最后,目标Provider决定使用何种方案解决冲突。
· 首先,MSF 2.0 使用日志管理管理冲突,使冲突的管理变得更加容易(比如,现在我们可以简单删除一个独立的冲突)。
· 然后,MSF 2.0 定义了一组接口用于冲突日志处理 - 帮助 MSF 管理日志列表中的冲突。
无论如何,将冲突保存成日志列表是非常实用的。使用日志,我们可以从区分出不同的冲突,并能够单独对其进行处理。比如说:用户可以预览冲突,分析并做出最终决定,并最终正确的处理、解决冲突。
实际应用中,应用程序在处理并发的冲突时,通常会以最后的更新为准(Last Wins)。MSF 2.0 可以让您的应用程序具备这种能力,无论冲突发生在源Replica或是目标Replica,Sync Framework能够比较两者的更改时间,并以最后发生变化的时间为准,完成冲突的处理。
最后,MSF2.0改进的 Simple Provider 冲突处理:Simple Provider 包含了一组冲突处理接口,使用他们处理并发和约束冲突时,可以指定相应的解决方案予以处理,从而降低了开发难度。
在绝大多数场景中,Provider之间所同步的- 均为相同格式的数据(比如说在两个数据库Provider之间,同步销售数据)。但在实际应用中,很多时候要求使用不同的Provider进行同步(例如同步的双方,一方是数据库Provider,另一方是文本的Provider,各自内部的的数据格式不同 - 这时候就需要用到“Provider之间的数据转换”)。
MSF 2.0 新提供了一组接口API - 可以将一种数据格式,转换为另一个接口所要求的格式(Data Format),从而实现同步。
转换 数据格式 所用的APIs非常灵活,我们可以将其应用在任意类型的,甚至是自定义Provider。同样,对于已有的Provider – File Sync Provider(文件同步Provider),转换APIs也同样适用。
使用过MSF 1.0的朋友应该感触颇深,同步过程中环境复杂、数据繁多,当遇到问题时,调试起来并不容易,而且很难快速定位问题所在。
为了应对这种情况,MSF 2.0增加了更为强劲跟踪机制,使用其组件,可以方便的对同步应用程序进行跟踪、调试。
开启跟踪机制后,MSF 2.0 将会自从生成 .TMF 文件,用于存放同步所产生的Log数据。
关于跟踪机制更多信息,请查阅在线帮助的“Tracing Sync Framework Components”章节。
支持3种数据库,即:SQL Server、SQL Server Express 和 SQL Server Compact,同时支持 hub-and-spoke 和 peer-to-peer 两种同步模式。
· 自动创建数据库相关的全部触发器、跟踪表、以及Tomb表。
· 内置的数据库Provider之间同步,不需要撰写任何额外的代码。
使用新的、内置数据库Provider,能够自动生成 - 全部的初始化代码与同步代码,不用撰写任何SQL语句即可完成表初始化,也不需要撰写额外的代码即可实现同步。
举例来说:在 Sync Service for ado.net 1.0 时,你需要使用专用工具修改Sql Server原表完成初始化,如:添加 跟踪列、触发器,以及Tomb表。而在MSF 2.0 环境下,新的数据库Provider将会自动帮你完成所需的一切。新的数据库Provider自动完成初始化:在Sqlserver端建立跟踪表与触发器,而且不会更改原表结构(这是一个亮点)。与 1.0 相比,这个改进带来不小的便利。
[关于 hub-and-spoke 和 peer-to-peer 的解释:]
hub-and-spoke并不是一个新的概念,早在Sync Services for ado.net V1版本中的 Server-Client 同步模式,即为:hub-and-spoke。具体来讲,hub-and-spoke 是指:中心向四周辐射的同步模式,进一步说,是以一个服务端为中心,同时向多个客户端辐射进行同步。
peer-to-peer(P2P同步) 与其不同,抛弃了客户端、服务端的概念- 即:任何一个数据库端点,都可以作为服务器端、或客户端使用,大大提高了同步灵活性。peer-to-peer支持任意两个数据库直接实现同步。
· 提供灵活的初始化选项,你现在能够选择:同步生成Schema,还是从现有表复制Schema
· 支持基于DataSize(指定数据大小)的批次同步(Batching),不像过去那样,仅能指定行数进行批次同步
· 增加维护任务支持,比如定时清除MetaData和恢复服务器端数据库等
MSF 1.0 的批次同步存在着一些不足,尤其是稳定性上稍有欠缺。MSF 2.0 的批次同步改用内存中完成,从而提供稳定性。
MSF 2.0 做了以下改进:
· 修复了MSF 1.0的Bugs
· 提供了稳定、全面的批次同步的APIs
· 实现批次同步代,开发人员不必撰写任何代码,MSF 2.0 予以代劳。
· MSF 2.0 批次同步在内存中完成,其稳定性远胜于1.0 - 基于行的批次同步,另一方面也避免了内存溢出等问题。
如上章节6.2所讲,MSF 2.0 改进了数据库Provider初始化、同步方法,同时还有以下改进:
· 支持对已存在数据的数据库,进行初始化
· 支持空数据进行初始化
· 自定义创建用户Schema
· 同步时,自动创建用户Schema
· 从已有的数据库中,复制创建Schema
测试结果证明,MSF 2.0 性能的某些方面可以与RDA媲美,甚至比RDA更快。与Merge相比,MSF同步技术具备更大的扩展空间。
测试环境模拟了一个大数据量的同步场景,一个Server与上千个Client同步,数百个同步并发操作。
如上章节4所讲,新的File Sync Provider支持与其他Providers之间进行数据格式转换,可以使用托管代码,完成转换过称。
新的File Sync Provider支持与其他的Provider(甚至非File Provider)进行同步,使用数据格式转换接口APIs,可以实现与自定义Provider或其他类型的Provider同步。
性能提升主要在已经复制的数据。
举例来说:一个文件我们已经完成了同步。当此文件发生变化后,需要重新同步时,当前文件已经复制的数据将不会再次被传送,新的File Sync Provider只会传送差异的部分,从而提高了性能。
通过这项改进,新的File Sync Provider与MSF 1.0 相比,提高了30%的性能。
旧版的File Sync Provider存在2个小缺陷,第一:遇到单个问题同步失败,可能会引起整个同步过程的终止。第二:同步失败后没有详细的错误信息。高兴的是,这两个问题都在MSF 2.0 中修复了。
新版的File Sync Provider同步更为稳定,在同步过程中,单个同步失败(哪怕是网络引起的)不会影响整个同步过程,同步将会继续进行直至全部完成,最后能够提供一个详细的错误列表。
Sync Framework 更多的信息,请点击这里查看:Sync Framework Developer Center
下载Sync Framework,请点击这里:Microsoft Sync Framework 2.0 Software Development Kit (SDK)
如果你以前没有接触过MSF,但对此有兴趣,建议你尝试使用一个同步小工具SyncToy 2.1,这是微软基于MSF 2.0 开发的一个小软件,非常好用。
SyncToy 2.1 下载请点击这里: http://www.microsoft.com/downloads/details.aspx?familyid=C26EFA36-98E0-4EE9-A7C5-98D0592D8C52&displaylang=en.
如果使用中有问题,可以到这里咨询:http://social.microsoft.com/Forums/en-US/synctoy/threads
若有MSF相关问题,请给我留言,我们一起讨论研究。