Kub*_*ias 9 erlang erlang-shell
我的docker容器(CentOS)上有一些奇怪的行为.当我连接到它时,有一个正在运行的Erlang VM实例(api@127.0.0.1)我无法使用-remsh参数连接它,但我可以ping它.我的Erlang节点(api@127.0.0.1)可以正常工作.
bash-4.2# ./bin/erl -name 'remote@127.0.0.1' -remsh 'api@127.0.0.1'
Eshell V6.1 (abort with ^G)
(remote@127.0.0.1)1> node().
'remote@127.0.0.1'
(remote@127.0.0.1)2> net_adm:ping('api@127.0.0.1').
pong
(remote@127.0.0.1)3> erlang:system_info(system_version).
"Erlang/OTP 17 [erts-6.1] [source] [64-bit] [smp:8:8] [async-threads:10] [hipe] [kernel-poll:false]\n"
(remote@127.0.0.1)4> rpc:call('api@127.0.0.1', erlang, node, []).
'api@127.0.0.1'
Run Code Online (Sandbox Code Playgroud)
运行了2个linux进程 - 一个用于实际VM,另一个用于尝试调用远程shell的进程
26 ? Sl 40:46 /home/vcap/app/bin/beam.smp -- -root /home/vcap/app -progname erl -- -home /home/vcap/app/ -- -name api@127.0.0.1 -boot releases/14.2.0299/start -config sys -boot_var PATH lib -noshell
32542 ? Sl+ 0:00 /home/vcap/app/bin/beam.smp -- -root /home/vcap/app -progname erl -- -home /home/vcap/app -- -name remote@127.0.0.1 -remsh api@127.0.0.1
Run Code Online (Sandbox Code Playgroud)
当我将Erlang二进制文件复制到主机(Arch Linux)并运行./bin/erl时,我得到了不同的结果:
[jodias@arch tmp]$ ./bin/erl
Erlang/OTP 17 [erts-6.1] [source] [64-bit] [smp:4:4] [async-threads:10] [hipe] [kernel-poll:false]
Eshell V6.1 (abort with ^G)
1>
Run Code Online (Sandbox Code Playgroud)
请注意,打印的Erlang系统版本在docker容器上缺失(但Erlang二进制文件完全相同).