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

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

这篇文章的构想目标是:即使外部环境严俊到堪称第三次世界大战, 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 回帖 • 285 关注
  • 思考
    29 引用 • 120 回帖

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • 都是很棒的想法

  • 其他回帖
  • 88250 2 赞同

    感谢你分享思考。

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

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

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

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

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

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

    特性:匿名、分布式

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

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

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

    1 回复
  • 这个赞同。其实我的很多想法什么的就是提一提,不算是主线任务。当下专造 Vditor 是正业 👍 。优秀的人是会吸引的,我是非常相信这样一种社区是未来的方向,会有更多大牛参与进来的。

  • zhangle1

    zeroNet 了解一下

  • 查看全部回帖

推荐标签 标签

  • Q&A

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

    6556 引用 • 29436 回帖 • 246 关注
  • Rust

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

    57 引用 • 22 回帖 • 5 关注
  • golang

    Go 语言是 Google 推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 Go,是因为过去 10 多年间软件开发的难度令人沮丧。Go 是谷歌 2009 发布的第二款编程语言。

    492 引用 • 1383 回帖 • 374 关注
  • Shell

    Shell 脚本与 Windows/Dos 下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的。但是它比 Windows 下的批处理更强大,比用其他编程程序编辑的程序效率更高,因为它使用了 Linux/Unix 下的命令。

    122 引用 • 73 回帖
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 455 关注
  • BND

    BND(Baidu Netdisk Downloader)是一款图形界面的百度网盘不限速下载器,支持 Windows、Linux 和 Mac,详细介绍请看这里

    107 引用 • 1281 回帖 • 25 关注
  • GitLab

    GitLab 是利用 Ruby 一个开源的版本管理系统,实现一个自托管的 Git 项目仓库,可通过 Web 界面操作公开或私有项目。

    46 引用 • 72 回帖
  • JRebel

    JRebel 是一款 Java 虚拟机插件,它使得 Java 程序员能在不进行重部署的情况下,即时看到代码的改变对一个应用程序带来的影响。

    26 引用 • 78 回帖 • 623 关注
  • Logseq

    Logseq 是一个隐私优先、开源的知识库工具。

    Logseq is a joyful, open-source outliner that works on top of local plain-text Markdown and Org-mode files. Use it to write, organize and share your thoughts, keep your to-do list, and build your own digital garden.

    4 引用 • 55 回帖 • 9 关注
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    41 引用 • 130 回帖 • 295 关注
  • 快应用

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

    15 引用 • 127 回帖 • 2 关注
  • SQLServer

    SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。

    19 引用 • 31 回帖 • 4 关注
  • PWL

    组织简介

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

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

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

    宋真宗赵恒曾经说过:“书中自有黄金屋,书中自有颜如玉。”

    76 引用 • 390 回帖
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    40 引用 • 24 回帖
  • Hibernate

    Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

    39 引用 • 103 回帖 • 685 关注
  • Kotlin

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

    19 引用 • 33 回帖 • 26 关注
  • 新人

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

    51 引用 • 226 回帖
  • 导航

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

    37 引用 • 168 回帖 • 1 关注
  • Wide

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

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

    30 引用 • 218 回帖 • 605 关注
  • 创业

    你比 99% 的人都优秀么?

    82 引用 • 1398 回帖 • 1 关注
  • Dubbo

    Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是 [阿里巴巴] SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。

    60 引用 • 82 回帖 • 609 关注
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    333 引用 • 323 回帖 • 65 关注
  • GAE

    Google App Engine(GAE)是 Google 管理的数据中心中用于 WEB 应用程序的开发和托管的平台。2008 年 4 月 发布第一个测试版本。目前支持 Python、Java 和 Go 开发部署。全球已有数十万的开发者在其上开发了众多的应用。

    14 引用 • 42 回帖 • 687 关注
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    131 引用 • 3641 回帖
  • 正则表达式

    正则表达式(Regular Expression)使用单个字符串来描述、匹配一系列遵循某个句法规则的字符串。

    31 引用 • 94 回帖
  • MySQL

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

    675 引用 • 535 回帖