diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2019-09-18 12:18:18 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2019-09-18 12:18:18 +0100 |
commit | 797d916601ee998c7a382f79d6a2e6afdd98235c (patch) | |
tree | 0a448c4e94ae6c22ec94af8b3be086fb4454e084 | |
parent | 7495b2553520b2bc2ea5fe6f8c0888cf2595d65f (diff) | |
download | rspamd-797d916601ee998c7a382f79d6a2e6afdd98235c.tar.gz rspamd-797d916601ee998c7a382f79d6a2e6afdd98235c.zip |
[Minor] Reduce libev calls by optimizing IO
-rw-r--r-- | src/fuzzy_storage.c | 72 |
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 |