运行牛仔应用程序时出错

时间:2013-09-12 19:02:19

标签: erlang cowboy

我在启动牛仔应用程序时遇到问题,它给了我以下错误。出于某种原因,牧场没有启动,虽然我已经添加了代码来启动我的应用程序中的牧场。

我看到一个新的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

1 个答案:

答案 0 :(得分:7)

从shell调用application:start(satomi)时,它不会自动启动它所依赖的应用程序,需要手动启动它们。 您拥有的satomi:start/0函数就是这样做的,因此解决方案是从shell调用satomi:start()

原因是application:start(satomi)实际上不会调用satomi:start(),当应用程序不是Erlang版本的一部分时,它是启动应用程序及其依赖项的便捷方法。

更新:自Erlang R16B02以来,还有application:ensure_all_started。它会自动启动所有依赖项。