[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <23986fd90801171253o56f3dbcbqe44d9f29e719cba1@mail.gmail.com>
Date: Thu, 17 Jan 2008 12:53:58 -0800
From: "Patrick J. LoPresti" <lopresti@...il.com>
To: linux-kernel <linux-kernel@...r.kernel.org>
Subject: Fast network file copy; "recvfile()" ?
I need to copy large (> 100GB) files between machines on a fast
network. Both machines have reasonably fast disk subsystems, with
read/write performance benchmarked at > 800 MB/sec. Using 10GigE cards
and the usual tweaks to tcp_rmem etc., I am getting single-stream TCP
throughput better than 600 MB/sec.
My question is how best to move the actual file. NFS writes appear to
max out at a little over 100 MB/sec on this configuration. FTP and
rcp give me around 250 MB/sec. Thus I am planning to write custom
code to send and receive the file.
For sending, I believe my best options are:
1) O_DIRECT read() + send()
2) mmap() + madvise(WILLNEED) + send()
3) fadvise(WILLNEED) + sendfile()
I am leaning towards (3), since I gather that sendfile() is supposed
to be pretty fast.
My question is what to do on the receiving end. In short, if I want
the equivalent of a "recvfile()" to go with sendfile(), what is my
best bet on Linux?
I will probably try recv() + O_DIRECT write(), but I am curious if
there are other approaches I should try.
Thanks!
- Pat
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists