なぜgen_tcp:controlling_process()badargで失敗しましたか?
質問
私はejabberdの一つのモジュールに問題があります。それはhttp_bindです。 私は深くデバッグするときしかし、私は後にソケットを受け入れることを発見し、産卵します プロセスをhadlingとするとき、新規作成されたプロセスのためのレシーブデータのreasignプロセス gen_tcpを呼び出して:?controlling_process()WHY
、badargで失敗しました...
{ok, Socket} = get_tcp:accept(ListenSocket),
Opts = [{active, false}, ...],
% here function return result of proc_lib:spawn_link(handler, ...)
{ok, Pid} = ejabberd_http:start({gen_tcp, Socket}, Opts),
gen_tcp:controlling_process(Socket, Pid),
: {badarg, [
{erlang, port_connect, [#Port<0.140743856>, <0.5939.4350>]},
{inet, tcp_controlling_process, 2},
{ejabberd_socket,start,4},
{ejabberd_listener,accept,3},
{proc_lib,init_p,5}
]}
任意のヘルプ?
解決
おそらくソケットまたはプロセスがcontrolling_processを呼び出す前にクラッシュしています。
http://www.erlang.org/doc/man /erlang.html#port_connect-2する
彼らは私にはわからないクラッシュしましたなぜは、あなたはそれが?
必要としてejabberdプロセスが実行されていることを確認してきました所属していません StackOverflow