首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >与gen_server:call()相关的Erlang可伸缩性问题

与gen_server:call()相关的Erlang可伸缩性问题
EN

Stack Overflow用户
提问于 2014-01-17 02:35:22
回答 1查看 104关注 0票数 0

在erlang中,当生成gen_server:call()时,必须发送要调用的节点的名称。

让我说我有这样的用法:

我有两个节点:'node1‘和'node2’正在运行。我可以使用这些节点来使gen_server:call()彼此连接。

现在,假设我又添加了两个节点:'node3‘和'node4’,然后互相点击,这样所有节点都可以看到并相互生成gen_server:calls。

erlang专业人员如何处理这样的新节点的动态添加,以便他们知道要输入gen_server调用的新节点名称,或者是否需要事先知道所有节点的名称,以便在像sys.config这样的地方硬编码?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-01-17 04:13:53

您可以使用:erlang:nodes()获取节点列表的“立即”视图。

此外,您还可以使用:net_kernel:monitor_nodes(true) (通过ping / crash / etc)在节点来来去去时得到通知。

要查看模块是否运行在该节点上,可以使用某种ping回调调用gen_server。

或者您可以使用rpc模块在外部节点上调用erlang:whereis(name)。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21176849

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档