【思源新人指南】莫名其妙遇到锁定空间,提示「避免潜在的数据损坏」该怎么办

本贴最后更新于 587 天前,其中的信息可能已经渤澥桑田

思源在若干个版本之前更新后,禁止了第三方同步盘的时候,目的是防止多个进程同时读写同样的文件目录,造成数据损坏。

开发者根据接受到用户反馈出现的四个阶段:

  1. 发现同步盘问题,尝试使用文件锁解决:“先说结论:第三方同步盘可能造成数据损坏,目前因为使用同步盘带来的数据损坏问题是无法彻底解决的” https://ld246.com/article/1626537583158

  2. 发现文件锁解决不了问题:“这个不是通过代码能解决的,而是操作系统本身就不支持两个不同的进程同时安全读写同一个文件。” 于是发公告不支持第三方网盘同步: https://ld246.com/article/1664442401353

  3. 开源云端服务同步,暂时免费开放端对端加密同步,数据同步支持第三方 S3 储存 https://github.com/siyuan-note/siyuan/issues/6445

  4. 发现发了公告还是有用户使用同步盘丢数据,没办法就去做了限制 https://github.com/siyuan-note/siyuan/issues/7683

热知识 1:notion flowus 这类软件不会出现这种问题是因为他们是云笔记,根本不存在读写文件的问题。

热知识 2: obsidian logseq 这类软件同样有这个问题,但是他们不说

image.png

image.png

但是读写文件往往不光光是同步盘的问题,有时候我们就算没有开启同步盘也可能出现这种让人心肺停止的问题:

image.pngc80f0c11b57cbc4ca77d222ba3b01dcb.jpeg

不要怕!这种情况下往往是有未知的进程在读写我们的思源数据。解决方法很简单:找到这个进程,把它关掉。

热知识 2:其实不管是同步盘还是别的进程,他们造成思源文件系统读写错误的原因本质是一样的,都是这些的进程(程序)同时在和思源争抢数据文件的读写权限,造成了冲突。

同步盘会时时刻刻去监听麾下的文件系统,所以往往是导致思源文件系统冲突的罪魁祸首——但这并不代表着其他软件不会造成这种问题。只不过大部分软件不会闲着没事跑到你的数据目录下读写,既然他们都不会来淌这篇雷池,自然不会炸雷。

但是倘若就是有那么个别的进程闯了进来,嘿——那也确实有可能触发冲突的问题。

热知识 3:你可能会有些抱怨这种莫名其妙的设定。但是以前确实发生过别的同步盘进程和思源抢夺读写数据——最后导致用户数据损害的案例。这是 windows 设计的锅,没法避免。所以开发者只能采用这种比较保守的做法,一旦检测到有别的进程正在占用,就直接锁定发出警告,从而避免文件损害的可能。

方法 1:powertoy

  1. 安装 powertoy 软件,这是微软官方提供的一个 windows 工具软件

  2. 打开 powertoy,启用 File Locksmith

    image.png

  3. 找到你工作目录的文件夹,右键点击「使用此文件的进程」

    image.png

  4. 原来是 utools 在使用我们的文件

    image.png

  5. 不建议直接点击「结束进程」,可能会存在意外的问题,最好是通过正常的方法关闭软件。

    我正常关闭了 Utools 之后,现在只有一个文件管理器了,这回就没事了

    image.png

方法 2:windows 资源管理器

如果你不想要下载一个额外的软件,还有一个更加原生的方案。

首先打开 windows 的资源管理器,然后打开「资源监视器」

image.png

点开之后,在 CPU 一页的下方,选择「搜索句柄」,并把疑似被工作空间的目录的路径填进去

image.png

稍等片刻之后,就可以看到所有占用了这个目录的进程,找到那些不属于思源的进程,然后把对应的程序关掉。

image.png

同样,非常不推荐直接在资源管理器里结束进程,更好的做法是

  1. 记下进程对应的 PID
  2. 在资源管理器当中找到对应 PID 的程序,然后通过正常方式关掉

image.png

注意,实测发现资源管理器有时候反而还不如 Powertoy 准确,如果你用方法 2 始终发现不了占用,但是思源一直提醒有文件读写 xowu,不妨使用方法 1 试一下。

  • 思源笔记

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

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

    25984 引用 • 107779 回帖

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • 还有一个使用资源监视器的方案:

    Windows + S 搜索 资源监视器 并打开

    在资源监视器 CPU 页签中的 关联的句柄 子面板搜索 < 思源工作空间目录名称 >, 也能查询到具体是哪些程序占用了该目录下的文件

  • 91editor 1 评论 via macOS

    妈耶,MAC 哭瞎在厕所,咋整噢

    lsof 命令? 这个 linux 可以用,mac 是 unix 我不知道能不能用。
    Frostime
  • 这个真不错,感谢

  • 同步问题遇到的人很多,定期自顶一下防沉。

  • sasser 1 1 赞同

    热知识:Obsidian 允许使用第三方同步盘,没有遇到类似问题。obsidina 不是云笔记,除了这个应该也有其他的笔记支持网盘同步。

    热知识 2:出现文件读写错误,并不一定是跟 siyuan 同时争抢读写权限,siyuan 放在后台没有操作也会这样,此时刻 siyuan 并不一定真打算写入数据

    因为 siyuan 会持续监听是否被其他进程打开了,一直在不断的创建文件 check_consistency,然后重命名文件,删除文件,对磁盘 IO 读写

    代码见:https://github.com/siyuan-note/siyuan/blob/master/kernel/util/runtime.go#L173

    热知识 3:就算有锁定检查,保守的做法应该是重试、延时重试,或者弹框提示用户,而不是直接退出

    用的时间过去比较久了,以上情况可能有变化,说得不对之处请见谅

    2 回复
  • 对,2 是更严谨的说法,3 确实有道理,我也觉得直接退出有点激进了。

    至于 ob 那个属于我知识盲区了,可能是数据结构和同步原理不一样?这个就属于比较深入的技术细节了。

    思源的做同步面临的问题比 Ob 要复杂,一个是底层的数据结构完全不同,另一个是思源相比单纯的同步还多了一大堆数据快照端到端加密之类的东西,文件 IO 需求可能会更密集一些。

    1 操作
    Frostime 在 2023-06-28 23:17:04 更新了该回帖
  • Miobowl via macOS

    Mac 还是隔一会儿就遇到这个问题

    1 回复
  • QHS

    微信截图 20230906100524.png

    没有占用还被锁,哭都没地方哭

    重启无效,重装无效,直接打不开,微软商店安装的

    突然这样

  • bluove

    那我用各种同步盘,同时用 word, ppt, wps, 等等软件打开创建修改文件,怎么没报错?

    合着只要用同步盘,同步盘里面的文件就都不能被打开创建修改了???

    这个帖子把锅都甩给操作系统,何必如此? 不就是想收钱吗,逼迫用户为 wdav,S3 同步方式付费。思源已经声明 wdav,S3 同步即将要收费了,虽然也不贵,48 元终身支持。

    3 回复
  • 谁给你说可以类比 word ppt 了?他们原理机制和思源一样吗?他们读写文件系统的频率和思源一样吗?

    不是我把锅甩给操作系统,而是长期的事件证明了就是系统的问题

    开发者根据接受到用户反馈出现的四个阶段:

    1. 发现同步盘问题,尝试使用文件锁解决:“先说结论:第三方同步盘可能造成数据损坏,目前因为使用同步盘带来的数据损坏问题是无法彻底解决的” https://ld246.com/article/1626537583158

    2. 发现文件锁解决不了问题:“这个不是通过代码能解决的,而是操作系统本身就不支持两个不同的进程同时安全读写同一个文件。” 于是发公告不支持第三方网盘同步: https://ld246.com/article/1664442401353

    3. 开源云端服务同步,暂时免费开放端对端加密同步,数据同步支持第三方 S3 储存 https://github.com/siyuan-note/siyuan/issues/6445

    4. 发现发了公告还是有用户使用同步盘丢数据,没办法就去做了限制 https://github.com/siyuan-note/siyuan/issues/7683

    不明白背后的原因可以去问、可以去讨论,而不是直接妄自推断前因后果,然后拿着未加检验的猜想大放厥词。

    你觉得你自己仿佛很聪明,看透了事实的“真相”;但在实际上知道是怎么回事的人看来,可能像个莫名其妙的 xx(我给你基本的尊重,手动和谐)

    以上为给你的所有回复,你要觉得我侮辱你可以抗议,但是我不会继续回复你的。

    1 回复
  • temacc0531

    所有的软件都有这个问题,只要读写文件的频率够高,你举的软件例子一样会

    当然你可能只相信自己所认为的,嗯,自重

    1 操作
    temacc0531 在 2023-11-08 11:54:29 更新了该回帖
  • 这是放在 onedrive 里的 xlsx 文件,修改后保存同步,然后 WPS 在同步时打开显示的锁定。并不是不存在,只是你没遇到罢了。

    9c1c705c16948991a653e6e6604050a2.png

    aabccd411e09c13ef75c75833769af3d.png

  • bluove

    你说得对。任何同步盘、云盘、onedrive 等等下面的文件,都不能用。你宣布:同步盘云盘是反人类设计,同步盘云盘下的文件大多数时候都不能被打开、创建、修改、编辑。

  • soltus 1 评论

    怎么现在还没解决。。。

    操作系统的特性
    JeffreyChen
  • wfliuhao

    按照上面的方法看了下,没有进程占用,那怎么办?

    1 回复
  • 不行的话就手动迁移工作空间(我是这样解决的)

  • Bishan

  • jjjiii

    占用进程就只有 explorer,还是被锁,无法打开

  • powcai940606

    我 windows 也是一样

  • AXIOM via macOS

    一个最简单入门的文件锁问题都搞不定。。。

    你这个结论岂不是说 word excel 都不能用 onedrive,自己打自己脸

    另外 vim, vscode,CLion 都不能打开操作云盘下代码和文件了?? 太扯了

  • mmxdm

    同步工具一般只有一个端在用吧。就算写也是同步的时候(此时不打开思源),同步完成,打开思源进行编辑,第三方同步工具读(不会写)。感觉这样流程,是不是不会导致这个问题?为啥“第三方 S3 数据同步和备份”和“官方数据同步和备份”就没问题呢,不是很懂

  • lg123666 1 评论

    可以避免软件频繁退出吗?公司电脑有安全软件,可能没有办法避免扫描

    后面解决了。。查看校验文件:data.siyuan\filesys_status_check 及下面文件的读写权限,之前是没有写入权限,导致频繁退出
    lg123666
  • lg123666

    请问可以避免软件频繁的检测吗?自动退出次数太多,实在受不了

    1 回复
  • 大概避免不了吧?或者你可以试试用手机伺服到电脑通过浏览器访问

    1 回复
  • lg123666

    后面解决了。。查看校验文件:data.siyuan\filesys_status_check 及下面文件的读写权限,之前是没有写入权限,导致频繁退出

  • lg123666

    对于这个监听进程有什么比较好的解决方法吗?

  • image.pngimage.png

    一样的问题,我输入的是思源的工作空间,搜到是只有资源管理器的进程咋整?

请输入回帖内容 ...

推荐标签 标签

  • Sandbox

    如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

    435 引用 • 1238 回帖 • 588 关注
  • JavaScript

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

    730 引用 • 1281 回帖 • 4 关注
  • RYMCU

    RYMCU 致力于打造一个即严谨又活泼、专业又不失有趣,为数百万人服务的开源嵌入式知识学习交流平台。

    4 引用 • 6 回帖 • 58 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 84 关注
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 65 关注
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 73 关注
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 605 关注
  • FlowUs

    FlowUs.息流 个人及团队的新一代生产力工具。

    让复杂的信息管理更轻松、自由、充满创意。

    1 引用 • 7 关注
  • 阿里巴巴

    阿里巴巴网络技术有限公司(简称:阿里巴巴集团)是以曾担任英语教师的马云为首的 18 人,于 1999 年在中国杭州创立,他们相信互联网能够创造公平的竞争环境,让小企业通过创新与科技扩展业务,并在参与国内或全球市场竞争时处于更有利的位置。

    43 引用 • 221 回帖 • 58 关注
  • 电影

    这是一个不能说的秘密。

    122 引用 • 608 回帖 • 1 关注
  • HTML

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

    108 引用 • 295 回帖
  • 开源中国

    开源中国是目前中国最大的开源技术社区。传播开源的理念,推广开源项目,为 IT 开发者提供了一个发现、使用、并交流开源技术的平台。目前开源中国社区已收录超过两万款开源软件。

    7 引用 • 86 回帖
  • Love2D

    Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。

    14 引用 • 53 回帖 • 557 关注
  • 职场

    找到自己的位置,萌新烦恼少。

    127 引用 • 1708 回帖
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    167 引用 • 597 回帖
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    20 引用 • 245 回帖 • 231 关注
  • RIP

    愿逝者安息!

    8 引用 • 92 回帖 • 404 关注
  • Swift

    Swift 是苹果于 2014 年 WWDC(苹果开发者大会)发布的开发语言,可与 Objective-C 共同运行于 Mac OS 和 iOS 平台,用于搭建基于苹果平台的应用程序。

    34 引用 • 37 回帖 • 552 关注
  • 分享

    有什么新发现就分享给大家吧!

    248 引用 • 1794 回帖 • 2 关注
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖 • 4 关注
  • CodeMirror
    2 引用 • 17 回帖 • 167 关注
  • Notion

    Notion - The all-in-one workspace for your notes, tasks, wikis, and databases.

    10 引用 • 77 回帖 • 1 关注
  • CSS

    CSS(Cascading Style Sheet)“层叠样式表”是用于控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。

    198 引用 • 543 回帖 • 1 关注
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    693 引用 • 537 回帖
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖
  • JWT

    JWT(JSON Web Token)是一种用于双方之间传递信息的简洁的、安全的表述性声明规范。JWT 作为一个开放的标准(RFC 7519),定义了一种简洁的,自包含的方法用于通信双方之间以 JSON 的形式安全的传递信息。

    20 引用 • 15 回帖 • 26 关注
  • Kotlin

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

    19 引用 • 33 回帖 • 79 关注