Skip to content

Commit

Permalink
Increase receive buffer size whenever possible to beyond largest mess…
Browse files Browse the repository at this point in the history
…age size
  • Loading branch information
ckolivas committed Jan 16, 2016
1 parent 4eed171 commit 1a003db
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 0 deletions.
32 changes: 32 additions & 0 deletions src/ckpool.c
Original file line number Diff line number Diff line change
Expand Up @@ -519,8 +519,12 @@ void empty_buffer(connsock_t *cs)
static void clear_bufline(connsock_t *cs)
{
if (unlikely(!cs->buf)) {
socklen_t optlen = sizeof(cs->rcvbufsiz);

cs->buf = ckzalloc(PAGESIZE);
cs->bufsize = PAGESIZE;
getsockopt(cs->fd, SOL_SOCKET, SO_RCVBUF, &cs->rcvbufsiz, &optlen);
LOGDEBUG("connsock rcvbufsiz set to %d", cs->rcvbufsiz);
} else if (cs->buflen) {
memmove(cs->buf, cs->buf + cs->bufofs, cs->buflen);
memset(cs->buf + cs->buflen, 0, cs->bufofs);
Expand Down Expand Up @@ -549,6 +553,34 @@ static void add_buflen(connsock_t *cs, const char *readbuf, const int len)
cksleep_ms(backoff);
backoff <<= 1;
}
/* Increase receive buffer if possible to larger than the largest
* message we're likely to buffer */
if (buflen > cs->rcvbufsiz && !cs->rcvbufsiz_setfail) {
socklen_t optlen;
int opt;

optlen = sizeof(opt);
opt = buflen * 4 / 3;
setsockopt(cs->fd, SOL_SOCKET, SO_RCVBUF, &opt, optlen);
getsockopt(cs->fd, SOL_SOCKET, SO_RCVBUF, &opt, &optlen);
opt /= 2;
if (opt < buflen) {
LOGDEBUG("Failed to set desired rcvbufsiz of %d unprivileged, only got %d",
buflen, opt);
optlen = sizeof(opt);
opt = buflen * 4 / 3;
setsockopt(cs->fd, SOL_SOCKET, SO_RCVBUFFORCE, &opt, optlen);
getsockopt(cs->fd, SOL_SOCKET, SO_RCVBUF, &opt, &optlen);
opt /= 2;
}
cs->rcvbufsiz = opt;
if (opt < buflen) {
LOGWARNING("Failed to increase rcvbufsiz to %d, increase rmem_max or start %s privileged",
buflen, cs->ckp->name);
cs->rcvbufsiz_setfail = true;
} else
LOGDEBUG("Increased rcvbufsiz to %d of desired %d", opt, buflen);
}
memcpy(cs->buf + cs->bufofs, readbuf, len);
cs->bufofs += len;
cs->buf[cs->bufofs] = '\0';
Expand Down
2 changes: 2 additions & 0 deletions src/ckpool.h
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,8 @@ struct connsock {
int bufofs;
int buflen;
int bufsize;
int rcvbufsiz;
bool rcvbufsiz_setfail;

ckpool_t *ckp;
/* Semaphore used to serialise request/responses */
Expand Down

0 comments on commit 1a003db

Please sign in to comment.