erlang节点通讯例子及问题分析

本文介绍了Erlang分布式特性的基础——节点通信,包括如何在两个节点间建立连接并通信,展示了示例代码。同时,讨论了Erlang节点通信的透明性及其与socket通信的性能比较。此外,重点分析了Erlang节点连接时可能出现的cookie、名字和版本问题,并提供了相应的解决方法。
摘要由CSDN通过智能技术生成

分布式是erlang的三大特性之一,都说erlang分布式,最简单最直接的应用就是节点通讯。

问题来了,怎么节点通讯,节点连接可能很多人知道,如何在两个节点连接后进行本地与远程通信?这就是本篇所讲的内容。

下面是示例代码,完成2个节点的通讯:

A节点的代码:

-module(server_demo).
-export([start/0, rpc_call/2]).

start() ->
   Pid = spawn(fun() -> server_loop() end),
   register(demo, Pid), %%注册进程名字
   ok.

server_loop() ->
   receive
      {msg, Pid, Msg} ->
         io:format("receive msg ~p from pid ~p~n",[Msg, Pid]);
      {rpc, Pid, Msg} ->
         io:format("receive rpc ~p from pid ~p~n",[Msg, Pid])
   end,
   server_loop().
	
rpc_call(Pid, Msg) ->
   demo ! {rpc, Pid, Msg}.	
启动A节点:
erl -s server_demo start -hidden -name server@127.0.0.1 -setcookie 123456


B节点的代码:
-module(client_demo).
-export([start/0]).

start() -&
  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值