erlang - gen_server 中的数据被其主管重新启动后会保留吗?

标签 erlang erlang-otp

我有一个主管启动了许多 gen_server。每个 gen_server 都有大量的数据负载,这需要很多时间。我想知道什么时候发生错误,存储在 gen_server 状态及其进程 dict 中的数据是否会保留以备下次启动时使用,这样我就不需要再次初始化它们了?

最佳答案

Erlang 行为的当前状态不会保存在任何地方。你必须自己照顾它。

您要么定期将状态保存在外部某处(在另一个进程中,在 ETS 表中,在数据库中等),要么确保您的 init/1函数足够智能和动态,能够在启动时重新创建状态(恢复现有文件,根据原始输入参数重新创建一些缓存等)

基本上,您必须定义哪些数据应该在崩溃后幸存下来,以及如何保留或重新创建它。

关于erlang - gen_server 中的数据被其主管重新启动后会保留吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6881075/

相关文章:

erlang - 启动erlang代码的脚本

c - gcc 警告 "coverage_mismatch"是什么意思?

erlang - 如何在氮中调用erlang函数?

erlang - 获取erlang中嵌套映射的值

hmac - 如何在 Elixir 中生成 HMAC 字符串?

erlang - 名为timer_server的gen_server导致定时器模块函数不返回

erlang - 将 map 转换为erlang中的列表的函数

logging - 如何确保在进程崩溃时获取具有行号的error_logger报告

elixir - 如何用elixir创建事件发射器,otp方式

erlang - 为什么 "cast"这个词用于处理 GenServer 中的异步消息?