blog/source/_posts/the-first-year-of-lightstands.md
2023-08-23 20:38:50 +08:00

68 lines
5.6 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

---
title: LightStands的第一年
date: 2023-08-23 19:29:21
tags:
- LightStands
---
现在的LightStands软件的第一个Commit来自2022年7月31日。不过LightStands的想法和开发其实开始得很早最早的版本早在2017年就开始开发了。详细的时间我并不记得我只知道在2017年8月8日我在Git上提交了web.dart的[第一个commit](https://github.com/thislight/webart/commit/dc37ef4a44ea52d7c8515528fd68ae46ad901b62)——它是LightStands第一个版本的基础。但是在写了几千行代码之后这个LightStands软件就被废弃了。
这篇文章是我过去几年里开发LightStands软件的经历总结。
<!--more-->
## 坚实的基础
从2017年到2022年我对LightStands软件的技术栈就有很多想像。最开始的版本使用了Dart语言编写但是很快就废弃了原因稍微有点复杂。
原本Dart的实现是它的一大卖点Dart的实现可以在两个模式下运行程序一个叫做检查模式Checked Mode一个是生产模式Production Mode。检查模式会在程序运行时进行额外的检查包括一些类型检查而生产模式不会。我猜这两个模式产生的原因是这样的Dart的类型系统支持动态类型但是检查动态类型引入了条件判断条件判断对性能的影响非常大。
他们希望你可以在以生产模式运行程序在检查模式中测试程序这样你就拥有了the best of two worlds。通过两种模式的区别Dart在提供动态类型的同时达到了比较高的性能。我没有做过比较正式的测试但是生产模式比当时的CPython要快得多。
事情在Dart 2的时候就起了变化Dart 2开始转型为Flutter的专用语言。Dart 2移除了生产模式和检查模式的区别取而代之的是单独的”强模式“Strong Mode
这只是一个好听的营销术语。我用web.dart写了一个简单的HTTP服务示例进行了大致测试发现Dart 2.0强模式的性能与Dart 1.24.3的检查模式没有太大区别这样的性能没有太大的亮点。并且新的强模式对原本自动使用动态类型的变量使用了类型推断一些情况下推断出的类型并不符合直觉还导致Dart 2失去了向前兼容。
还没完呢。为了强行推广Dart 2PubDart的包管理器和包仓库对不支持Dart 2的库降权被降权的库就会直接放在搜索结果末尾。
> Google什么时候砍掉一个产品现在或者下一秒。
这件事给我很深刻的教训技术栈的基础一定要可靠最少要确定它的维护团队不会强行推动一个尚未完成的修改。对于编程语言这件事后来我曾考虑过Lua还为此写了[hussar](https://gitlab.com/thislight/hussar)最后在去年开始新开发时还是选择了Python。
## 减少可替换部件
减少Moving Parts是我在开发初期的一个大胆决定。目前LightStands有三个组件httpgated、mangerd、cleanupd和一个最终依赖melon。并且
* 线上服务也使用SQLite3作为DBMS
* 所有的组件都写在同一个仓库只是暴露不同的进入点entrypoint
* 运行服务只需要3个进程分别是HTTP API服务、拉取RSS、垃圾收集。最开始进程之间不需要交换信息都是直接操作数据库
这极大地简化了开发和部署。配合容器手动部署甚至只需要5分钟就可以完成。开发的时候可以直接运行程序、使用DB Browser for SQLite直接查看数据库。而且目前来看SQLite3并没有给性能带来太大问题。
Melon是一个ORM框架。最开始我将它和LightStands其它组件放在一起这样迭代会更简单。但它是一个高内聚的框架和LightStands其实没什么关系这时我就想将它从LightStands中独立出来。我当时就意识到我们缺少一个私有的软件包仓库如果最开始就有一个私有的软件包仓库不仅可以用来整理模块还可以简化远程服务器上的部署。我打算在今年完成这件事。
## 单页应用不是唯一选项
最开始我是想要把LightStands的登录和注册做成单页应用在客户端上完成验证、创建访问密钥、授权的工作。但是这样做效果很一般单页应用的无缓存访问很慢。登录和注册只有寥寥几个页面完全无法利用单页应用渐进式下载的优势反而被JS拖累延长了首次内容显示耗时。而且这些工作本来就是一次性在服务器上完成更快将他们分为几个HTTP请求确实进一步拖慢了速度。
我正在编写一个JavaScript库可以简化多页应用的DOM操作。希望今年能应用在新的LightStands用户面板上。
## 下一站
LightStands是我新想法的试验田应用了许多在很多人看来都很小众的想法。不过激进自有其坏处LightStands的开发相对来说很缓慢为一个小众架构编写能够使用的库是一个巨大的挑战。编写实现这些新想法的代码需要消耗许多时间例如LightStands使用的ORM框架melon代码五千余行。
LightStands正在将旧有基于feedparser的feedloaderd迁移到全新的mangerdmangerd不仅能够从源拉取还支持接受推送为ActivityPub支持做足了准备。不过在此之前我们还面临一个重要挑战将旧的数据结构迁移到新的数据结构。
新的一年LightStands在技术上的路线图大概如下
* 将API迁移到新的数据结构
* 支持更新通知
* 支持ActivityPub
在新的一年继续“添砖加瓦”,干杯!