aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2019-09-18 12:18:18 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2019-09-18 12:18:18 +0100
commit797d916601ee998c7a382f79d6a2e6afdd98235c (patch)
tree0a448c4e94ae6c22ec94af8b3be086fb4454e084
parent7495b2553520b2bc2ea5fe6f8c0888cf2595d65f (diff)
downloadrspamd-797d916601ee998c7a382f79d6a2e6afdd98235c.tar.gz
rspamd-797d916601ee998c7a382f79d6a2e6afdd98235c.zip
[Minor] Reduce libev calls by optimizing IO
-rw-r--r--src/fuzzy_storage.c72
1 files changed, 49 insertions, 23 deletions
diff --git a/src/fuzzy_storage.c b/src/fuzzy_storage.c
index 9e98f3df1..ef2afac4b 100644
--- a/src/fuzzy_storage.c
+++ b/src/fuzzy_storage.c
@@ -560,7 +560,8 @@ rspamd_fuzzy_write_reply (struct fuzzy_session *session)
/* Grab reference to avoid early destruction */
REF_RETAIN (session);
session->io.data = session;
- ev_io_init (&session->io, rspamd_fuzzy_reply_io, session->fd, EV_WRITE);
+ ev_io_init (&session->io,
+ rspamd_fuzzy_reply_io, session->fd, EV_WRITE);
ev_io_start (session->ctx->event_loop, &session->io);
}
else {
@@ -680,15 +681,26 @@ rspamd_fuzzy_make_reply (struct rspamd_fuzzy_cmd *cmd,
rspamd_fuzzy_write_reply (session);
}
-static void
-fuzzy_peer_send_io (EV_P_ ev_io *w, int revents)
+static gboolean
+fuzzy_peer_try_send (gint fd, struct fuzzy_peer_request *up_req)
{
- struct fuzzy_peer_request *up_req = (struct fuzzy_peer_request *)w->data;
gssize r;
- r = write (w->fd, &up_req->cmd, sizeof (up_req->cmd));
+ r = write (fd, &up_req->cmd, sizeof (up_req->cmd));
if (r != sizeof (up_req->cmd)) {
+ return FALSE;
+ }
+
+ return TRUE;
+}
+
+static void
+fuzzy_peer_send_io (EV_P_ ev_io *w, int revents)
+{
+ struct fuzzy_peer_request *up_req = (struct fuzzy_peer_request *)w->data;
+
+ if (!fuzzy_peer_try_send (w->fd, up_req)) {
msg_err ("cannot send update request to the peer: %s", strerror (errno));
}
@@ -768,10 +780,15 @@ rspamd_fuzzy_check_callback (struct rspamd_fuzzy_reply *result, void *ud)
sizeof (up_req->cmd.cmd.shingle.sgl));
}
- up_req->io_ev.data = up_req;
- ev_io_init (&up_req->io_ev, fuzzy_peer_send_io,
- session->ctx->peer_fd, EV_WRITE);
- ev_io_start (session->ctx->event_loop, &up_req->io_ev);
+ if (!fuzzy_peer_try_send (session->ctx->peer_fd, up_req)) {
+ up_req->io_ev.data = up_req;
+ ev_io_init (&up_req->io_ev, fuzzy_peer_send_io,
+ session->ctx->peer_fd, EV_WRITE);
+ ev_io_start (session->ctx->event_loop, &up_req->io_ev);
+ }
+ else {
+ g_free (up_req);
+ }
}
}
@@ -904,10 +921,16 @@ rspamd_fuzzy_process_command (struct fuzzy_session *session)
(gpointer)&up_req->cmd.cmd.shingle :
(gpointer)&up_req->cmd.cmd.normal;
memcpy (ptr, cmd, up_len);
- up_req->io_ev.data = up_req;
- ev_io_init (&up_req->io_ev, fuzzy_peer_send_io,
- session->ctx->peer_fd, EV_WRITE);
- ev_io_start (session->ctx->event_loop, &up_req->io_ev);
+
+ if (!fuzzy_peer_try_send (session->ctx->peer_fd, up_req)) {
+ up_req->io_ev.data = up_req;
+ ev_io_init (&up_req->io_ev, fuzzy_peer_send_io,
+ session->ctx->peer_fd, EV_WRITE);
+ ev_io_start (session->ctx->event_loop, &up_req->io_ev);
+ }
+ else {
+ g_free (up_req);
+ }
}
result.v1.value = 0;
@@ -1785,20 +1808,23 @@ rspamd_fuzzy_peer_io (EV_P_ ev_io *w, int revents)
(struct rspamd_fuzzy_storage_ctx *)w->data;
gssize r;
- r = read (w->fd, &cmd, sizeof (cmd));
+ for (;;) {
+ r = read (w->fd, &cmd, sizeof (cmd));
- if (r != sizeof (cmd)) {
- if (errno == EINTR) {
- rspamd_fuzzy_peer_io (EV_A_ w, revents);
- return;
+ if (r != sizeof (cmd)) {
+ if (errno == EINTR) {
+ continue;
+ }
+ if (errno != EAGAIN) {
+ msg_err ("cannot read command from peers: %s", strerror (errno));
+ }
+
+ break;
}
- if (errno != EAGAIN) {
- msg_err ("cannot read command from peers: %s", strerror (errno));
+ else {
+ g_array_append_val (ctx->updates_pending, cmd);
}
}
- else {
- g_array_append_val (ctx->updates_pending, cmd);
- }
}
static void