由 B3log 构思引起的思考,怎样让它在几乎任何严俊的外部环境下都展现出顽强的生命力

本贴最后更新于 1430 天前,其中的信息可能已经事过景迁

这篇文章的构想目标是:即使外部环境严俊到堪称第三次世界大战, B3log 也能无比顽强地存在和发展。

下图是 B3log 的主要结构:

我不是程序员,只是个体验的软件比较多的用户,从一个普通用户,谈下看法。

在我的理解中:

  • Synphony 像是一个社区的广场,近乎是一个公共空间。
  • Pipe 像是这个社区的楼房,可以分配出许多房间,租给用户,用作私人空间,写的东西可以同步到社区公共空间。
  • Solo 像是用户在社区之外自己的小别墅,地是自己的,房子是自己的,房子里的东西还是自己的,而且还可以盖好多个别墅!用户可以选择不租用 Pipe ,而是在自己的 Solo 中创作,并同步到社区公共空间。

但这样有一些问题:无论是 Solo 还是 Pipe,都需要一个稳定、可访问的地址(例如域名),才能时刻顺利访问。

如果域名因为外部原因,无法访问了,那么将会给用户带来访问的困扰。更何况,我们生活中有很多这样的外部原因:

  • 没钱交服务器费用了
  • 手头设备断网了
  • 为了省电,关闭网络了
  • 手机不小心没流量了
  • DNS 被感染了

在上述情况下,用户还想要更新、管理他的博客,发篇文章的话,就没办法访问自己服务器的 Solo 或 B3log 提供的 Pipe 了。

以或者,极端一点,你搭建的 Solo 和 Pipe 都是在阿里云上,定期备份在 Github 上,世界大战爆发了,商业网络服务提供商暂停服务了,用户如何能够在这样的时期依然畅通地管理自己的博客,并且在大战结束后,即使阿里云上存储的所有数据都被摧毁了,只要网络恢复,社区都可以不受数据丢失影响地恢复?

不那么极端,考虑美好的未来,IPV6 的世界,每一台设备都能有一个直达的 IP 地址,每个设备(笔记本、手机)都能作为一台性能沿可的个人服务器,只是 IPV6 地址可能会因网络环境而变化,随着知识人群的增多,可能每个高级知识分子都需要一个博客,让博客连接到社区,来发表自己的见解。

但是,在众多高级知识分子中,许多并不是程序员,没有自己搭建博客的技能,他们只是其它领域的大牛,难道他们就只能使用所有文件都在远端的 Pipe 了吗?一旦网络出现问题,访问和数据安全问题也就会悬在他们头顶。

结合使用 Syncthing1 的理解,我提出这样一种构思:

  • 提供多平台的 Solo GUI 客户端,只要从(Win, Android, iOS)图标启动,那么就在本地后台启动了一个 Solo 服务,本机可以通过例如: http://127.0.0.1:8080 访问
  • 每个 Solo 和 Solo 之间可以通过 P2P 同步,Rhythm 充当 Tracker
  • Rhythm 提供 GUI 工具,只要打开运行,就可以在本机运行一个 Tracker,这就允许普通用户轻易运行一个 Tracker
  • Solo 可以添加多个 Tracker
  • Solo 和 Pipe 之间可以通过 P2P 同步
  • Solo 和社区之间可以通过 P2P 同步

请允许我描述一下,上述构思实现之后,是怎样的体验:

简要而言,无论处于什么网络环境,用户只需在设备后台运行 Solo 客户端,就可以访问 http://127.0.0.1 来流畅地管理自己的博客。

例如:

  • 我月底没钱,宽带费刚好到期,没钱交了,路由断网了。不怕,继续在我的电脑上管理我的本地 Solo 博客,同时,我的手机和电脑,将通过电脑上运行的 Rhythm 提供的 Tracker 使用 P2P 直连(都在一个局域网下,自然可以直连)同步博客。所以在电脑上编辑博客后,我电脑上的博客和手机上的博客内容是一致同步的。
  • 然后我出去溜一圈,打开了流量开关,同步到手机上的 Solo 博客在官方服务器 Tracker 的帮助下,自动与 Pipe 进行同步,交换最新消息,Pipe 上的收到的评论同步到了手机 Solo 上,Pipe 上要公开的文章也同步到了 Synphony 社区中。
  • 回家之后,手机连上了家里的 Wifi ,自动将最新的 Solo 与电脑上的 Solo 同步到了最新,在电脑上继续处理新消息。

在这样一个过程中,有以下几点好处:

  • 无论是多糟糕的网络环境,都不会影响用户在博客上畅快地写文章,管理文章
  • 只要设备能访问共同添加的 Tracker,就能同步、交换最新消息(新文章、新评论、……)
  • 最少有了三份同步的、在不同设备上的数据:手机一份、电脑一份,阿里云服务器 Pipe 中一份,数据安全几乎无懈可击。这样的好处就是:
    • 即使阿里云 Pipe 炸了,所有外网环境炸了,用户仍能通过本地设备安全地访问、管理、更新他的数据,大不了再换一个新的 Pipe 平台
    • 即使家里着火了,所有随身设备都烧坏了,没关系,云端还有,换一个手机,连上 Tracker ,添加上设备,最新数据又回来了。
    • 不用再去花精力做数据备份。
    • 要是云也炸了,自己身边的所有设备也炸了,最大的可能就是世界核平了,那时博客也没有意义了。
  • 客户端的 Solo 等服务是 GUI 一键启动的,不需要程序员知识,不需要命令行操作,只要智力正常,都能会用。

我认为这样一个构思正好和星火计划有共性,在这样的 P2P 博客网络下,可以让 B3log 社区真正做到野火烧不尽,春风吹又生,在几乎任何严俊的外部环境下都展现出顽强的生命力。


  1. Syncthing 是一个开源的多设备 P2P 同步软件,可以让多个设备上的文件保持同步,它的 Tracker 服务器也是开源的,所以用户可以运行自己的 Tracker 服务器,在跨网段、访问不到官方 Tracker 的情况下,也能顺畅同步。

  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1083 引用 • 3461 回帖 • 286 关注
  • 思考
    29 引用 • 120 回帖

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • wizardforcel

    我觉得无论怎么样都得优先接入 ipfs,其中重中之重是找到愿意给你 pin 的人。

    然后其次是拿几个硬盘备份数据,硬盘贵就换成磁带机。

    2 回复
  • 其他回帖
  • ipfs 对我有点高深,许多地方理解不了。我对数据安全的理解仅限于将数据最少三份同步保存在不同的设备上,并且加上可调节的版本控制。

  • 88250 2 赞同

    感谢你分享思考。

    在 B3log 发展的现阶段,去中心化暂时不是首要目标。目前我们需要继续推进分布式社区实现,当有一定量的用户充分参与到分布式社区后再继续考虑去中心化,这样基础会更稳定一些,届时黑客派将作为星火社区的一个对等节点加入到星火网络中。

    我设想过一种“Hub”模式,节点间可以类似 git 做 fork/merge 操作,拉取其他节点内容数据或者推送内容数据到其他节点,形成不同偏好内容的社区,比如面向编程语言、产品设计、运维等,由不同的参与者运营,用户可以在不同社区之间分享贡献。

    不过这个考虑过于长远,现阶段并不具备开发和运营的条件。但这个模式的试水 demo 我已经构思好了,即摸鱼聊天室——鱼塘。

    隐喻:各不相同的鱼塘通过水渠连接,摸鱼人可以随着水流摸到各种不同的鱼,也可以放鱼到鱼塘中让其游历。

    功能:鱼塘是一个分布式的聊天服务,通过鱼塘开源项目搭建聊天室,不同聊天室之间通过服务端接口打通数据,所有聊天室对等节点共同构成了鱼塘网络。

    愿景:成为全球最大的摸鱼聊天社区

    特性:匿名、分布式

    好像有点扯远了,而且有点“不务正业,误人子弟”🤣

    现在我们最主要的目标是将 Vditor 打造为”下一代的 Markdown 编辑器“,这是以后发展的基础,因为以上所构思的任何一款产品都离不开编辑器,有了好用的编辑器,才能在最大程度上方便用户创造内容,有了有价值的内容才能带来更多用户参与,有了一定量级用户的参与,分布式化乃至去中心化社区才能建立,当这样社区的网络节点呈现出一定规模后才能改变体验,最终实现目标,回归初心。

    实现这些需要的时间会比较长,现在发展也比较缓慢,期待有更多的人参与进来。悲观一些,即使没人关注,我也会一直努力下去,因为我坚信正在做的事情是有意义的。

    1 回复
  • 都是很棒的想法

  • 查看全部回帖

推荐标签 标签

  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    28 引用 • 108 回帖
  • JWT

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

    20 引用 • 15 回帖 • 17 关注
  • 七牛云

    七牛云是国内领先的企业级公有云服务商,致力于打造以数据为核心的场景化 PaaS 服务。围绕富媒体场景,七牛先后推出了对象存储,融合 CDN 加速,数据通用处理,内容反垃圾服务,以及直播云服务等。

    25 引用 • 215 回帖 • 164 关注
  • 倾城之链
    23 引用 • 66 回帖 • 100 关注
  • Rust

    Rust 是一门赋予每个人构建可靠且高效软件能力的语言。Rust 由 Mozilla 开发,最早发布于 2014 年 9 月。

    57 引用 • 22 回帖 • 3 关注
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    330 引用 • 614 回帖
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖 • 3 关注
  • RIP

    愿逝者安息!

    8 引用 • 92 回帖 • 290 关注
  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    170 引用 • 414 回帖 • 431 关注
  • 新人

    让我们欢迎这对新人。哦,不好意思说错了,让我们欢迎这位新人!
    新手上路,请谨慎驾驶!

    51 引用 • 226 回帖
  • SOHO

    为成为自由职业者在家办公而努力吧!

    7 引用 • 55 回帖 • 93 关注
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1083 引用 • 3461 回帖 • 285 关注
  • frp

    frp 是一个可用于内网穿透的高性能的反向代理应用,支持 TCP、UDP、 HTTP 和 HTTPS 协议。

    15 引用 • 7 回帖 • 11 关注
  • HBase

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

    17 引用 • 6 回帖 • 45 关注
  • React

    React 是 Facebook 开源的一个用于构建 UI 的 JavaScript 库。

    192 引用 • 291 回帖 • 441 关注
  • SVN

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

    29 引用 • 98 回帖 • 692 关注
  • 服务

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

    41 引用 • 24 回帖 • 4 关注
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    185 引用 • 318 回帖 • 346 关注
  • 分享

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

    242 引用 • 1747 回帖 • 1 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖 • 2 关注
  • 禅道

    禅道是一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法 scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管理、文档管理、事务管理等功能,在一个软件中就可以将软件研发中的需求、任务、bug、用例、计划、发布等要素有序的跟踪管理起来,完整地覆盖了项目管理的核心流程。

    5 引用 • 15 回帖 • 222 关注
  • WebSocket

    WebSocket 是 HTML5 中定义的一种新协议,它实现了浏览器与服务器之间的全双工通信(full-duplex)。

    48 引用 • 206 回帖 • 399 关注
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 43 关注
  • 反馈

    Communication channel for makers and users.

    123 引用 • 906 回帖 • 193 关注
  • 支付宝

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

    29 引用 • 347 回帖 • 1 关注
  • 阿里云

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

    89 引用 • 345 回帖
  • 百度

    百度(Nasdaq:BIDU)是全球最大的中文搜索引擎、最大的中文网站。2000 年 1 月由李彦宏创立于北京中关村,致力于向人们提供“简单,可依赖”的信息获取方式。“百度”二字源于中国宋朝词人辛弃疾的《青玉案·元夕》词句“众里寻他千百度”,象征着百度对中文信息检索技术的执著追求。

    63 引用 • 785 回帖 • 253 关注