【发布时间】:2021-08-19 06:11:40
【问题描述】:
尝试运行编程 erlang 书中的示例应用程序 sellaprime 应用程序。我使用主管内的测试功能测试了主管代码。所以,主管应该没问题。应用程序已加载,但应用程序启动遇到以下错误:
=INFO REPORT==== 31-May-2021::22:39:44.235167 ===
application: sellaprime
exited: {bad_return,
{{sellaprime_app,start,[normal,[]]},
{'EXIT',
{undef,
[{sellaprime_app,start,[normal,[]],[]},
{application_master,start_supervisor,3,
[{file,"application_master.erl"},{line,331}]},
{application_master,start_the_app,5,
[{file,"application_master.erl"},{line,313}]},
{application_master,start_it_new,7,
[{file,"application_master.erl"},
{line,299}]}]}}}}
type: temporary
需要帮助找出错误。
这是文件,sellaprime_app.erl:
-module(sellaprime_app).
-behaviour(application).
-export([start/2, stop/1]).
start(_Type, StartArgs) -> sellaprime_supervisor:start_link(StartArgs).
stop(_State) -> ok.
还有sellaprime_supervisor.erl:
-module(sellaprime_supervisor).
-behaviour(supervisor).
-export([start/0, start_in_shell_for_testing/0, start_link/1, init/1]).
start() ->
spawn(fun() -> supervisor:start_link({local, ?MODULE}, ?MODULE, _Arg=[]) end).
start_in_shell_for_testing() ->
{ok, Pid} = supervisor:start_link({local, ?MODULE}, ?MODULE, _Arg=[]),
unlink(Pid).
start_link(Args) ->
supervisor:start_link({local, ?MODULE}, ?MODULE, Args).
init([]) ->
gen_event:swap_handler(alarm_handler, {alarm_handler, swap}, {my_alarm_handler, xyz}),
{ok, {{one_for_one, 3, 10},
[{tag1,
{area_server, start_link, []},
permanent,
10000,
worker,
[area_server]},
{tag2,
{prime_server, start_link, []},
permanent,
10000,
worker,
[prime_server]}
]}}.
【问题讨论】: