又消失了两个笔记本组,心累了...... 昨天刚求助完

本贴最后更新于 200 天前,其中的信息可能已经东海扬尘

昨天刚求助完,无果,一条条重新搬运回来一组丢失的笔记。
今天有凭空消失了两组...........为什么会这样子?

43a69cfcbe40c43c46410a193778188.png

fc6e9dd520934e90aaac83bce8ece27.png

image.png

  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    23014 引用 • 92569 回帖
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    8447 引用 • 38479 回帖 • 155 关注
优质回帖
  • ringx 1 赞同

    第一个还好吧,一个「馊主意」是在思源软件本地内支持一个「webdav」把读写交给他,sync 本地的目录作为 webdav 的目录。这样问题就又变成一个 web 问题了,可以避开不同平台、系统的文件 api 了,反正笔记内置了一个 http 服务器的。

    第二个的话,我之前本来也想提的,后来想想没啥必要(虽然我常用的 DevonThink 可以支持多个备份源的)。我是一开始用 webdav,后来加了一个 s3,发现只能 enable 一个。这个倒不是什么大问题,也没必要搞那么多备份。

  • ringx 1

    可以在「已关闭笔记本」那个文案最右边显示笔记本数量。并且可以弄一个带灰色背景的数字。

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • 可以上传日志看看,然后消失的应该可以在数据历史中找回

  • 建议先别编辑了,然后关闭同步功能、导出 Data 备份。再上传日志等待回复

  • 88250

    请在 设置 - 关于 中导出系统日志上传。

  • LEO1234 1 评论

    systemlog.zip

    在这里,谢谢大神们

    @88250 看看日志
    JeffreyChen
  • @88250 你看下面这部分日志,我没理解错的话其中 4c827840449d866259f84b299d35df66d890f4c2, files=4046, size=6.35 GB, created=2024-06-04 00:04:48 创建时间是 00:04:48 他覆盖了 [722f0d7f0bfe73867c960fef2ace822c04dd183a] files [4057] ,往上翻看到 I 2024/06/04 00:11:34 ref.go:64: updated local latest to [device=b292b2e7-0dee-4d87-9d0b-ff287716c1c7/windows, id=722f0d7f0bfe73867c960fef2ace822c04dd183a, files=4057, size=6.36 GB, created=2024-06-04 00:11:34] 创建于 00:11:34,这里创建时间较早的覆盖来创建时间更晚的是不是有问题

    I 2024/06/04 00:11:37 sync.go:221: got local latest [722f0d7f0bfe73867c960fef2ace822c04dd183a] files [4057]
    I 2024/06/04 00:11:37 sync.go:1454: got latest sync [device=b292b2e7-0dee-4d87-9d0b-ff287716c1c7/windows, id=4c827840449d866259f84b299d35df66d890f4c2, files=4046, size=6.35 GB, created=2024-06-04 00:04:48]
    I 2024/06/04 00:11:37 sync.go:228: got latest sync [4c827840449d866259f84b299d35df66d890f4c2] files [4046]
    
    1 回复
  • 有点可怕啊。。。

    感觉左上角的 ☁️ 同步按钮有必要增加「同步到本地」的方式欸,可以在出问题时保存一份数据起来先。哪怕失败了也可以重新开始一份笔记,方便本地拷贝也迁移。

    有一些其他软件支持这样的,比如 DevonThink 可以 webdav/icloud 之外还可以 sync 到 local storage。

    1 回复
  • 但是思源本身就有数据快照和单向同步啊。

    1 回复
  • 我的意思是,就像这个楼主遇到的情况,有可能触发了某些「诡异」,让他正在经历丢数据的痛苦中。

    如果我遇到这种情况,那么会「导出」一份数据,然后把原来的「笔记软件」和「笔记数据」全删除了,然后重新安装一份,从本地 sync 回来。

    而且支持 sync 到本地,那么我的 google drive 和 icloud 也可以用来备份数据了。这个也是我使用了很多笔记软件它们的套路,非常适合小白用户的。


    你看,我这样想对不对。如果有时候因为插件,或者逻辑缺陷,导致思源笔记在做一些错误的数据删除,那么此时你的数据是"绝对不安全"的。因为本地的修改会被同步到 s3 云上,云上的数据也会经历删除。

    那么我作为一个用户第一步应该先本地备份一下我的数据,再排查问题。这样我只要保证第一份备份在,数据总有回复的一天。

    在出故障的时候,就不太能相信软件内的快照了。

    3 回复
    3 操作
    ringx 在 2024-06-04 23:27:22 更新了该回帖
    ringx 在 2024-06-04 23:26:42 更新了该回帖
    ringx 在 2024-06-04 23:25:57 更新了该回帖
  • 第一步应该是关闭同步功能,然后在其他客户端标记快照并上传云端

  • 快照里的数据不会被删的

  • 88250

    第二个截图中 数据历史 - 已删除的笔记本 时间是 3 号 20:07:54,在日志中找到了对应的记录:

    I 2024/06/03 20:07:54 mount.go:145: removed box [20240603200211-y9bkbgw]
    

    说明是人为手动删除的。


    今天凌晨最后一份快照 2f4aae289b0068d371ab09aac5752e2c4a7ae26f,文件数量是 4062

    I 2024/06/04 01:11:09 ref.go:50: got local latest [device=b292b2e7-0dee-4d87-9d0b-ff287716c1c7/windows, id=2f4aae289b0068d371ab09aac5752e2c4a7ae26f, files=4062, size=6.37 GB, created=2024-06-04 01:01:31]
    ...
    I 2024/06/04 01:11:10 sync.go:1581: got cloud latest [device=b292b2e7-0dee-4d87-9d0b-ff287716c1c7/windows, id=2f4aae289b0068d371ab09aac5752e2c4a7ae26f, files=4062, size=6.37 GB, created=2024-06-04 01:01:31]
    

    这次同步后就退出程序了,今天早上 10 点第一次同步是本地快照和云端快照都没有变,还是 2f4aae289b0068d371ab09aac5752e2c4a7ae26f,从这以后一直到日志结束,文件数量没有变化过,一直是 4062,并且日志中没有出现 local remove,即这段时间内本地没有删除过任何文件,所以文件数量没有变化。

    截图中楼主描述有两个笔记本不见了,我猜测是被关闭了,建议在 已关闭的笔记本中 找一下。

    1 回复
  • 88250

    你再仔细看下,是 722f0d7f0bfe73867c960fef2ace822c04dd183a 覆盖的 4c827840449d866259f84b299d35df66d890f4c2

  • 88250

    每一次同步都会产生一个数据快照,数据可以回滚到任何一次同步之前或之后。

    只要数据仓库没有被外部损坏,数据快照可以完全相信,这是同步机制的基石。

    1 回复
  • OK,了解,但是希望也考虑考虑同步到本地的方式。感觉这样的话你们也不用再去考虑其他什么云的 api 了,可以瞬间支持各种云备份了~ 搞各种像什么坚果云什么云的他们的 webdav,还是有点门槛的~

    我还没有使用过快照回滚的功能,现在是在服务器上定时任务做文件夹快照的 😂 ,这样看起来有点多余了~

    1 回复
  • 88250

    设置 - 导出 - 导出 Data

    或者关闭思源后手动复制整个工作空间文件夹备份。

    1 回复
  • 复制整个工作文件夹又都是明文的内容,导出的话只能算是备份的一种方式吧。

    为啥不复用现在的 sync 逻辑呢?理论上就是把文件的 api 上传下载换成文件系统的写入读取吧,这个应该更容易才对。背后用 google drive,icloud 之类的客户端做云备份。


    突然有了一个点子,我之前提到的一个关于笔记本加密的: 可不可以考虑支持对单个笔记本加密?

    这种「加密的笔记本」是不是可以总是「优先」从“sync”的目标读取,然后所有数据都放在内存中,这样就解决明文保存的问题了。 因为 “sync”的目标总是加过密,只要解密之后的笔记本不落盘就可以了

    不行,对于「笔记本的上锁」的目的是打开笔记本的时候需要「输入密码」。

    1 回复
    2 操作
    ringx 在 2024-06-05 00:13:37 更新了该回帖
    ringx 在 2024-06-05 00:13:15 更新了该回帖
  • 88250

    文件系统多进程并发读写同一个文件很容易报错的。另外,同步仅支持设置一个存储,不支持设置多个。

    1 回复
  • ringx 1 赞同

    第一个还好吧,一个「馊主意」是在思源软件本地内支持一个「webdav」把读写交给他,sync 本地的目录作为 webdav 的目录。这样问题就又变成一个 web 问题了,可以避开不同平台、系统的文件 api 了,反正笔记内置了一个 http 服务器的。

    第二个的话,我之前本来也想提的,后来想想没啥必要(虽然我常用的 DevonThink 可以支持多个备份源的)。我是一开始用 webdav,后来加了一个 s3,发现只能 enable 一个。这个倒不是什么大问题,也没必要搞那么多备份。

  • Zsiyuan

    如果是 Windows 的话,实在不行写个 Bat 脚本每天凌晨四点自动把工作目录压缩备份一下算了,我就是这么做的。😂

    1 回复
  • 哇,这样的话数据会爆炸吧,都是全量备份。(我发现我还没有迁移完笔记,目录就有 500 多 M 了,不过 temp 比较大,没必要备份 🤣)

    全量备份不需要这么频繁吧~ 还是得依赖快照做增量~

    1 回复
  • Zsiyuan

    还好吧,可能我的笔记比较小,NAS 里现在有 200+ 天的备份了,也才 70 多 G。我设置的是最多 365 个备份,多出来的会删除最早的那个备份,而且实在放不下也可以手动删除的嘛。😂

    1 回复
  • 参考参考我的方案:

    我是在 NAS 上启用了 webdav,然后让思源笔记同步到那个 webdav 的;然后在 NAS 上对那个 webdav 目录做快照,一小时一个~

    1 回复
  • Zsiyuan

    多谢,看起来是比我的方案灵活很多,用了这么长时间群晖,还真没用过快照功能,😂 我去了解一下。👍

  • 这种问题,大部分都是误操作或者本地问题,按 D 大的看看已关闭笔记本吧。

  • LEO1234

    真的,找到了!!谢谢你!!下次怎么避免出现这种情况呀,是不是因为多端同步的问题?

    image.png

    1 回复
  • 88250

    和多端同步没有关系,建议看看是不是思源运行期间使用了第三方软件进行实时备份,或者有其他软件读写了笔记本/.siyuan/conf.json 导致笔记本配置文件损坏。

    2 回复
  • 不过有个交互可以改进一下,就是关闭笔记本有个弹窗提示一下,给个确认,并提示可以在已关闭笔记本里找到。

    1 回复
  • 88250

    笔记本配置文件损坏的情况还需要看看原因,先不加提示了。

    1 回复
  • ringx 1

    可以在「已关闭笔记本」那个文案最右边显示笔记本数量。并且可以弄一个带灰色背景的数字。

    1 回复
  • 88250

    是个好主意,先记录 Issue #11648 · siyuan-note/siyuan

  • LEO1234

    没用三方软件备份,倒是开通了华为云 S3 同步,只是会在平板上老出错。

    1 回复
  • 88250

    发一下平板的日志。

    1 回复
  • 3Woods 1 评论

    @88250 我有一个主意,就是思源同步能否设置多个同步点,其中一个为主同步的,执行双向同步。其余的为备份点,只进行全量备份,保留一定数量的数据备份(可由用户设定,比如 3 条、5 条)。然后在云同步时或者空闲多久以后执行一次备份。

    1 回复
    好主意呀,这个方法实现简单,逻辑原理可靠。从根子上可以挽救多端同步错误。
    bpLzUuLylDBLqy5o
  • 88250

    我没看懂……

    1 回复
  • LEO1234

    整个软件删掉了.....暂时不敢在平板上用了,闪退几率也高,基本无法正常使用,手机端倒是挺稳定得

  • LEO1234

    **啊!我可能找到问题了!!**在知乎上看到的。我最近在折腾平板的实时同步问题。

    我平板端同步数据的时候,会出现出错中断的情况,我一般是立马退出软件打开继续同步,如此反复。
    但同时我电脑上的软件是没有关闭的,而且还在编辑的状态,每隔一段时间又会更新一次云端数据。

    而平板在没完全将云端完整的数据同步完的情况下,又被我反复强制同步,导致移动端笔记残缺的状态被当做是我更新文件后的状态,一并上传到云端,覆盖了云端完整的数据

    冲突的文件就被自动放进“关闭的笔记本里”

    是这个原理吗?

    image.png

    1 回复
  • 额,就是说可以设置多个同步点(A、B、C),比如 A 使用思源官方的同步,作为主同步点,就跟现在正常的同步一样,可以执行双向同步,本地的增删改在 A 上也会同步。而 B、C 只作为备份点,可以用 S3、WebDav、本地目录等,对本地数据做全量压缩备份,B、C 上会保留多个备份,但不是像 A 那样实时同步每一次增删改,而是只打包上传每次最新的本地数据。这样子就可以实现多地多中心备份了,避免因为本地或者云端数据损坏同步至多端上,导致数据全部损坏无法找回,一旦本地或云端数据出现故障,用户可以自行从 B、C 上获得最近的全量备份进行恢复。虽然这个也可以自己通过其他计划程序在后台实现,但是如果要确保数据安全,就要退出思源然后操作,所以如果官方能够支持是最好的,也能避免像讨论中说的那样多个进程同步读写工作空间导致数据损坏。

    或者也可以像 ringx 说的那样:

    第一个还好吧,一个「馊主意」是在思源软件本地内支持一个「webdav」把读写交给他,sync 本地的目录作为 webdav 的目录。这样问题就又变成一个 web 问题了,可以避开不同平台、系统的文件 api 了,反正笔记内置了一个 http 服务器的。

    第二个的话,我之前本来也想提的,后来想想没啥必要(虽然我常用的 DevonThink 可以支持多个备份源的)。我是一开始用 webdav,后来加了一个 s3,发现只能 enable 一个。这个倒不是什么大问题,也没必要搞那么多备份。

    作者:ringx
    链接: 又消失了两个笔记本组,心累了...... 昨天刚求助完 - ringx 的回帖
    来源:链滴
    协议:CC BY-SA 4.0 https://creativecommons.org/licenses/by-sa/4.0/

    这样同步到本地多一个全量备份,然后用户再通过其他程序去读写这个本地的备份目录进行其他备份,而不读写思源的工作空间。

    1 回复
  • 那你这完全是未定义行为了,出现什么情况都有可能。

    另外,实时同步听上去就像是你使用了第三方程序进行读写操作……

  • 88250

    目前的多端同步已经是多中心备份了,其他设备可以选择单向同步作为备份,也支持手动快照。

请输入回帖内容 ...

推荐标签 标签

  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    728 引用 • 1273 回帖 • 1 关注
  • 外包

    有空闲时间是接外包好呢还是学习好呢?

    26 引用 • 232 回帖
  • Bootstrap

    Bootstrap 是 Twitter 推出的一个用于前端开发的开源工具包。它由 Twitter 的设计师 Mark Otto 和 Jacob Thornton 合作开发,是一个 CSS / HTML 框架。

    18 引用 • 33 回帖 • 667 关注
  • IBM

    IBM(国际商业机器公司)或万国商业机器公司,简称 IBM(International Business Machines Corporation),总公司在纽约州阿蒙克市。1911 年托马斯·沃森创立于美国,是全球最大的信息技术和业务解决方案公司,拥有全球雇员 30 多万人,业务遍及 160 多个国家和地区。

    17 引用 • 53 回帖 • 140 关注
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖 • 2 关注
  • Electron

    Electron 基于 Chromium 和 Node.js,让你可以使用 HTML、CSS 和 JavaScript 构建应用。它是一个由 GitHub 及众多贡献者组成的活跃社区共同维护的开源项目,兼容 Mac、Windows 和 Linux,它构建的应用可在这三个操作系统上面运行。

    15 引用 • 136 回帖 • 1 关注
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 63 关注
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    209 引用 • 358 回帖
  • 架构

    我们平时所说的“架构”主要是指软件架构,这是有关软件整体结构与组件的抽象描述,用于指导软件系统各个方面的设计。另外还有“业务架构”、“网络架构”、“硬件架构”等细分领域。

    142 引用 • 442 回帖 • 1 关注
  • 工具

    子曰:“工欲善其事,必先利其器。”

    288 引用 • 734 回帖 • 2 关注
  • 大疆创新

    深圳市大疆创新科技有限公司(DJI-Innovations,简称 DJI),成立于 2006 年,是全球领先的无人飞行器控制系统及无人机解决方案的研发和生产商,客户遍布全球 100 多个国家。通过持续的创新,大疆致力于为无人机工业、行业用户以及专业航拍应用提供性能最强、体验最佳的革命性智能飞控产品和解决方案。

    2 引用 • 14 回帖 • 2 关注
  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    107 引用 • 295 回帖
  • 导航

    各种网址链接、内容导航。

    42 引用 • 175 回帖
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖 • 1 关注
  • 阿里云

    阿里云是阿里巴巴集团旗下公司,是全球领先的云计算及人工智能科技公司。提供云服务器、云数据库、云安全等云计算服务,以及大数据、人工智能服务、精准定制基于场景的行业解决方案。

    89 引用 • 345 回帖 • 1 关注
  • GitHub

    GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

    210 引用 • 2036 回帖
  • 钉钉

    钉钉,专为中国企业打造的免费沟通协同多端平台, 阿里巴巴出品。

    15 引用 • 67 回帖 • 335 关注
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    53 引用 • 37 回帖 • 3 关注
  • Gitea

    Gitea 是一个开源社区驱动的轻量级代码托管解决方案,后端采用 Go 编写,采用 MIT 许可证。

    4 引用 • 16 回帖
  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 559 关注
  • Wide

    Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。

    欢迎访问我们运维的实例: https://wide.b3log.org

    30 引用 • 218 回帖 • 635 关注
  • CloudFoundry

    Cloud Foundry 是 VMware 推出的业界第一个开源 PaaS 云平台,它支持多种框架、语言、运行时环境、云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的问题。

    5 引用 • 18 回帖 • 172 关注
  • 自由行
    4 关注
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    167 引用 • 1520 回帖
  • gRpc
    11 引用 • 9 回帖 • 69 关注
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4601 回帖 • 700 关注