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

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

这篇文章的构想目标是:即使外部环境严俊到堪称第三次世界大战, 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思源笔记

    1063 引用 • 3453 回帖 • 204 关注
  • 思考
    29 引用 • 120 回帖

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • 88250 2 赞同

    感谢你分享思考。

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

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

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

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

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

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

    特性:匿名、分布式

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

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

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

    1 回复
  • 其他回帖
  • 都是很棒的想法

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

  • wizardforcel

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

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

    2 回复
  • 查看全部回帖

推荐标签 标签

  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖
  • 深度学习

    深度学习(Deep Learning)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高层抽象的算法。

    53 引用 • 40 回帖
  • 安全

    安全永远都不是一个小问题。

    199 引用 • 816 回帖 • 1 关注
  • Shell

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

    123 引用 • 74 回帖 • 1 关注
  • AngularJS

    AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

    12 引用 • 50 回帖 • 474 关注
  • 负能量

    上帝为你关上了一扇门,然后就去睡觉了....努力不一定能成功,但不努力一定很轻松 (° ー °〃)

    88 引用 • 1235 回帖 • 412 关注
  • 域名

    域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。

    43 引用 • 208 回帖
  • etcd

    etcd 是一个分布式、高可用的 key-value 数据存储,专门用于在分布式系统中保存关键数据。

    5 引用 • 26 回帖 • 529 关注
  • Latke

    Latke 是一款以 JSON 为主的 Java Web 框架。

    71 引用 • 535 回帖 • 788 关注
  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖 • 1 关注
  • 职场

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

    127 引用 • 1705 回帖
  • BND

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

    107 引用 • 1281 回帖 • 27 关注
  • WordPress

    WordPress 是一个使用 PHP 语言开发的博客平台,用户可以在支持 PHP 和 MySQL 数据库的服务器上架设自己的博客。也可以把 WordPress 当作一个内容管理系统(CMS)来使用。WordPress 是一个免费的开源项目,在 GNU 通用公共许可证(GPLv2)下授权发布。

    66 引用 • 114 回帖 • 228 关注
  • 阿里云

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

    89 引用 • 345 回帖
  • 生活

    生活是指人类生存过程中的各项活动的总和,范畴较广,一般指为幸福的意义而存在。生活实际上是对人生的一种诠释。生活包括人类在社会中与自己息息相关的日常活动和心理影射。

    230 引用 • 1454 回帖
  • Flutter

    Flutter 是谷歌的移动 UI 框架,可以快速在 iOS 和 Android 上构建高质量的原生用户界面。 Flutter 可以与现有的代码一起工作,它正在被越来越多的开发者和组织使用,并且 Flutter 是完全免费、开源的。

    39 引用 • 92 回帖
  • Redis

    Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

    286 引用 • 248 回帖 • 61 关注
  • ReactiveX

    ReactiveX 是一个专注于异步编程与控制可观察数据(或者事件)流的 API。它组合了观察者模式,迭代器模式和函数式编程的优秀思想。

    1 引用 • 2 回帖 • 155 关注
  • Chrome

    Chrome 又称 Google 浏览器,是一个由谷歌公司开发的网页浏览器。该浏览器是基于其他开源软件所编写,包括 WebKit,目标是提升稳定性、速度和安全性,并创造出简单且有效率的使用者界面。

    62 引用 • 289 回帖
  • Gitea

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

    4 引用 • 16 回帖 • 5 关注
  • iOS

    iOS 是由苹果公司开发的移动操作系统,最早于 2007 年 1 月 9 日的 Macworld 大会上公布这个系统,最初是设计给 iPhone 使用的,后来陆续套用到 iPod touch、iPad 以及 Apple TV 等产品上。iOS 与苹果的 Mac OS X 操作系统一样,属于类 Unix 的商业操作系统。

    85 引用 • 139 回帖 • 1 关注
  • Swagger

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    17 引用 • 236 回帖 • 327 关注
  • Netty

    Netty 是一个基于 NIO 的客户端-服务器编程框架,使用 Netty 可以让你快速、简单地开发出一个可维护、高性能的网络应用,例如实现了某种协议的客户、服务端应用。

    49 引用 • 33 回帖 • 21 关注
  • Unity

    Unity 是由 Unity Technologies 开发的一个让开发者可以轻松创建诸如 2D、3D 多平台的综合型游戏开发工具,是一个全面整合的专业游戏引擎。

    25 引用 • 7 回帖 • 173 关注
  • 运维

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

    149 引用 • 257 回帖
  • 安装

    你若安好,便是晴天。

    132 引用 • 1184 回帖