ejabberd_sup
ejabberd_sup是ejabberd的进程监视者(),由ejabberd_app创建。
supervisor(监视进程)
supervisor的功能是启动,停止和监控它的子进程。其作用是保持其子进程运行,在必要的时候重启其子进程,例如子进程死掉的时候。
A supervisor is responsible for starting, stopping and monitoring its child processes. The basic idea of a supervisor is that it should keep its child processes alive by restarting them when necessary.
ejabberd_sup负责创建一堆的子进程并监视它们,这些进程有:
ejabberd_hooks,ejabberd_node_groups,ejabberd_system_monitor,ejabberd_router,ejabberd_sm,ejabberd_s2s,ejabberd_local,
ejabberd_listener,ejabberd_receiver_sup,ejabberd_c2s_sup,ejabberd_s2s_in_sup,ejabberd_s2s_out_sup,ejabberd_service_sup,
ejabberd_http_sup,ejabberd_http_poll_sup,ejabberd_frontend_socket_sup,ejabberd_iq_sup,ejabberd_tmp_sup
这些进程大部分也是以sup结尾的supervisor监视进程.
ejabberd_listener
ejabberd_listener是由ejabberd_sup创建的一个supervisor进程,他负责监视和创建一系列的网络端口监听进程。
ejabberd_listener创建的端口监听进程列表是由配置文件中的listen读取的,配置文件样例如下:
{listen,
[
{4222, ejabberd_c2s, [
%%
%% If TLS is compiled and you installed a SSL
%% certificate, put the correct path to the
%% file and uncomment this line:
%%
%%{certfile, "/path/to/ssl.pem"}, starttls,
{access, c2s},
{shaper, c2s_shaper},
{max_stanza_size, 65536}
]},
{5269, ejabberd_s2s_in, [
{shaper, s2s_shaper},
{max_stanza_size, 131072}
]},
{5280, ejabberd_http, [
http_poll,
web_admin,
{request_handlers, [{["httpbind"], mod_http_bind},{["pub", "archive"], mod_http_fileserver}]}
]},
{5347, ejabberd_service, [{host, "msn-transport.bucc.cn", [{password, "1j5llz!o"}]}]}
]}.
每个进程的格式如下,{port_no,module_name,[args]}
port_no:端口号,同时也是创建进程时的进程标识
module_name:进程模块名称
args:参数列表
ejabberd_receiver
ejabberd_receiver是一个gen_server进程(behaviour),由ejabberd_socket创建
xml_stream
ejabber_c2s
ejabber_cs2是一个gen_fsm(有限状态机),维护一系列client和server之间的状态。gen_fsm的状态改变是由gen_fsm:send_event(FsmRef, Event)触发的。在ejabberd里,ejabberd_receiver通过xml_stream把事件和xml发送至ejabber_c2s改变其状态。
ejabber_c2s有限状态机的初始状态是wait_for_stream,其余的状态有:
wait_for_auth,wait_for_feature_request,wait_for_sasl_response,wait_for_bind,wait_for_session,session_established
没有评论:
发表评论