2

我无法启动牛仔应用程序,它给了我以下错误。出于某种原因,牧场没有启动,尽管我已经在我的应用程序中添加了启动牧场的代码。

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

我想弄清楚这里出了什么问题

谁能指出我可以用作模板的牛仔工作样本。我正在使用钢筋来编译代码。我不认为这应该有任何区别。我正在使用以下命令启动应用程序

erl -pa ./ebin ./deps/*/ebin

4

1 回答 1

7

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

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

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

于 2013-09-16T12:30:36.770 回答