Erlang节点互联失败原因分析以及解决方案

转载自Erlang非业余研究

今天和项仲在部署新系统的时候发现节点间ping不成功的情况,类似

1> net_adm:ping('xx@ip1').      
pang

由于这个问题比较普遍,我就记录下一步步的排除步骤.

首先从原理上分析下!由于erlang节点间通讯是透过tcp来进行的,所以我们确保以下几点:    
1. 确保网络连接是通的,可以透过ping来查看。    
2. 确保网络连接上tcp是可以通的,可以透过netcat在二个节点所在的机器上分别开个服务器端和客户端进行验证。    
3. 确保端口是防火墙友好的。erlang的节点是登记在epmd服务上的,所以4369端口要能访问,其次节点的动态端口是可以访问的。

epmd -names      
epmd: up and running on port 4369 with data:      
name xx at port 46627      

同样可以用netcat来验证。    
4. erlang节点的cookie是一样的,可以透过setcookie来解决。

这几点确认无误后,就可以开始排查问题了。    
首先交代下环境,二台机器IP分别是10.1.150.12,10.232.31.89, 上面分别运行Erlang版本R16B和R14B04,cookie统一设置为456789。    
接着我们来演习下,首先我们10.1.150.12在节点A上起个节点’xx@10.1.150.12′,如下:

# erl -name xx@`hostname -i` -setcookie 456789

Erlang R16B (erts-5.10) 1 [64-bit] [smp:24:24] [async-threads:0] [hipe] [kernel-poll:false]

Eshell V5.10  (abort with ^G)

(xx@10.1.150.12)1>

=ERROR REPORT==== 28-Mar-2012::13:25:42 ===

** Connection attempt from disallowed node 'yy@10.232.31.89' **

同时我们在10.232.31.89上运行另外一个节点’yy@10.232.31.89′进行节点间连接,如下:

$erl -name yy@`hostname -i` -setcookie 456789

Erlang R14B04 (erts-5.8.5) 1 [64-bit] [smp:16:16] [rq:16] [async-threads:0] [hipe] [kernel-poll:false]

Eshell V5.8.5  (abort with ^G)

(yy@10.232.31.89)1>  net_adm:ping('xx@10.1.150.12').

pang

我们看到节点无法互通,出错的原因是”** Connection attempt from disallowed node ‘yy@10.232.31.89′ ** “.    
有提示消息就好办, 在otp源码目录下简单的运行:

# grep -rin "disallowed node" .

./lib/kernel/src/dist_util.erl:154:                   "disallowed node ~w ** ~n", [Node]),

./lib/kernel/src/dist_util.erl:603:                           "disallowed node ~w ** ~n", [NodeB]),

./lib/kernel/src/dist_util.erl:623:                           "disallowed node ~w ** ~n", [NodeB]),

./lib/kernel/src/net_kernel.erl:1149:                 "disallowed node ~w ** ~n", [Node]),

我们可以看到有4个函数有可能打印这个语句,分别是:    
1. is_allowed %% check if connecting node is allowed to connect with allow-node-scheme    
2 .recv_challenge_reply %% wait for challenge response after send_challenge    
3. recv_challenge_ack    
4. setup %% Set up connection to a new node.

其中和被动连接相关的俄只有1,2,3这几种情况.

情况1: 节点间allow相关的东西可以参考这篇文章:Erlang如何限制节点对集群的访问之net_kernel:allow    
我们来排除下allow导致问题的原因,把allow设成[],允许任意节点访问:

2> net_kernel:allow([]).      
ok      
(xx@10.1.150.12)2>      
=ERROR REPORT==== 28-Mar-2012::13:36:09 ===      
** Connection attempt from disallowed node ‘yy@10.232.31.89′ **

很清楚,这样并没有解决问题。

那就可以肯定是第2,3个原因了,回头来看下我们的版本号:    
R14B04 和 R16B, 差了二个大版本, 这个是核心原因。    
换成同样的版本的erlang问题应该解决!如下:

$erl -name yy@`hostname -i` -setcookie 456789

Erlang R16B (erts-5.10) 1 [64-bit] [smp:24:24] [async-threads:0] [hipe] [kernel-poll:false]

Eshell V5.10  (abort with ^G)

(yy@10.232.31.89)1>  net_adm:ping('xx@10.1.150.12').

pong

看来确实解决了!

小结: Erlang版本不混用,即使混用最好不超过2个版本。    
祝玩得开心!

转载于:https://my.oschina.net/szpengvictor/blog/51750

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在安装Erlang时,如果出现授权失败的问题,可以尝试以下步骤解决: 1. 确保您有足够的权限进行安装,可以使用管理员身份运行安装程序。 2. 如果您在安装时遇到了权限问题,可以使用sudo命令进行安装: ``` sudo apt-get install erlang ``` 3. 如果您使用的是Windows系统,可以尝试在命令提示符中以管理员身份运行安装程序。 希望这些步骤能够帮助您解决安装Erlang时的授权问题。 ### 回答2: 当安装Erlang时,授权失败可能有几个原因。 首先,安装Erlang可能需要管理员权限。请确保您在安装过程中具有管理员权限或受管理员授权。 第二,您的操作系统可能具有安全策略,禁止安装未知来源的软件或需要额外的许可证。在这种情况下,请确保您从官方Erlang网站下载的安装程序,并按照操作系统的指引进行安装。如果操作系统提示需要进行额外的许可或授权,请按照指引进行操作。 第三,您的防火墙或安全软件可能阻止了Erlang的安装。请检查您的防火墙和安全软件设置,并确保Erlang的安装程序被允许通过。您可以在防火墙或安全软件的白名单中添加Erlang的安装程序,或者暂时禁用它们以完成安装。 如果以上方法仍然无法解决问题,建议尝试在Erlang官方网站上查找有关安装问题的解决方案。或者,您可以尝试在Erlang的开发者社区或相关论坛上寻求帮助。他们可能能够提供更具体的解决方案或对您的问题进行更详细的分析

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值