有人告诉我,simple_one_for_one对于聊天应用程序非常有用,因为每个聊天客户端都是一个服务器进程(gen_server)。是这样的吗?
我想知道我们为什么需要它?为什么不只创建一个中心服务器(gen_server)来处理所有聊天客户端通信?因为可能聊天客户端的数量非常多,所以只有一台服务器不能快速处理,导致系统变慢?
我认为创建太多像simple_one_for_one这样的服务器可能会占用太多的系统资源。我是一个OTP新手,所以我真的需要关于这一点的解释。
发布于 2014-05-02 09:14:21
是的,想法是每个客户端都有一个进程(gen_server)。
这使您可以将一个客户端的故障与另一个客户端的故障隔离开来。
如果每个人都在一个进程中,则必须非常小心地处理所有可能出错并使进程崩溃的事情(因此,断开所有客户端的连接)。
对于每个客户端一个进程,您可以编写快乐路径的代码,并在出现错误时让它崩溃。最坏的情况是你丢弃了一个客户端。
进程相当便宜(与创建线程完全不同)。在一台现代机器上,你可以拥有数百万台计算机。
如果你的用户群有几百万,我敢肯定你最终会拥有不止一台服务器。因此,可以轻松扩展到数十万到数百万的东西在一个盒子上就足够了。
https://stackoverflow.com/questions/23412792
复制相似问题