gpt4 book ai didi

erlang - 在初始化 Erlang 主管进程时添加 gen_event 处理程序

转载 作者:行者123 更新时间:2023-12-04 01:44:45 25 4
gpt4 key购买 nike

我正在学习 Erlang,并且正在设法找到答案并相对有效地解决大多数问题的解决方案,但是花了很多时间来解决这个问题:

将处理程序添加到主管进程正在启动的 gen_event 模块的正确方法是什么?到目前为止,在我的探索中,我已经能够设置进程、gen_servers、主管(启动 gen_servers)和 gen_event 模块,但是我尝试向 gen_event 实际添加处理程序的所有操作都使我的主管进程崩溃——有时甚至我的壳!!

主管模块:

-module(sup).
-behaviour(supervisor).

%% API
-export([start_link/0, init/1]).
-export([stop/0]).

start_link() ->
supervisor:start_link({local, ?MODULE}, ?MODULE, []).

init(_) ->
EventServerSpec = #{
id => osc_event_server,
start => {gen_event, start_link, [{local, osc_server}]},
modules => dynamic
},
ChildSpecList = [EventServerSpec, child(frequency), child(bkpt_server)],
SupFlags = #{strategy => rest_for_one,
intensity => 2, period => 3600},
{ok, {SupFlags, ChildSpecList}}.

child(Module) ->
#{id => Module,
start => {Module, start_link, []},
restart => permanent,
shutdown => 2000,
type => worker,
modules => [Module]}.


…以及来自 gen_event 模块 osc_event_server 的一些点点滴滴(希望是相关的!)
...
init([]) ->
{ok, Socket} = gen_udp:open(8980, [binary, {active, false}]),
{ok, #{socket => Socket, target_port => get_target_port()}}.

...
handle_event({send_osc, Path, Data}, State) ->
TargetPort = maps:get(target_port, State),
Socket = maps:get(socket, State),
sendMessage(Socket, TargetPort, Path, Data),
{ok, State};
...


尽管我对 gen_event 行为的理解很差,但我对运行包含这些片段的代码的结果并不感到惊讶:
  • 它启动时不会崩溃
  • 它启动 gen_event 并为其生成一个可引用的 Pid,但从未达到 init 'osc_event_server' block
  • gen_event 没有附加实际的事件处理程序。 “which_handlers”和发送消息的尝试都证实了这一点。

  • 我想合并的两件事:
  • 将特定的事件处理程序(例如,“send_osc”)附加到我的 gen_event 进程……希望来自主管代码
  • 将初始化参数传递给 osc_event_server 模块;我希望至少能够为 UDP 服务器指定端口(而不是硬连线“8980”),并提供我希望我的进程与之通信的远程 UDP 服务器的 IP+端口。

  • 非常感谢。随意批评你看到的任何东西……例如,我的整个方法:) 就我现在所理解的 Erlang 而言,我敢肯定,与我误解的 Erlang 的数量相比,它什么都不是。

    最佳答案

    您应该考虑 gen_event进程作为一种服务存在于您的节点上。通常你会给它一个名字,然后用这个名字和它说话。在您这样做之前,它只是一段独立的代码。

    这意味着如果您想添加处理程序,鉴于您不能在主管中运行任意代码来执行此操作,最简单的方法是让您的主管在 gen_event 之后生成同级进程。流程已准备就绪。

    将新同级标记为 transienttemporary , 有一点点gen_serversupervisor_bridge worker ,并给它 gen_event 的名称和处理程序.小 worker 应该添加处理程序。然后它可以关闭原因 normal ,或者如果需要,监督处理程序,以防它们崩溃以重新添加它们。

    关于erlang - 在初始化 Erlang 主管进程时添加 gen_event 处理程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55756188/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com