Erlang组播

时间:2008-09-17 01:07:00

标签: networking erlang multicast

如何在Erlang中使用gen_udp进行多播?我知道它在代码中,它背后没有文档。发送数据显而易见且简单。我想知道如何添加会员资格。不仅在启动时添加成员资格,而且在运行时添加成员资格也很有用。

4 个答案:

答案 0 :(得分:14)

以下是有关如何收听Bonjour / Zeroconf流量的示例代码。

-module(zcclient).

-export([open/2,start/0]).
-export([stop/1,receiver/0]).

open(Addr,Port) ->
   {ok,S} = gen_udp:open(Port,[{reuseaddr,true}, {ip,Addr}, {multicast_ttl,4}, {multicast_loop,false}, binary]),
   inet:setopts(S,[{add_membership,{Addr,{0,0,0,0}}}]),
   S.

close(S) -> gen_udp:close(S).

start() ->
   S=open({224,0,0,251},5353),
   Pid=spawn(?MODULE,receiver,[]),
   gen_udp:controlling_process(S,Pid),
   {S,Pid}.

stop({S,Pid}) ->
   close(S),
   Pid ! stop.

receiver() ->
   receive
       {udp, _Socket, IP, InPortNo, Packet} ->
           io:format("~n~nFrom: ~p~nPort: ~p~nData: ~p~n",[IP,InPortNo,inet_dns:decode(Packet)]),
           receiver();
       stop -> true;
       AnythingElse -> io:format("RECEIVED: ~p~n",[AnythingElse]),
           receiver()
   end. 

答案 1 :(得分:10)

已回答多播发送,收据需要订阅多播组。

它(仍然)似乎没有记录,但之前已经在erlang-questions邮件列表中进行了介绍。 http://www.erlang.org/pipermail/erlang-questions/2003-March/008071.html

    {ok, Socket} = gen_udp:open(Port, [binary, {active, false},
                                       {reuseaddr, true},{ip, Addr}, 
                                       {add_membership, {Addr, LAddr}}]).

其中Addr是组播组,LAddr是本地接口。 (代码由mog提供)

上面使用的相同选项可以传递给inet:setopts,包括{drop_membership, {Addr, LAddr}}以停止收听该群组。

答案 2 :(得分:4)

我尝试在我的电脑上运行此示例。如果我通过打开接收套接字始终得到消息{error,eaddrnotavail}会发生什么?

示例1:这有效:

{ok, Socket} = gen_udp:open(?PORT, [{reuseaddr,true}, {ip,?SERVER_IP},
               {multicast_ttl,4}, {multicast_loop,false}, binary]),

示例2:获取运行时错误:

{ok, Socket} = gen_udp:open(?PORT, [{reuseaddr,true}, {ip,?MULTICAST_IP},
               {multicast_ttl,4}, {multicast_loop,false}, binary]),

% - > {错误,EADDRNOTAVAIL}

-define(SERVER_IP, {10,31,123,123}). % The IP of the current computer
-define(PORT, 5353).
-define(MULTICAST_IP, {224,0,0,251}). 

答案 3 :(得分:0)

多播由IP地址指定

在erlang中与所有语言相同。 IP地址224.0.0.0到239.255.255.255是多播地址。

选择该范围内的地址,检查您是否与已分配的地址重叠,并且您可以继续。

http://www.iana.org/assignments/multicast-addresses