我在启动牛仔应用程序时遇到问题,它给了我以下错误。出于某种原因,牧场没有启动,虽然我已经添加了代码来启动我的应用程序中的牧场。
我看到一个新的git repo cowlib被拉了。但仍然遇到麻烦。
1> application:start(satomi).
{error,
{bad_return,
{{satomi_app,start,[normal,[]]},
{'EXIT',
{noproc,
{gen_server,call,
[ranch_sup,
{start_child,
{{ranch_listener_sup,http},
{ranch_listener_sup,start_link,
[http,100,ranch_tcp,
[{port,9090}],
cowboy_protocol,
[{...}]]},
permanent,5000,supervisor,
[ranch_listener_sup]}},
infinity]}}}}}}
=INFO REPORT==== 12-Sep-2013::11:42:46 ===
application: satomi
exited: {bad_return,
{{satomi_app,start,[normal,[]]},
{'EXIT',
{noproc,
{gen_server,call,
[ranch_sup,
{start_child,
{{ranch_listener_sup,http},
{ranch_listener_sup,start_link,
[http,100,ranch_tcp,
[{port,9090}],
cowboy_protocol,
[{env,
[{dispatch,
[{'_',[],[{[],[],toppage_handler,[]}]}]}]}]]},
permanent,5000,supervisor,
[ranch_listener_sup]}},
infinity]}}}}}
type: temporary
以下是我的app.src
>cat satomi.app.src
{application, satomi,
[
{description, ""},
{vsn, "1"},
{registered, []},
{applications, [
kernel,
stdlib,
cowboy
]},
{mod, { satomi_app, []}},
{env, []}
]}.
>cat satomi.erl
-module(satomi).
-export([start/0]).
start()->
ok = application:start(crypto),
ok = application:start(sasl),
ok = application:start(ranch),
ok = application:start(cowlib),
ok = application:start(cowboy),
ok = application:start(satomi).
我想弄清楚这里出了什么问题
有人能指出我可以用作模板的牛仔工作样本吗?我正在使用rebar来编译代码。我认为这不应该有任何区别。 我使用以下命令启动应用程序
erl -pa。/ ebin ./deps/*/ebin
答案 0 :(得分:7)
从shell调用application:start(satomi)
时,它不会自动启动它所依赖的应用程序,需要手动启动它们。
您拥有的satomi:start/0
函数就是这样做的,因此解决方案是从shell调用satomi:start()
。
原因是application:start(satomi)
实际上不会调用satomi:start()
,当应用程序不是Erlang版本的一部分时,它是启动应用程序及其依赖项的便捷方法。
更新:自Erlang R16B02以来,还有application:ensure_all_started。它会自动启动所有依赖项。