aboutsummaryrefslogtreecommitdiffstats
path: root/src/client
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2014-01-21 17:57:22 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2014-01-21 17:57:22 +0000
commit7f9bff354f6b78db3e59dca470d85d3d0338bf16 (patch)
tree0a26ee3c9d755c6edff5c246997e8310f6115424 /src/client
parent8eb283092e7b75defaed26d0222f260ed5172a5e (diff)
downloadrspamd-7f9bff354f6b78db3e59dca470d85d3d0338bf16.tar.gz
rspamd-7f9bff354f6b78db3e59dca470d85d3d0338bf16.zip
Add concurrency limit for the client.
Diffstat (limited to 'src/client')
-rw-r--r--src/client/rspamc.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/src/client/rspamc.c b/src/client/rspamc.c
index 082a0eccc..e7244090b 100644
--- a/src/client/rspamc.c
+++ b/src/client/rspamc.c
@@ -44,6 +44,7 @@ static gchar *classifier = "bayes";
static gchar *local_addr = NULL;
static gint weight = 1;
static gint flag;
+static gint max_requests = 1024;
static gdouble timeout = 5.0;
static gboolean pass_all;
static gboolean tty = FALSE;
@@ -75,6 +76,7 @@ static GOptionEntry entries[] =
{ "json", 'j', 0, G_OPTION_ARG_NONE, &json, "Output json reply", NULL },
{ "headers", 0, 0, G_OPTION_ARG_NONE, &headers, "Output HTTP headers", NULL },
{ "raw", 0, 0, G_OPTION_ARG_NONE, &raw, "Output raw reply from rspamd", NULL },
+ { "max-requests", 'n', 0, G_OPTION_ARG_INT, &max_requests, "Maximum count of parallel requests to rspamd", NULL },
{ NULL, 0, 0, G_OPTION_ARG_NONE, NULL, NULL, NULL }
};
@@ -559,7 +561,7 @@ rspamc_process_input (struct event_base *ev_base, struct rspamc_command *cmd,
gint
main (gint argc, gchar **argv, gchar **env)
{
- gint i, start_argc;
+ gint i, start_argc, cur_req = 0;
GHashTable *kwattrs;
struct rspamc_command *cmd;
FILE *in = NULL;
@@ -642,7 +644,13 @@ main (gint argc, gchar **argv, gchar **env)
exit (EXIT_FAILURE);
}
rspamc_process_input (ev_base, cmd, in, argv[i], kwattrs);
+ cur_req ++;
fclose (in);
+ if (cur_req >= max_requests) {
+ cur_req = 0;
+ /* Wait for completion */
+ event_base_loop (ev_base, 0);
+ }
}
}