我已经使用basho rebar编译了我的Erlang应用程序,它生成了一个独立的escript可执行文件。我从命令行运行它,如: ./myapp myconfig.config
我的问题是如何确定运行我的应用程序的Erlang节点名称。在我的应用程序中运行'node()'命令时,它默认返回“nonode @ nohost”,但我想将我的名字命名为该节点(例如mynode@domain.com),所以当我运行'node()'时在我的申请中,我喜欢看'mynode@domain.com'而不是'nonode @ nohost'
我知道“erlang -name'mynode@domain.com'”但请考虑从命令行运行应用程序。我认为Erlang VM会在应用程序生命周期内自动运行和终止。
答案 0 :(得分:15)
最好的方法当然是通过“-sname node”或“-name node @ host”在命令行中设置nodename。 但是可以使用`net_kernel'模块代替。它在http://www.erlang.org/doc/man/net_kernel.html
中描述$ erl
Erlang R15B01 (erts-5.9.1) [source] [64-bit] [smp:2:2] [async-threads:0] [hipe] [kernel-poll:false]
Eshell V5.9.1 (abort with ^G)
1> node().
nonode@nohost
2> net_kernel:start([rumata, shortnames]).
{ok,<0.34.0>}
(rumata@rumata-osx)3> node().
'rumata@rumata-osx'
(rumata@rumata-osx)4> net_kernel:stop().
ok
5> node().
nonode@nohost
6> net_kernel:start(['rumata@myhost', longnames]).
{ok,<0.44.0>}
(rumata@myhost)7> node().
rumata@myhost
答案 1 :(得分:0)
我看了一下用钢筋(氮气)分发的应用程序。它们使用参数-args_file:
传递配置文件中的大多数vm参数erts-5.9\bin\werl -pa %PA% -boot releases/2.1.0/nitrogen -embedded -config etc/app.generated.config -args_file etc/vm.args
并在vm.args中只需使用参数-name来定义节点名称:
-name nitrogen@127.0.0.1
答案 2 :(得分:0)
您可以使用神奇的“模拟器参数”行(如escript docs中所述)。例如:
#!/usr/bin/env escript
%%! -sname ohai
main(_Args) ->
io:format("I am: ~p~n", [node()]).
%%!
- 前缀行被视为在命令行上传递给erl
,允许您从那里指定节点名称。