【发布时间】:2014-11-03 02:01:30
【问题描述】:
我的项目在 .../deps 中有许多依赖项,其中两个包含在 .../apps 中的 Erlang 应用程序。
rebar.config:
{sub_dirs, ["apps/rmbrDb","apps/rmbrRest","rel"]}.
{lib_dirs, ["deps","apps"]}.
{deps, [
{webmachine, "1.10.*", {git, "git://github.com/basho/webmachine", "HEAD"}},
{riakc, ".*", {git, "git://github.com/basho/riak-erlang-client", "HEAD"}}
]}.
项目编译 (./rebar get-deps compile) 没有错误,并且包含的应用程序确实会生成光束文件。
有问题的应用文件如下所示:
{application,rmbrDb,
[{description,"Database Api for Main"},
{vsn,"0.0.1"},
{modules,[rmbrDb,rmbrDb_app,rmbrDb_sup]},
{registered,[rmbrDb_sup]},
{applications,[kernel,stdlib]},
{mod,{rmbrDb_app,[]}},
{start_phases,[]}]}.
我尝试开始使用 shell 脚本:
exec erl -pa $PWD/ebin $PWD/deps/*/ebin $PWD/apps/*/ebin -boot start_sasl -s reloader -s rmbrDb -s rmbrRest
产生:
{"init terminating in do_boot",{undef,[{rmbrDb,start,[],[]},{init,start_it,1,[]},{init,start_em,1,[]}]}}
Crash dump was written to: erl_crash.dump
init terminating in do_boot ()
日志包含
=mod:rmbrDb
Current size: 7281
Current attributes: 836C0000000...
Current compilation info: 836C0000000...
和
=fun
Module: rmbrDb
Uniq: 118638513
Index: 0
Address: 0x000000001a52b6d0
Native_address: 0x0000000017c8d370
Refc: 1
这表明模块已加载。
rmbrDb_app 文件包含:
-module(rmbrDb_app).
-behaviour(application).
-export([start/2, stop/1]).
-spec start(normal | {takeover, node()} | {failover, node()},
any()) -> {ok, pid()} | {ok, pid(), State::any()} |
{error, Reason::any()}.
start(_StartType, _StartArgs) ->
case rmbrDb_sup:start_link() of
{ok, Pid} ->
{ok, Pid};
Error ->
Error
end.
所以定义了启动函数。
我在 OSX 10.9.4 上工作,使用 Erlang/OTP 17 [erts-6.1] [source] [64-bit] [smp:8:8] Erlang已经编译启动了一些项目,安装是最近的。
我不知道为什么 do_boot 无法启动 rmbrDb
请注意,其他应用程序也无法启动。以先到者为准。
【问题讨论】:
标签: erlang erlang-otp rebar