前言
各位,小小透露一下,温知文档,免费上线,欢迎使用。
之前跟大家讨论了富文本的实现,今天的主题是,git同步在笔记软件中的作用,优缺点,及其实现方案。
同步方案
笔记软件首先要保障数据安全问题,作为个人开发者,搭建私有服务确实很难赢得信任。
于是我就探索一种相对安全,并且支持笔记同步备份的实现方式,网络上通用的方案有网盘webdav、ftp、对象存储等等。
但这些方案有些问题,无法避免笔记冲突的问题,以及没有一个比较好的服务去存储。
对于网盘存储,会产生太多奇怪的文件,导致文件污染;对于ftp则需要自己部署服务,比较麻烦;对于对象存储,价格有点不亲民。
git同步优缺点
当我发现同行有用git同步笔记的方案之后,我就想我能不能实现git同步笔记?git同步笔记有以下几点好处:
1.数据安全,git同步通过ssh加密同步,非常安全
2.技术成熟,传统行业非常稳定成熟的技术
3.天然支持历史版本,一旦提交更新,则永远的存在于历史文件中,随时可以回滚版本
4.社区资源丰富,无论是国内还是国外,都有对应的公共服务,一方面可以分享内容,一方面可以帮助用户存储内容
5.支持自动化部署,例如将笔记存到git服务器,通过脚本自动部署网页
当然,凡是都有其2面性,缺点也是存在的:
1.操作会有一定的门槛,只有程序员才比较熟练
2.大文件同步会导致内存较高,因为即使删除后,文件还是存在历史版本长河中
3.实现冲突处理比较困难
具体实现方案
在了解其优缺点后,我断然忽略其缺点,因为缺点可以解决,进而埋头苦干2个月,实现了这个功能。
通过调查发现,有以下方式可以实现git同步:
1.通过git命令行,调用git命令
2.通过开源库,自己实现具体功能
我尝试过git命令实现,发现有些信息获取还是需要开源库实现,于是我就采用开源库的方式。
java有成熟的jgit,而flutter却没有对应的库,然我头痛了一段时间。
后来找到了go-git开源库,于是我就尝试学习flutter调用go语言。
flutter调用go语言,需要先将go生成动态库,然后再通过flutter的ffi库来调用。
然后通过搜索,找到了flutter_go_bridge库,借用了一下这个去实现。
最终实现方案就是通过flutter和go语言联调的方式实现了,资源如下:
flutter-go-bridge
go-git
通过git同步还需要解决以下2个问题:
1.大文件同步问题
2.文档内容冲突处理
对于第1个问题,使用图床方式存储文件即可。
对于第2个问题,就比较麻烦了,需要彻底搞懂git同步逻辑,在这里给大家贴个git同步流程图:
其实主要冲突阶段在于push和pull或者clone阶段,只需要在此阶段实现文档差异对比即可
总结
最终还是实现了这个功能,希望可以帮助到各位= =