在erlang中,当生成gen_server:call()时,必须发送要调用的节点的名称。
让我说我有这样的用法:
我有两个节点:'node1‘和'node2’正在运行。我可以使用这些节点来使gen_server:call()彼此连接。
现在,假设我又添加了两个节点:'node3‘和'node4’,然后互相点击,这样所有节点都可以看到并相互生成gen_server:calls。
erlang专业人员如何处理这样的新节点的动态添加,以便他们知道要输入gen_server调用的新节点名称,或者是否需要事先知道所有节点的名称,以便在像sys.config这样的地方硬编码?
发布于 2014-01-17 04:13:53
您可以使用:erlang:nodes()获取节点列表的“立即”视图。
此外,您还可以使用:net_kernel:monitor_nodes(true) (通过ping / crash / etc)在节点来来去去时得到通知。
要查看模块是否运行在该节点上,可以使用某种ping回调调用gen_server。
或者您可以使用rpc模块在外部节点上调用erlang:whereis(name)。
https://stackoverflow.com/questions/21176849
复制相似问题