docs: 添加了几个图

This commit is contained in:
2023-11-29 13:38:34 +00:00
parent 0192ed248a
commit 2c079e0475
10 changed files with 834 additions and 4 deletions

View File

@ -11,6 +11,9 @@
- 快照
- 文件系统修复
系统结构图:![系统结构图加载中……](https://cloud.zymsite.ink/f/O8IQ/%E7%B3%BB%E7%BB%9F%E7%BB%93%E6%9E%84%E5%9B%BE.png)
# 功能设计(模块划分)、数据库设计
整个程序分为后端和前端两部分,后端即主体部分
## 后端
@ -48,8 +51,8 @@ memoryriver类维护一个缓存简单地缓存高频访问和连续访问
### 调度模块
负责对外提供文本模式的交互,以及维护请求级的并行。从流`request`读取文本格式的命令并把内部数据格式的响应翻译成文本格式向引擎模块发送请求调用引擎模块对外提供的API并把响应返回到流`response`。支持条件允许时的并行:
- 输入子模块从`request`读取请求,打上时间戳,分独占式请求和可并行请求按时间戳顺序分批处理。处理一个请求时,启动一个工作线程调用翻译子模块。同一个会话的请求不可并行,把`std::thread`move进相应的该会话的工作线程句柄队列下一个join前一个。成批执行可并行请求时启动完当前批次所有工作线程后join每个session的最后一个工作线程结束之后就可以执行下一批了。为了在服务模式下处理时有时无的请求两个流在读取时是阻塞的自己封装一个`std::condition_variable`通讯),并且读一个处理一个,碰到“不属于自己批次”的东西才算一批结束。
- 翻译子模块(入口函数本身阻塞)join完同一个session的上一个请求后向引擎模块API发送请求得到响应后把响应数据传给输出子模块的调用接口(阻塞但可并行,处理部分同时运行,上锁后直接输出到`response`,输出本身不同时进行)。
- 输入子模块从`request`读取请求,打上时间戳,分独占式请求和可并行请求按时间戳顺序分批处理。处理一个请求时,启动一个工作线程调用翻译执行子模块。同一个会话的请求不可并行,把`std::thread`move进相应的该会话的工作线程句柄队列下一个join前一个。成批执行可并行请求时启动完当前批次所有工作线程后join每个session的最后一个工作线程结束之后就可以执行下一批了。为了在服务模式下处理时有时无的请求两个流在读取时是阻塞的自己封装一个`std::condition_variable`通讯),并且读一个处理一个,碰到“不属于自己批次”的东西才算一批结束。
- 翻译执行子模块(入口函数本身阻塞)join完同一个session的上一个请求后向引擎模块API发送请求得到响应后把响应数据传给输出子模块的调用接口(阻塞但可并行,处理部分同时运行,上锁后直接输出到`response`,输出本身不同时进行)。
注意,在`request`流和`response`流中,输入输出仅保证单个请求/响应是完整的,多个请求/响应之间是完全“混杂”的,通过`session token``operation token`(操作标识由用户侧会话管理器维护,~~反正`session token`已经划分频道了用户开F12瞎改后果自负~~)区分,通过`outhentication key`鉴权。`request`流和`response`流始终由信模块控制。注意,通讯模块不负责会话管理。
@ -58,7 +61,7 @@ memoryriver类维护一个缓存简单地缓存高频访问和连续访问
标准输入输出始终由内置交互模块控制。
## 前端
~~不清楚有没有时间写~~。WebUI采用`Node.JS`+`Socket.IO`~~不打算弄得很好看,不打算支持响应式设计~~支持图形化操作面板和“云命令行”。和interactive模式一样单个会话的操作支持逻辑上并发上一操作未结束可以发出下一操作但后端实际上是串行的。对于通讯中断、偶发的服务器未响应只保证不会彻底崩掉不保证出问题的业务能恢复。会话管理方面只负责信息准确投送。
~~不清楚有没有时间写~~。WebUI采用`Node.JS`+`Socket.IO`~~不打算弄得很好看,不打算支持响应式设计~~支持图形化操作面板和“云命令行”。和interactive模式一样单个会话的操作支持逻辑上并发上一操作未结束可以发出下一操作但后端实际上是串行的。对于通讯中断、偶发的服务器未响应只保证不会彻底崩掉不保证出问题的业务能恢复。会话管理方面只负责信息准确投送。WebUI套一层Electron生成全平台客户端。
~~不考虑卡死的情况,数据库卡死了也拿它没办法,引擎部分不死循环就不会卡死~~只支持重置session。
### 服务端

View File

@ -1,5 +1,9 @@
# 大致预设场景
一个中小规模的书店,后台运行一个服务端,使得用户、店员、店主可以方便地在电脑端或移动端上完成相关业务操作
业务流程图:![业务流程图加载中……](https://cloud.zymsite.ink/f/9DS9/%E4%B8%9A%E5%8A%A1%E6%B5%81%E7%A8%8B%E5%9B%BE.png)
数据流图:![数据流图加载中……](https://cloud.zymsite.ink/f/Q2cE/%E6%95%B0%E6%8D%AE%E6%B5%81%E5%9B%BE.png)
## 功能需求
### 游客
- 注册用户