summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/config.h6
-rw-r--r--src/replication.c84
2 files changed, 15 insertions, 75 deletions
diff --git a/src/config.h b/src/config.h
index 23de5d3ad..0fcc42972 100644
--- a/src/config.h
+++ b/src/config.h
@@ -133,12 +133,6 @@ void setproctitle(const char *fmt, ...);
/* Byte ordering detection */
#include <sys/types.h> /* This will likely define BYTE_ORDER */
-/* Define redis_sendfile. */
-#if defined(__linux__) || (defined(__APPLE__) && defined(MAC_OS_X_VERSION_10_5))
-#define HAVE_SENDFILE 1
-ssize_t redis_sendfile(int out_fd, int in_fd, off_t offset, size_t count);
-#endif
-
#ifndef BYTE_ORDER
#if (BSD >= 199103)
# include <machine/endian.h>
diff --git a/src/replication.c b/src/replication.c
index 063a8705e..d9bff79ad 100644
--- a/src/replication.c
+++ b/src/replication.c
@@ -1008,41 +1008,10 @@ void removeRDBUsedToSyncReplicas(void) {
}
}
-#if HAVE_SENDFILE
-/* Implements redis_sendfile to transfer data between file descriptors and
- * avoid transferring data to and from user space.
- *
- * The function prototype is just like sendfile(2) on Linux. in_fd is a file
- * descriptor opened for reading and out_fd is a descriptor opened for writing.
- * offset specifies where to start reading data from in_fd. count is the number
- * of bytes to copy between the file descriptors.
- *
- * The return value is the number of bytes written to out_fd, if the transfer
- * was successful. On error, -1 is returned, and errno is set appropriately. */
-ssize_t redis_sendfile(int out_fd, int in_fd, off_t offset, size_t count) {
-#if defined(__linux__)
- #include <sys/sendfile.h>
- return sendfile(out_fd, in_fd, &offset, count);
-
-#elif defined(__APPLE__)
- off_t len = count;
- /* Notice that it may return -1 and errno is set to EAGAIN even if some
- * bytes have been sent successfully and the len argument is set correctly
- * when using a socket marked for non-blocking I/O. */
- if (sendfile(in_fd, out_fd, offset, &len, NULL, 0) == -1 &&
- errno != EAGAIN) return -1;
- else
- return (ssize_t)len;
-
-#endif
- errno = ENOSYS;
- return -1;
-}
-#endif
-
void sendBulkToSlave(connection *conn) {
client *slave = connGetPrivateData(conn);
- ssize_t nwritten;
+ char buf[PROTO_IOBUF_LEN];
+ ssize_t nwritten, buflen;
/* Before sending the RDB file, we send the preamble as configured by the
* replication process. Currently the preamble is just the bulk count of
@@ -1067,46 +1036,23 @@ void sendBulkToSlave(connection *conn) {
}
}
- /* If the preamble was already transferred, send the RDB bulk data.
- * try to use sendfile system call if supported, unless tls is enabled.
- * fallback to normal read+write otherwise. */
- nwritten = 0;
-#if HAVE_SENDFILE
- if (!server.tls_replication) {
- if ((nwritten = redis_sendfile(conn->fd,slave->repldbfd,
- slave->repldboff,PROTO_IOBUF_LEN)) == -1)
- {
- if (errno != EAGAIN) {
- serverLog(LL_WARNING,"Sendfile error sending DB to replica: %s",
- strerror(errno));
- freeClient(slave);
- }
- return;
- }
+ /* If the preamble was already transferred, send the RDB bulk data. */
+ lseek(slave->repldbfd,slave->repldboff,SEEK_SET);
+ buflen = read(slave->repldbfd,buf,PROTO_IOBUF_LEN);
+ if (buflen <= 0) {
+ serverLog(LL_WARNING,"Read error sending DB to replica: %s",
+ (buflen == 0) ? "premature EOF" : strerror(errno));
+ freeClient(slave);
+ return;
}
-#endif
- if (!nwritten) {
- ssize_t buflen;
- char buf[PROTO_IOBUF_LEN];
-
- lseek(slave->repldbfd,slave->repldboff,SEEK_SET);
- buflen = read(slave->repldbfd,buf,PROTO_IOBUF_LEN);
- if (buflen <= 0) {
- serverLog(LL_WARNING,"Read error sending DB to replica: %s",
- (buflen == 0) ? "premature EOF" : strerror(errno));
+ if ((nwritten = connWrite(conn,buf,buflen)) == -1) {
+ if (connGetState(conn) != CONN_STATE_CONNECTED) {
+ serverLog(LL_WARNING,"Write error sending DB to replica: %s",
+ connGetLastError(conn));
freeClient(slave);
- return;
- }
- if ((nwritten = connWrite(conn,buf,buflen)) == -1) {
- if (connGetState(conn) != CONN_STATE_CONNECTED) {
- serverLog(LL_WARNING,"Write error sending DB to replica: %s",
- connGetLastError(conn));
- freeClient(slave);
- }
- return;
}
+ return;
}
-
slave->repldboff += nwritten;
server.stat_net_output_bytes += nwritten;
if (slave->repldboff == slave->repldbsize) {