22、并发系统中的错误处理与监督机制

并发系统中的错误处理与监督机制

1. 运行时错误处理策略

与 C++、C#、Java 和 JavaScript 等语言相比,在某些场景下,捕获运行时错误的需求相对较少。一种常见的做法是让进程崩溃,然后再进行处理(通常是重启进程)。这种方法看似有些随意,但背后有其合理的逻辑。

在复杂系统中,大多数错误会在测试阶段被发现。剩余的错误大多属于所谓的“海森堡错误”(Heisenbug)类别,即那些在特殊情况下不规则出现且难以重现的不可预测错误。这类错误的原因通常在于状态的损坏。因此,合理的解决办法是让进程崩溃并重新启动一个新进程。这样做可以摆脱可能已损坏的进程状态,以全新的状态重新开始。在很多情况下,这能解决眼前的问题。当然,需要记录错误信息,以便后续分析并找出根本原因。

2. 并发系统中的错误

并发在构建基于 BEAM 的容错系统中起着核心作用。这是因为各个进程是完全隔离和独立的,一个进程的崩溃通常不会影响其他进程(除非你明确希望如此)。

以下是一个简单的示例:

iex(1)> spawn(fn ->                      
          spawn(fn ->                     
            Process.sleep(1000) 
            IO.puts("Process 2 finished") 
          end) 

          raise("Something went wrong")   
        end)
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值