Try to start epmd (erlang port mapper daemon) if ei_publish fails
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@10302 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
08f8cb41d8
commit
fb3505ec92
|
@ -1199,10 +1199,17 @@ SWITCH_MODULE_RUNTIME_FUNCTION(mod_erlang_event_runtime)
|
||||||
|
|
||||||
/* return value is -1 for error, a descriptor pointing to epmd otherwise */
|
/* return value is -1 for error, a descriptor pointing to epmd otherwise */
|
||||||
if ((epmdfd = ei_publish(&ec, prefs.port)) == -1) {
|
if ((epmdfd = ei_publish(&ec, prefs.port)) == -1) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Failed to publish port to empd\n");
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_WARNING, "Failed to publish port to empd, trying to start empd manually\n");
|
||||||
/* TODO - start epmd? */
|
if (system("epmd -daemon")) {
|
||||||
close_socket(&listen_list.sockfd);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Failed to start empd manually\n");
|
||||||
return SWITCH_STATUS_GENERR;
|
close_socket(&listen_list.sockfd);
|
||||||
|
return SWITCH_STATUS_GENERR;
|
||||||
|
}
|
||||||
|
if ((epmdfd = ei_publish(&ec, prefs.port)) == -1) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Failed to publish port to empd AGAIN\n");
|
||||||
|
close_socket(&listen_list.sockfd);
|
||||||
|
return SWITCH_STATUS_GENERR;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Connected and published erlang cnode at %s port %u\n", thisnodename, prefs.port);
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Connected and published erlang cnode at %s port %u\n", thisnodename, prefs.port);
|
||||||
|
|
Loading…
Reference in New Issue