android - 类似Evernote多客户端与服务器同步数据的最佳方案?
黄舟
黄舟 2017-04-17 11:39:52
0
4
632

这里说的同步是:
手机App内有一个sqlite的数据库,以便他离线时可以增加一些数据,例如拍的照片以及写的文字等.
当联网时,自动把离线时写的东西提交给服务器
同时,如果用其他客户端改变的旧内容或删除了旧文章,那么在App里也做出对应的修改和删除,保证本地App与服务器始终是一模一样的

目前采取的方案是按最后修改时间来做处理,如果ID相同的项目,始终以修改时间最新的那个作为标准,
如果App本地数据库出现有服务器不存在的项目,那么就把本地的删除.

可有其他更优的方案实现类似Evernote的多客户端同步?

黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全員に返信 (4)
Ty80

删除的逻辑有问题

如果本地创建了新项目,服务器是肯定没有的,而本地的就被删除了。

当一个项目被删除时,数据库内仍然应该留有【ID=xx被删除】的删除记录;只要没有这个删除记录,就是新增的记录。若干天后可以清理老的删除记录;天数取决于你认为多长时间所有客户端都会同步一次。

多个客户端在离线状态下改变了同一个文件可能造成冲突

Dropbox的处理方法是复制出一个conflict copy文件。 我还是偏好覆盖为最新版本,并在服务器保留历史版本若干天。

不过,要判断谁是【最新版本】并不容易。在网络上,你不能保证时钟是同步的。时区的问题容易解决,使用UTC就行。即使如此,UTC绝对时间也无法保证精确。

いいねを押す+0
    Ty80

    请看 知乎上的回答

    http://www.zhihu.com/question/20238731

    作者 Wayde Tse http://www.zhihu.com/people/waydetse

    いいねを押す+0
      Peter_Zhu

      自己没有动手试过,但是也许可以试一下类似Git的同步方式?commit和update分离。 服务器端记录所有的更新/提交信息,客户端记录从上一次的同步时间(如果有的话)后最终的修改记录(添加/删除应该是一样的),然后客户端把修改记录发给服务器(同一账户的多客户端可以通过消息队列的方式排队进行更新),当然,只有最后一个commit后发送更新请求的客户端能获得全部更新

      当然,遗留问题就是指向同一个文件的不同修改造成的冲突的问题,没想好该怎么处理……要不和git一样提醒用户自己手动解决?

      いいねを押す+0
        伊谢尔伦

        要判断谁是【最新版本】并不容易。在网络上,你不能保证时钟是同步的。
        目前我改成所有更新到服务器的数据,都用服务器时间来更新时间戳,然后将该时间返回给客户端,客户端修改自己数据的时间跟服务器上一样

        いいねを押す+0
          最新のダウンロード
          詳細>
          ウェブエフェクト
          公式サイト
          サイト素材
          フロントエンドテンプレート
          私たちについて 免責事項 Sitemap
          PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!