[Freeswitch-svn] [commit] r5804 - in freeswitch/trunk/src: . include include/private mod/applications/mod_commands
Freeswitch SVN
anthm at freeswitch.org
Thu Oct 4 17:35:51 EDT 2007
Author: anthm
Date: Thu Oct 4 17:35:50 2007
New Revision: 5804
Modified:
freeswitch/trunk/src/include/private/switch_core_pvt.h
freeswitch/trunk/src/include/switch_types.h
freeswitch/trunk/src/mod/applications/mod_commands/mod_commands.c
freeswitch/trunk/src/softtimer.c
freeswitch/trunk/src/switch_core.c
Log:
add sps count to the status output
Modified: freeswitch/trunk/src/include/private/switch_core_pvt.h
==============================================================================
--- freeswitch/trunk/src/include/private/switch_core_pvt.h (original)
+++ freeswitch/trunk/src/include/private/switch_core_pvt.h Thu Oct 4 17:35:50 2007
@@ -156,6 +156,7 @@
switch_mutex_t *throttle_mutex;
uint32_t sps_total;
int32_t sps;
+ int32_t sps_last;
switch_log_level_t hard_log_level;
};
Modified: freeswitch/trunk/src/include/switch_types.h
==============================================================================
--- freeswitch/trunk/src/include/switch_types.h (original)
+++ freeswitch/trunk/src/include/switch_types.h Thu Oct 4 17:35:50 2007
@@ -1008,6 +1008,7 @@
SCSC_CHECK_RUNNING,
SCSC_LOGLEVEL,
SCSC_SPS,
+ SCSC_LAST_SPS,
SCSC_RECLAIM
} switch_session_ctl_t;
Modified: freeswitch/trunk/src/mod/applications/mod_commands/mod_commands.c
==============================================================================
--- freeswitch/trunk/src/mod/applications/mod_commands/mod_commands.c (original)
+++ freeswitch/trunk/src/mod/applications/mod_commands/mod_commands.c Thu Oct 4 17:35:50 2007
@@ -44,6 +44,7 @@
uint8_t html = 0;
switch_core_time_duration_t duration;
char *http = NULL;
+ int sps, last_sps;
if (session) {
return SWITCH_STATUS_FALSE;
@@ -68,7 +69,9 @@
duration.mms == 1 ? "" : "s");
stream->write_function(stream, "%"SWITCH_SIZE_T_FMT" sessions since startup\n", switch_core_session_id() - 1 );
- stream->write_function(stream, "%d sessions\n", switch_core_session_count());
+ switch_core_session_ctl(SCSC_LAST_SPS, &last_sps);
+ switch_core_session_ctl(SCSC_SPS, &sps);
+ stream->write_function(stream, "%d session(s) %d/%d\n", switch_core_session_count(), last_sps, sps);
if (html) {
stream->write_function(stream, "</b>\n");
@@ -130,6 +133,9 @@
}
switch_core_session_ctl(SCSC_LOGLEVEL, &arg);
stream->write_function(stream, "log level: %s [%d]\n", switch_log_level2str(arg), arg);
+ } else if (!strcasecmp(argv[0], "last_sps")) {
+ switch_core_session_ctl(SCSC_LAST_SPS, &arg);
+ stream->write_function(stream, "last sessions per second: %d\n", arg);
} else if (!strcasecmp(argv[0], "sps")) {
if (argc > 1) {
arg = atoi(argv[1]);
Modified: freeswitch/trunk/src/softtimer.c
==============================================================================
--- freeswitch/trunk/src/softtimer.c (original)
+++ freeswitch/trunk/src/softtimer.c Thu Oct 4 17:35:50 2007
@@ -206,7 +206,7 @@
uint32_t current_ms = 0;
uint32_t x, tick = 0;
switch_time_t ts = 0;
-
+
memset(&globals, 0, sizeof(globals));
switch_mutex_init(&globals.mutex, SWITCH_MUTEX_NESTED, module_pool);
@@ -229,6 +229,7 @@
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_CRIT, "Over Session Rate of %d!\n", runtime.sps_total);
}
switch_mutex_lock(runtime.throttle_mutex);
+ runtime.sps_last = runtime.sps_total - runtime.sps;
runtime.sps = runtime.sps_total;
switch_mutex_unlock(runtime.throttle_mutex);
tick = 0;
Modified: freeswitch/trunk/src/switch_core.c
==============================================================================
--- freeswitch/trunk/src/switch_core.c (original)
+++ freeswitch/trunk/src/switch_core.c Thu Oct 4 17:35:50 2007
@@ -657,6 +657,9 @@
}
*val = runtime.hard_log_level;
break;
+ case SCSC_LAST_SPS:
+ *val = runtime.sps_last;
+ break;
case SCSC_SPS:
switch_mutex_lock(runtime.throttle_mutex);
if (*val > 0) {
More information about the Freeswitch-svn
mailing list