docs: 完成并发相关的总体设计,准备开始确认细节合理性

This commit is contained in:
2023-11-28 08:23:02 +00:00
parent 04ded888bf
commit fd5606f4ab

View File

@ -26,14 +26,20 @@
~~因此我不太打算碰文件系统~~ ~~因此我不太打算碰文件系统~~
#### 数据库设计方案 #### 数据库设计方案
##### 数据结构
##### 文件访问与缓存
##### 并发安全
### 引擎模块 ### 引擎模块
具体执行业务一次请求对应且只对应一次引擎模块API调用支持并行API阻塞但可同时运行 具体执行业务一次请求对应且只对应一次引擎模块API调用支持并行API阻塞但可同时运行当API入口函数被调用后执行相关具体操作然后返回响应。
### 通信模块 ### 通信模块
负责对外提供文本模式的交互,从流`request`读取文本格式的命令并把内部数据格式的响应翻译成文本格式向引擎模块发送请求调用引擎模块对外提供的API并把响应返回到流`response`。支持并行: 负责对外提供文本模式的交互,从流`request`读取文本格式的命令并把内部数据格式的响应翻译成文本格式向引擎模块发送请求调用引擎模块对外提供的API并把响应返回到流`response`。支持并行:
- 输入子模块从`request`读取请求,启动一个线程调用翻译子模块。同一个会话的请求不可并行,把`std::thread`move进相应的`std::unordered_map<std::string,std::thread>`,同一会话下次请求发出前,必须join - 输入子模块从`request`读取请求,打上时间戳,分独占式请求和可并行请求按时间戳顺序分批处理。处理一个请求时,启动一个线程调用翻译子模块。同一个会话的请求不可并行,把`std::thread`move进相应的该会话的线程句柄队列,下一个join前一个
- 翻译子模块(入口函数本身阻塞)向引擎模块API发送请求得到响应后把响应数据传给输出子模块的调用接口(阻塞但可并行,处理部分同时运行,上锁后直接输出到`response`,输出本身不同时进行)。 - 翻译子模块(入口函数本身阻塞)join完同一个session的上一个请求后向引擎模块API发送请求得到响应后把响应数据传给输出子模块的调用接口(阻塞但可并行,处理部分同时运行,上锁后直接输出到`response`,输出本身不同时进行)。
注意,输入输出仅保证单个请求/响应是完整的,多个请求/响应之间是完全“混杂”的通过session token、operation token区分通过outhentication key鉴权。`request`流和`response`流始终由信模块控制。注意,通讯模块不负责会话管理。 注意,输入输出仅保证单个请求/响应是完整的,多个请求/响应之间是完全“混杂”的通过session token、operation token区分通过outhentication key鉴权。`request`流和`response`流始终由信模块控制。注意,通讯模块不负责会话管理。