docs: 添加了一些参考资料
This commit is contained in:
@ -17,10 +17,18 @@
|
||||
后端只有一个可执行文件,书店实例通过配置文件夹来决定(默认为当前目录下`.bookstore`文件夹,亦可通过命令行参数指定)。当书店系统在运行时,有且仅有一个后端进程,分为interactive模式(使用后端自带的交互,单会话模式)和server模式(通过WebUI交互)。
|
||||
### 数据库模块
|
||||
维护相关数据,支持并行(API阻塞但可同时运行)。
|
||||
#### 磁盘IO的并发
|
||||
- 机械硬盘下不应该并发,反复寻址会负优化
|
||||
- 从安全性角度,没有把握不要同时写
|
||||
- 进程内部使用同一个文件描述符时,可以并发地调用读取函数,但是会自动相互阻塞
|
||||
- 当使用不同的文件描述符时,并发调用读取函数时不会自动相互阻塞,如果并发读取的区域重叠,会有安全性问题
|
||||
|
||||
~~因此我不太打算碰文件系统~~
|
||||
|
||||
#### 数据库设计方案
|
||||
|
||||
### 引擎模块
|
||||
具体执行业务,支持并行(API阻塞但可同时运行)。
|
||||
具体执行业务,一次请求对应且只对应一次引擎模块API调用,支持并行(API阻塞但可同时运行)。
|
||||
|
||||
### 通信模块
|
||||
负责对外提供文本模式的交互,从流`request`读取文本格式的命令,并把内部数据格式的响应翻译成文本格式,向引擎模块发送请求(调用引擎模块对外提供的API),并把响应返回到流`response`。支持并行:
|
||||
|
Reference in New Issue
Block a user