mirror of
https://github.com/samba-team/samba.git
synced 2025-01-12 09:18:10 +03:00
tsocket: optimize tdgram_bsd a lot
The desire is to do as less syscalls during the tdgram_sendto_send/recv() and tdgram_recvfrom_send/recv() operations. 1. we first try the sendto()/recvfrom() syscall and only use a fd event if we got EAGAIN. 2. we cache the fd event and only change it's flags if really needed. For the highload case we do almost no epoll_ctl() and epoll_wait()/select() syscalls anymore. This speeds up the LDAP-BENCH-CLDAP test by more than 20%. (With a modified version of this test which let the server skip any ldb calls and just return success I'm getting about 8000 requests per second, while I'm getting just about 6000 requests per second without optimization) metze
This commit is contained in:
parent
85742dbc06
commit
c59ee5a139
@ -1313,6 +1313,10 @@ static void tdgram_bsd_fde_handler(struct tevent_context *ev,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (flags & TEVENT_FD_READ) {
|
if (flags & TEVENT_FD_READ) {
|
||||||
|
if (!bsds->readable_handler) {
|
||||||
|
TEVENT_FD_NOT_READABLE(bsds->fde);
|
||||||
|
return;
|
||||||
|
}
|
||||||
bsds->readable_handler(bsds->readable_private);
|
bsds->readable_handler(bsds->readable_private);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1328,18 +1332,24 @@ static int tdgram_bsd_set_readable_handler(struct tdgram_bsd *bsds,
|
|||||||
errno = EINVAL;
|
errno = EINVAL;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
if (!bsds->readable_handler) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
bsds->readable_handler = NULL;
|
bsds->readable_handler = NULL;
|
||||||
bsds->readable_private = NULL;
|
bsds->readable_private = NULL;
|
||||||
TEVENT_FD_NOT_READABLE(bsds->fde);
|
|
||||||
|
|
||||||
if (bsds->fde && !bsds->writeable_handler) {
|
return 0;
|
||||||
/* we don't need the fd event anymore */
|
}
|
||||||
|
|
||||||
|
/* read and write must use the same tevent_context */
|
||||||
|
if (bsds->event_ptr != ev) {
|
||||||
|
if (bsds->readable_handler || bsds->writeable_handler) {
|
||||||
|
errno = EINVAL;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
bsds->event_ptr = NULL;
|
bsds->event_ptr = NULL;
|
||||||
TALLOC_FREE(bsds->fde);
|
TALLOC_FREE(bsds->fde);
|
||||||
}
|
}
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (bsds->fde == NULL) {
|
if (bsds->fde == NULL) {
|
||||||
bsds->fde = tevent_add_fd(ev, bsds,
|
bsds->fde = tevent_add_fd(ev, bsds,
|
||||||
@ -1352,15 +1362,10 @@ static int tdgram_bsd_set_readable_handler(struct tdgram_bsd *bsds,
|
|||||||
|
|
||||||
/* cache the event context we're running on */
|
/* cache the event context we're running on */
|
||||||
bsds->event_ptr = ev;
|
bsds->event_ptr = ev;
|
||||||
}
|
} else if (!bsds->readable_handler) {
|
||||||
|
|
||||||
/* read and write must use the same tevent_context */
|
|
||||||
if (bsds->event_ptr != ev) {
|
|
||||||
errno = EINVAL;
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
TEVENT_FD_READABLE(bsds->fde);
|
TEVENT_FD_READABLE(bsds->fde);
|
||||||
|
}
|
||||||
|
|
||||||
bsds->readable_handler = handler;
|
bsds->readable_handler = handler;
|
||||||
bsds->readable_private = private_data;
|
bsds->readable_private = private_data;
|
||||||
|
|
||||||
@ -1377,18 +1382,25 @@ static int tdgram_bsd_set_writeable_handler(struct tdgram_bsd *bsds,
|
|||||||
errno = EINVAL;
|
errno = EINVAL;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
if (!bsds->writeable_handler) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
bsds->writeable_handler = NULL;
|
bsds->writeable_handler = NULL;
|
||||||
bsds->writeable_private = NULL;
|
bsds->writeable_private = NULL;
|
||||||
TEVENT_FD_NOT_WRITEABLE(bsds->fde);
|
TEVENT_FD_NOT_WRITEABLE(bsds->fde);
|
||||||
|
|
||||||
if (bsds->fde && !bsds->readable_handler) {
|
return 0;
|
||||||
/* we don't need the fd event anymore */
|
}
|
||||||
|
|
||||||
|
/* read and write must use the same tevent_context */
|
||||||
|
if (bsds->event_ptr != ev) {
|
||||||
|
if (bsds->readable_handler || bsds->writeable_handler) {
|
||||||
|
errno = EINVAL;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
bsds->event_ptr = NULL;
|
bsds->event_ptr = NULL;
|
||||||
TALLOC_FREE(bsds->fde);
|
TALLOC_FREE(bsds->fde);
|
||||||
}
|
}
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (bsds->fde == NULL) {
|
if (bsds->fde == NULL) {
|
||||||
bsds->fde = tevent_add_fd(ev, bsds,
|
bsds->fde = tevent_add_fd(ev, bsds,
|
||||||
@ -1401,15 +1413,10 @@ static int tdgram_bsd_set_writeable_handler(struct tdgram_bsd *bsds,
|
|||||||
|
|
||||||
/* cache the event context we're running on */
|
/* cache the event context we're running on */
|
||||||
bsds->event_ptr = ev;
|
bsds->event_ptr = ev;
|
||||||
}
|
} else if (!bsds->writeable_handler) {
|
||||||
|
|
||||||
/* read and write must use the same tevent_context */
|
|
||||||
if (bsds->event_ptr != ev) {
|
|
||||||
errno = EINVAL;
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
TEVENT_FD_WRITEABLE(bsds->fde);
|
TEVENT_FD_WRITEABLE(bsds->fde);
|
||||||
|
}
|
||||||
|
|
||||||
bsds->writeable_handler = handler;
|
bsds->writeable_handler = handler;
|
||||||
bsds->writeable_private = private_data;
|
bsds->writeable_private = private_data;
|
||||||
|
|
||||||
@ -1470,6 +1477,16 @@ static struct tevent_req *tdgram_bsd_recvfrom_send(TALLOC_CTX *mem_ctx,
|
|||||||
goto post;
|
goto post;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* this is a fast path, not waiting for the
|
||||||
|
* socket to become explicit readable gains
|
||||||
|
* about 10%-20% performance in benchmark tests.
|
||||||
|
*/
|
||||||
|
tdgram_bsd_recvfrom_handler(req);
|
||||||
|
if (!tevent_req_is_in_progress(req)) {
|
||||||
|
goto post;
|
||||||
|
}
|
||||||
|
|
||||||
ret = tdgram_bsd_set_readable_handler(bsds, ev,
|
ret = tdgram_bsd_set_readable_handler(bsds, ev,
|
||||||
tdgram_bsd_recvfrom_handler,
|
tdgram_bsd_recvfrom_handler,
|
||||||
req);
|
req);
|
||||||
@ -1634,6 +1651,16 @@ static struct tevent_req *tdgram_bsd_sendto_send(TALLOC_CTX *mem_ctx,
|
|||||||
goto post;
|
goto post;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* this is a fast path, not waiting for the
|
||||||
|
* socket to become explicit writeable gains
|
||||||
|
* about 10%-20% performance in benchmark tests.
|
||||||
|
*/
|
||||||
|
tdgram_bsd_sendto_handler(req);
|
||||||
|
if (!tevent_req_is_in_progress(req)) {
|
||||||
|
goto post;
|
||||||
|
}
|
||||||
|
|
||||||
ret = tdgram_bsd_set_writeable_handler(bsds, ev,
|
ret = tdgram_bsd_set_writeable_handler(bsds, ev,
|
||||||
tdgram_bsd_sendto_handler,
|
tdgram_bsd_sendto_handler,
|
||||||
req);
|
req);
|
||||||
|
Loading…
Reference in New Issue
Block a user