Elixir 中待办事项系统的测试、并发分析与数据持久化
1. 测试运行
在 Elixir 中,可以使用 mix test 来运行所有测试:
$ mix test
.......
Finished in 0.05 seconds
7 tests, 0 failures
若想了解更多关于 Elixir 单元测试的内容,可查看官方 ExUnit 参考文档(https://hexdocs.pm/ex_unit )和 mix test 文档(https://hexdocs.pm/mix/Mix.Tasks.Test.xhtml )。
2. 分析进程依赖
当前系统已支持管理多个待办事项列表实例,目标是将其用于 HTTP 服务器。在 Elixir 和 Erlang 环境中,HTTP 服务器通常为每个请求使用单独的进程。若有多个并发终端用户,会有多个 BEAM 进程访问待办事项缓存和待办事项服务器。进程间的依赖关系如下:
- 多个客户端(可能数量众多)向单个待办事项缓存进程发出请求。
- 多个客户端与多个待办事项服务器进程进行通信。
第一个情况可能成为系统瓶颈,因为只有一个待办事项缓存进程,无论有多少 CPU 资源,一次只能处理一个服务器进程请求。不过,实际中该问题可能并不严重。例如,若服务器进程处理一个请求需 1 微秒,待办事项缓存每秒可处理多达 1000000 个请求,能满足大多数需求;但如果处理一个请求需 100 毫秒,每秒只能处理 10 个请求,系统将无法处理更
超级会员免费看
订阅专栏 解锁全文
25

被折叠的 条评论
为什么被折叠?



