谈谈个人目前使用思源的一些体验和感受

就个人而言,目前思源插件的生态建设乏善可陈,在繁荣程度和好用上略有缺乏。但这也许是因为思源本身基础完善、功能多样,使得大多数能力开箱即用,而无需通过插件来完善。谈几点个人感受:

  1. 稳定性较差。这倒不是说插件本身造成了破坏,或者易于崩溃等,而是说插件机制在使用上不够灵敏高效,部分插件的禁用开启不能立即生效,甚至对界面的修改存在 bug,比如功能图标错位(通常在窗口尺寸调整、主题切换时出现)、插件开启了但相应的图标却没有出现等,需要重启软件,不知道是思源本身还是插件带来的问题。

  2. 各插件自行定制设置界面,插件之间设置界面比较割裂,如果能像 vscode 那样根据设置类型提供统一的设置界面就好了。

  3. 插件管理界面加载慢。即便是升级到最新办法,不论是已经下载的本地插件还是在线浏览界面,尤其是软件第一次冷启动时,加载都十分的缓慢。从插件目录结构看,个人猜测是逐个对插件目录进行了扫描加载(个人猜测!!!)。以 vscode 为例,vscode 的在插件目录下维护了一个 extensions.json ,里面包含了下载的插件的各类信息,个人觉得可以参考其实现,在每次进入插件管理时直接读取该文件加载插件列表,而后异步加载图标等其他插件信息。

  4. 主题与插件的界限比较模糊,容易冲突造成稳定性问题。从目前插件和主题的建设来看,一些主题带有本应通过插件来实现的功能,一些插件也对外观有所侵入。这很可能造成插件和主题在某个实现上的冲突,甚至进而损坏用户数据。个人觉得主题应该专注于外观上的调整和美化,一些针对功能上的实现应当迁移到插件上去,不知道在插件和主题机制上能否实现这种隔离。

  5. 主题相关文件的存放问题,不知道为什么在代码片段文件夹下出现了主题的配置文件,感觉是主题将配置以代码片段的形式存放,但是为什么不存放到主题文件夹中呢,这也是上面说的主题的一种侵入性表现吧。而其他插件的配置则在 data\storage\petal 目录下。

    8jAwA4jXyTMge.png

  6. 进入退出慢。不论是启动软件进入还是退出软件,都需要等待比较长的时间,尤其是数据量较大时,应该是同步机制上的问题,进入退出时都需要通过网络进行数据仓库的同步,给人的感觉不是很可靠的样子,感觉软件直接被杀掉的话会丢数据一样。

以上仅为个人使用的一些体会和建议,不代表其他任何意见,也没有攻击谁的意思,不管是思源还是一些插件主题,都有在使用,也向开发者表示感谢。思源发展至今,从功能上已经十分成熟了,也一直保持较高的更新频率和功能开发速度,但是从用户的角度来看,思源的生态依然十分欠缺,记得 logseq 刚出现的时候思源已经发展了一段时间了(不知道记得准不准确),但目前 logseq 在周边的主题、插件生态上都相对繁荣和完善。思源虽然作为开源产品,但主力开发者只有 D 大和 V 大的情况下,个人觉得还是应当好好打磨一些细节和基础,提供更加完善的机制吸引用户和开发者进入,完善和发展生态,才能更有利于长远发展。

  • 思源笔记

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

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

    19828 引用 • 75926 回帖

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • 稳定性较差。这倒不是说插件本身造成了破坏,或者易于崩溃等,而是说插件机制在使用上不够灵敏高效,部分插件的禁用开启不能立即生效,甚至对界面的修改存在 bug,比如功能图标错位(通常在窗口尺寸调整、主题切换时出现)、插件开启了但相应的图标却没有出现等,需要重启软件,不知道是思源本身还是插件带来的问题。

    这个是插件的问题,思源管不了

  • 主题与插件的界限比较模糊,容易冲突造成稳定性问题。从目前插件和主题的建设来看,一些主题带有本应通过插件来实现的功能,一些插件也对外观有所侵入。这很可能造成插件和主题在某个实现上的冲突,甚至进而损坏用户数据。个人觉得主题应该专注于外观上的调整和美化,一些针对功能上的实现应当迁移到插件上去,不知道在插件和主题机制上能否实现这种隔离。

    有讨论过,结果就是主题作者想怎样干就怎样干(作者想隔离就会自己做插件,不想隔离那就变成主题功能),高自由度

    主题相关文件的存放问题,不知道为什么在代码片段文件夹下出现了主题的配置文件,感觉是主题将配置以代码片段的形式存放,但是为什么不存放到主题文件夹中呢,这也是上面说的主题的一种侵入性表现吧。而其他插件的配置则在 data\storage\petal 目录下。

    这个应该也是看主题作者想存在哪里

    1 回复
  • 进入退出慢。不论是启动软件进入还是退出软件,都需要等待比较长的时间,尤其是数据量较大时,应该是同步机制上的问题,进入退出时都需要通过网络进行数据仓库的同步,给人的感觉不是很可靠的样子,感觉软件直接被杀掉的话会丢数据一样。

    本地数据丢不了,但云端数据会怎样我也不知道。所以不要随便杀内核

  • pakeh2866

    启动确实随着文件数增多越来越慢

  • 插件多了之后冷启动确实灾难,有优化空间

  • 不知道启动退出时是做的全量还是增量同步,感觉增量的话应该不会这么慢.

  • 目前的主题机制确实给了开发者非常大的自由度,但带来的问题就是标准不统一带来的稳定性问题。个人觉得其实可以将主题和插件在底层机制上进行隔离,参考一些编辑器的实现,主题是统一规范了相应的可配置项,不提供侵入式修改和 api 调用。如下:

    图片.png

    1 回复
  • 只是问题在于,这样改的话直接就摧毁了目前的主题生态,改不动,也没有必要

    1 回复
  • 其实感觉目前的主题在数量上还不算特别多特别成熟,迁移的成本应该还可以接受,可以在新机制成熟前两种方式并行,提供一个过渡期。😂

    1 回复
  • jihui

    可能会导致部分主题作者嫌麻烦直接不维护了,破坏了本就不太繁荣的集市开发欲望 😂

    1 回复
  • 可以设置修改期限,例如怼存粮主题两年内修改到符合规范,到时候还不符合规范就下架。

    1 回复
  • jihui

    你没懂我的意思,主题作者们现在都是用爱发电在,思源的集市还没繁荣到可以整幺蛾子搞些条条框框限制这些贡献者的程度

    2 回复
  • temacc0531 1 赞同

    啊?不应该越早规范越好吗,等数量多了再规范改起来代价更大吧?

  • 3Woods 1 赞同

    在我看来并不是说搞什么条条框框,而是形成一个统一的规范的开发机制,避免各自不同的开发方式和 hack 带来不稳定性,不稳定的代价就是用户的数据。有一个规范的插件、主题开发范式,个人觉得反而可以形成一个规范统一的“市场”,也可以吸引一部分非专业的人进入。(PS:个人看法,现在的主题开发机制更像是在开发者工具下对软件本体做的 hack)

请输入回帖内容 ...

推荐标签 标签

  • OnlyOffice
    4 引用 • 16 关注
  • App

    App(应用程序,Application 的缩写)一般指手机软件。

    90 引用 • 383 回帖
  • Hadoop

    Hadoop 是由 Apache 基金会所开发的一个分布式系统基础架构。用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力进行高速运算和存储。

    84 引用 • 122 回帖 • 620 关注
  • 设计模式

    设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

    198 引用 • 120 回帖
  • Ruby

    Ruby 是一种开源的面向对象程序设计的服务器端脚本语言,在 20 世纪 90 年代中期由日本的松本行弘(まつもとゆきひろ/Yukihiro Matsumoto)设计并开发。在 Ruby 社区,松本也被称为马茨(Matz)。

    7 引用 • 31 回帖 • 189 关注
  • Kotlin

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

    19 引用 • 33 回帖 • 44 关注
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    247 引用 • 1347 回帖 • 1 关注
  • Sphinx

    Sphinx 是一个基于 SQL 的全文检索引擎,可以结合 MySQL、PostgreSQL 做全文搜索,它可以提供比数据库本身更专业的搜索功能,使得应用程序更容易实现专业化的全文检索。

    1 引用 • 192 关注
  • PWL

    组织简介

    用爱发电 (Programming With Love) 是一个以开源精神为核心的民间开源爱好者技术组织,“用爱发电”象征开源与贡献精神,加入组织,代表你将遵守组织的“个人开源爱好者”的各项条款。申请加入:用爱发电组织邀请帖
    用爱发电组织官网:https://programmingwithlove.stackoverflow.wiki/

    用爱发电组织的核心驱动力:

    • 遵守开源守则,体现开源&贡献精神:以分享为目的,拒绝非法牟利。
    • 自我保护:使用适当的 License 保护自己的原创作品。
    • 尊重他人:不以各种理由、各种漏洞进行未经允许的抄袭、散播、洩露;以礼相待,尊重所有对社区做出贡献的开发者;通过他人的分享习得知识,要留下足迹,表示感谢。
    • 热爱编程、热爱学习:加入组织,热爱编程是首当其要的。我们欢迎热爱讨论、分享、提问的朋友,也同样欢迎默默成就的朋友。
    • 倾听:正确并恳切对待、处理问题与建议,及时修复开源项目的 Bug ,及时与反馈者沟通。不抬杠、不无视、不辱骂。
    • 平视:不诋毁、轻视、嘲讽其他开发者,主动提出建议、施以帮助,以和谐为本。只要他人肯努力,你也可能会被昔日小看的人所超越,所以请保持谦虚。
    • 乐观且活跃:你的努力决定了你的高度。不要放弃,多年后回头俯瞰,才会发现自己已经成就往日所仰望的水平。积极地将项目开源,帮助他人学习、改进,自己也会获得相应的提升、成就与成就感。
    1 引用 • 487 回帖
  • 思源笔记

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

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

    19828 引用 • 75926 回帖
  • 服务

    提供一个服务绝不仅仅是简单的把硬件和软件累加在一起,它包括了服务的可靠性、服务的标准化、以及对服务的监控、维护、技术支持等。

    41 引用 • 24 回帖 • 9 关注
  • 宕机

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

    13 引用 • 82 回帖 • 51 关注
  • CloudFoundry

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

    5 引用 • 18 回帖 • 154 关注
  • 996
    13 引用 • 200 回帖 • 3 关注
  • Markdown

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

    165 引用 • 1471 回帖
  • 运维

    互联网运维工作,以服务为中心,以稳定、安全、高效为三个基本点,确保公司的互联网业务能够 7×24 小时为用户提供高质量的服务。

    148 引用 • 257 回帖
  • Sillot

    Insights(注意当前设置 master 为默认分支)

    汐洛彖夲肜矩阵(Sillot T☳Converbenk Matrix),致力于服务智慧新彖乄,具有彖乄驱动、极致优雅、开发者友好的特点。其中汐洛绞架(Sillot-Gibbet)基于自思源笔记(siyuan-note),前身是思源笔记汐洛版(更早是思源笔记汐洛分支),是智慧新录乄终端(多端融合,移动端优先)。

    主仓库地址:Hi-Windom/Sillot

    安卓端仓库:Hi-Windom/Sillot-android

    注意事项:

    1. ⚠️ 汐洛仍在早期开发阶段,尚不稳定
    2. ⚠️ 汐洛并非面向普通用户设计,使用前请了解风险
    28 引用 • 25 回帖 • 56 关注
  • 机器学习

    机器学习(Machine Learning)是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。

    76 引用 • 37 回帖
  • Vue.js

    Vue.js(读音 /vju ː/,类似于 view)是一个构建数据驱动的 Web 界面库。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

    262 引用 • 664 回帖 • 1 关注
  • CAP

    CAP 指的是在一个分布式系统中, Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性),三者不可兼得。

    11 引用 • 5 回帖 • 583 关注
  • 微信

    腾讯公司 2011 年 1 月 21 日推出的一款手机通讯软件。用户可以通过摇一摇、搜索号码、扫描二维码等添加好友和关注公众平台,同时可以将自己看到的精彩内容分享到微信朋友圈。

    130 引用 • 793 回帖
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 687 关注
  • Spark

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

    74 引用 • 46 回帖 • 560 关注
  • Pipe

    Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    131 引用 • 1114 回帖 • 137 关注
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖 • 3 关注
  • 架构

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

    140 引用 • 441 回帖
  • JWT

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

    20 引用 • 15 回帖 • 19 关注