• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# 同应用跨设备数据同步概述
2<!--Kit: ArkData-->
3<!--Subsystem: DistributedDataManager-->
4<!--Owner: @baijidong-->
5<!--Designer: @widecode; @htt1997; @dboy190-->
6<!--Tester: @yippo; @logic42-->
7<!--Adviser: @ge-yafang-->
8
9
10## 场景介绍
11
12跨设备数据同步功能(即分布式功能)指将数据库中的数据同步到组网环境中的其他设备。该功能常用于在可信认证的不同设备间自由同步、修改和查询用户应用程序数据。
13
14例如:当设备1上的应用A在分布式数据库中增、删、改数据后,设备2上的应用A也可以获取到该数据库变化。可在分布式图库、备忘录、联系人、文件管理器等场景中使用。
15
16不同应用间订阅数据库变化通知,请参考[跨应用数据共享](data-share-overview.md)实现。
17
18根据跨设备同步数据生命周期的不同,可以分为:
19
20- 临时数据生命周期较短,通常保存到内存中。比如游戏应用产生的过程数据,建议使用分布式数据对象。
21
22- 持久数据生命周期较长,需要保存到存储的数据库中,根据数据关系和特点,可以选择关系型数据库或者键值型数据库。比如图库应用的各种相册、封面、图片等属性信息,建议使用关系型数据库;图库应用的具体图片缩略图,建议使用键值型数据库。
23
24
25## 基本概念
26
27在分布式场景中,会涉及多个设备,组网内设备之间看到的数据是否一致称为分布式数据库的一致性。
28
29
30分布式数据库一致性可以分为强一致性、弱一致性和最终一致性。
31
32
33- 强一致性:是指某一设备成功增、删、改数据后,组网内任意设备可立即读取数据获得更新后的值。
34
35- 弱一致性:是指某一设备成功增、删、改数据后,组网内设备可能读取到本次更新后的数据,也可能读取不到,不能保证在多长时间后每个设备的数据一定是一致的。
36
37- 最终一致性:是指某一设备成功增、删、改数据后,组网内设备可能读取不到本次更新后的数据,但在某个时间窗口之后组网内设备的数据能够达到一致状态。
38
39
40强一致性对分布式数据的管理要求非常高,在服务器的分布式场景中可能会遇到。由于移动终端设备具有不常在线且无中心的特点,所以同应用跨设备数据同步仅支持最终一致性。
41
42
43## 跨设备同步访问控制机制
44
45数据跨设备同步时,数据管理基于设备等级和数据安全标签进行访问控制,具体可见[跨设备同步访问控制机制](access-control-by-device-and-data-level.md#跨设备同步访问控制机制)。
46
47## 相关实例
48
49针对分布式开发,有以下相关实例可供参考:
50
51- [分布式组网认证(ArkTS)(Full SDK)(API10)](https://gitcode.com/openharmony/applications_app_samples/tree/master/code/SystemFeature/DistributedAppDev/DistributedAuthentication)