[sr-dev] git:4.2:9b44517c: kazoo - fix timer interval
Luis Azedo
luis at 2600hz.com
Fri Feb 27 16:59:14 CET 2015
Module: kamailio
Branch: 4.2
Commit: 9b44517c6e8efe9e6445940ee7f0c505abef613d
URL: https://github.com/kamailio/kamailio/commit/9b44517c6e8efe9e6445940ee7f0c505abef613d
Author: Luis Azedo <luis at 2600hz.com>
Committer: Luis Azedo <luis at 2600hz.com>
Date: 2015-02-24T22:27:47Z
kazoo - fix timer interval
amqp timer and publish proc take all cpu
new param amqp_timmer_process_interval in MS
and removed the timeout on select from tcp workers
(cherry picked from commit 7ae9f6693406c76d7d58389d5cf4ccaa44958a02)
---
Modified: modules/kazoo/kazoo.c
Modified: modules/kazoo/kz_amqp.c
---
Diff: https://github.com/kamailio/kamailio/commit/9b44517c6e8efe9e6445940ee7f0c505abef613d.diff
Patch: https://github.com/kamailio/kamailio/commit/9b44517c6e8efe9e6445940ee7f0c505abef613d.patch
---
diff --git a/modules/kazoo/kazoo.c b/modules/kazoo/kazoo.c
index d110131..c3f6a00 100644
--- a/modules/kazoo/kazoo.c
+++ b/modules/kazoo/kazoo.c
@@ -70,6 +70,8 @@ struct timeval kz_sock_tv = (struct timeval){0,100000};
struct timeval kz_amqp_tv = (struct timeval){0,100000};
struct timeval kz_qtimeout_tv = (struct timeval){2,0};
struct timeval kz_ack_tv = (struct timeval){0,100000};
+struct timeval kz_timer_tv = (struct timeval){0,200000};
+int kz_timer_ms = 200;
str dbk_consumer_event_key = str_init("Event-Category");
@@ -148,6 +150,7 @@ static param_export_t params[] = {
// {"mwi_expires", INT_PARAM, &dbk_mwi_expires},
{"amqp_connection", STR_PARAM|USE_FUNC_PARAM,(void*)kz_amqp_add_connection},
{"amqp_max_channels", INT_PARAM, &dbk_channels},
+ {"amqp_timmer_process_interval", INT_PARAM, &kz_timer_ms},
{"amqp_consumer_ack_timeout_micro", INT_PARAM, &kz_ack_tv.tv_usec},
{"amqp_consumer_ack_timeout_sec", INT_PARAM, &kz_ack_tv.tv_sec},
{"amqp_interprocess_timeout_micro", INT_PARAM, &kz_sock_tv.tv_usec},
@@ -235,6 +238,11 @@ static int mod_init(void) {
if(!kz_amqp_init()) {
return -1;
}
+
+ if(kz_timer_ms > 0) {
+ kz_timer_tv.tv_usec = (kz_timer_ms 1000) * 1000;
+ kz_timer_tv.tv_sec = kz_timer_ms / 1000;
+ }
if(dbk_pua_mode == 1) {
kz_db_url.len = kz_db_url.s ? strlen(kz_db_url.s) : 0;
diff --git a/modules/kazoo/kz_amqp.c b/modules/kazoo/kz_amqp.c
index 498347e..f1534d8 100644
--- a/modules/kazoo/kz_amqp.c
+++ b/modules/kazoo/kz_amqp.c
@@ -35,6 +35,7 @@ extern struct timeval kz_sock_tv;
extern struct timeval kz_amqp_tv;
extern struct timeval kz_qtimeout_tv;
extern struct timeval kz_ack_tv;
+extern struct timeval kz_timer_tv;
extern int dbk_internal_loop_count;
extern int dbk_consumer_loop_count;
@@ -1909,6 +1910,7 @@ void kz_amqp_timeout_proc(int child_no)
int i;
while(1) {
struct timeval now;
+ usleep(kz_timer_tv.tv_usec);
for(i=0; i < dbk_channels; i++) {
gettimeofday(&now, NULL);
if(channels[i].state == KZ_AMQP_CALLING
@@ -1972,7 +1974,7 @@ void kz_amqp_publisher_proc(int child_no)
while(OK) {
FD_ZERO(&fdset);
FD_SET(data_pipe, &fdset);
- selret = select(FD_SETSIZE, &fdset, NULL, NULL, &kz_sock_tv);
+ selret = select(FD_SETSIZE, &fdset, NULL, NULL, NULL);
if (selret < 0) {
LM_ERR("select() failed: %s\n", strerror(errno));
continue;
More information about the sr-dev
mailing list