summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDmitry Kozlov <xeb@mail.ru>2014-04-11 11:08:29 +0400
committerDmitry Kozlov <xeb@mail.ru>2014-04-14 17:08:39 +0400
commitf2774e5a02d29de71eb64a64565b23090b6f6c5e (patch)
tree716324d581411f36018fe94b933a18c3813d0a5f
parent0d5e6d03c74f3ab6b83d2333480b2441df9a6522 (diff)
downloadaccel-ppp-f2774e5a02d29de71eb64a64565b23090b6f6c5e.tar.gz
accel-ppp-f2774e5a02d29de71eb64a64565b23090b6f6c5e.zip
net-snmp: run snmp in "special" thread
NET-SNMP is built on top of stale file descriptor multiplexing mechanism (select) which prevents to use descriptors with number >= 1024. Due to accel-ppp uses a lots of descriptors NET-SNMP easy overflows this limit and fails and even may crash whole accel-ppp process. This patch runs snmp in special thread which does not share file descritor table with main process, so it can use less descriptors and live in __FD_SETSIZE limit. Signed-off-by: Dmitry Kozlov <xeb@mail.ru>
-rw-r--r--accel-pppd/extra/net-snmp/agent.c18
1 files changed, 10 insertions, 8 deletions
diff --git a/accel-pppd/extra/net-snmp/agent.c b/accel-pppd/extra/net-snmp/agent.c
index 7e06a79..9936460 100644
--- a/accel-pppd/extra/net-snmp/agent.c
+++ b/accel-pppd/extra/net-snmp/agent.c
@@ -1,5 +1,6 @@
#include <pthread.h>
#include <signal.h>
+#include <sys/wait.h>
#include <net-snmp/net-snmp-config.h>
#include <net-snmp/net-snmp-includes.h>
@@ -25,8 +26,8 @@ static int conf_master = 0;
static oid* oid_prefix;
static size_t oid_prefix_size;*/
-static pthread_t snmp_thr;
static int snmp_term = 0;
+static int snmp_pid;
/*int accel_ppp_alloc_oid(oid tail, size_t size, oid **oid)
{
@@ -69,7 +70,7 @@ static int agent_log(int major, int minor, void *serv_arg, void *cl_arg)
return 0;
}
-static void *snmp_thread(void *a)
+static int snmp_thread(void *a)
{
sigset_t set;
@@ -105,22 +106,22 @@ static void *snmp_thread(void *a)
if (conf_master)
init_master_agent();
- while (!snmp_term) {
+ while (!snmp_term)
agent_check_and_process(1);
- }
snmp_shutdown(conf_agent_name);
SOCK_CLEANUP;
- return NULL;
+ return 0;
}
static void snmp_ctx_close(struct triton_context_t *ctx)
{
+ int status;
snmp_term = 1;
- pthread_cancel(snmp_thr);
- pthread_join(snmp_thr, NULL);
+ kill(snmp_pid, 32);
+ waitpid(snmp_pid, &status, 0);
triton_context_unregister(ctx);
}
@@ -144,7 +145,8 @@ static void init(void)
if (opt)
conf_oid_prefix = opt;*/
- pthread_create(&snmp_thr, NULL, snmp_thread, NULL);
+ snmp_pid = clone(snmp_thread, malloc(1024*1024) + 1024*1024, CLONE_SIGHAND|CLONE_FS|CLONE_VM|CLONE_THREAD, NULL);
+
triton_context_register(&ctx, NULL);
triton_context_wakeup(&ctx);
triton_collect_cpu_usage();