From: Kenny Simpson <theonetruekenny@yahoo.com>
To: linux-kernel@vger.kernel.org
Subject: re: mmap over nfs leads to excessive system load
Date: Tue, 8 Nov 2005 12:57:55 -0800 (PST) [thread overview]
Message-ID: <20051108205755.37541.qmail@web34105.mail.mud.yahoo.com> (raw)
In-Reply-To: <1131480107.32482.48.camel@lade.trondhjem.org>
[-- Attachment #1: Type: text/plain, Size: 413 bytes --]
I am attaching a sample piece of code to show the behavior.
This simply tries to grow a file as fast as it can using different methods.
Use with caution as it does not stop, and will fill the disk if you let it run.
Run as "nfstest -m <filename>" where <filename> is on an nfs mount.
-Kenny
__________________________________
Start your day with Yahoo! - Make it your home page!
http://www.yahoo.com/r/hs
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: 652126289-nfstest.c --]
[-- Type: text/x-csrc; name="nfstest.c", Size: 3153 bytes --]
/* test the write throughput of a sliding mmap window vs simple FILE* */
#define _GNU_SOURCE
#include <errno.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <signal.h>
#include <string.h>
#include <unistd.h>
#include <time.h>
#include <errno.h>
#include <sys/mman.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <sys/time.h>
int total_bytes = 0;
int last_bytes = 0;
struct timeval last_time;
void timeout(int i)
{
struct timeval now;
gettimeofday(&now, 0);
(void) i;
{
double time_diff = (now.tv_sec - last_time.tv_sec) + ((now.tv_usec - last_time.tv_usec) / 1000000.);
int new_bytes = total_bytes;
int diff = new_bytes - last_bytes;
printf("wrote %dk %dM bytes in %f seconds -> %fM/sec\n", diff / 1024, diff / (1024 * 1024), time_diff, (diff / (time_diff * 1000000.)));
last_bytes = new_bytes;
last_time = now;
}
}
void do_mapwrite(int fd)
{
/* lets write as fast as we can.... */
int const window_size = 2 * 1024 * 1024; /* 16k */
int const window_pages = window_size / 4096;
int file_page_offset = 0;
long long file_size = window_size;
ftruncate64(fd, file_size);
{
char* mapping_start = (char*)mmap64(0, window_size, PROT_READ | PROT_WRITE, MAP_SHARED, fd, 0);
/* scribble into buffer and walk the window */
for (;;) {
memset(mapping_start, 0, window_size);
/* grow file */
file_size += window_size;
ftruncate64(fd, file_size);
file_page_offset += window_pages;
/*msync(mapping_start, window_size, MS_SYNC);*/
/*munmap(mapping_start, window_size);*/
/*mapping_start = (char*)mmap64(mapping_start, window_size, PROT_READ | PROT_WRITE, MAP_SHARED | MAP_FIXED, fd, file_size - window_size);*/
remap_file_pages(mapping_start, window_size, 0, file_page_offset, MAP_SHARED);
total_bytes += window_size;
}
}
}
void do_filewrite(int fd)
{
FILE* ptr = fdopen(fd, "w+");
int line_len = 80;
char* buf = (char*)malloc(line_len);
memset(buf, 0, line_len);
for (;;) {
fwrite(buf, line_len, 1, ptr);
total_bytes += line_len;
}
}
void do_syswrite(int fd)
{
int line_len = 64 * 1024;
char* buf = (char*)malloc(line_len);
memset(buf, 0, line_len);
for (;;) {
write(fd, buf, line_len);
total_bytes += line_len;
}
}
int main(int argc, char* argv[])
{
if (argc != 3) {
printf("usage: %s -[mfw] <filename>\n", argv[0]);
return 0;
}
if ((argv[1][0] != '-') ||
((argv[1][1] != 'm') &&
(argv[1][1] != 'w') &&
(argv[1][1] != 'f'))) {
printf("usage: %s -[mfw] <filename>\n", argv[0]);
return 0;
}
int fd = open(argv[2], O_RDWR | O_CREAT | O_LARGEFILE | O_DIRECT, 0644);
if (fd < 0) {
perror("open");
return 0;
}
/* start the clock... */
signal(SIGALRM, timeout);
{
struct itimerval itv;
itv.it_interval.tv_sec = 1;
itv.it_interval.tv_usec = 0;
itv.it_value = itv.it_interval;
setitimer(ITIMER_REAL, &itv, 0);
}
switch (argv[1][1]) {
case 'm': do_mapwrite(fd); break;
case 'f': do_filewrite(fd); break;
case 'w': do_syswrite(fd); break;
}
return 0;
}
next prev parent reply other threads:[~2005-11-08 20:57 UTC|newest]
Thread overview: 53+ messages / expand[flat|nested] mbox.gz Atom feed top
2005-11-08 19:25 mmap over nfs leads to excessive system load Kenny Simpson
2005-11-08 20:01 ` Trond Myklebust
2005-11-08 20:18 ` Kenny Simpson
2005-11-08 20:57 ` Kenny Simpson [this message]
[not found] <20051115224645.27832.qmail@web34103.mail.mud.yahoo.com>
2005-11-15 23:47 ` Kenny Simpson
2005-11-16 4:31 ` William Lee Irwin III
2005-11-16 6:05 ` Kenny Simpson
2005-11-16 7:45 ` Andrew Morton
2005-11-16 14:03 ` Trond Myklebust
2005-11-16 15:01 ` Kenny Simpson
2005-11-16 17:44 ` Trond Myklebust
2005-11-16 18:00 ` Andrew Morton
2005-11-16 18:34 ` Trond Myklebust
2005-11-16 18:38 ` Christoph Hellwig
2005-11-17 13:08 ` Nikita Danilov
2005-11-16 19:09 ` Andrew Morton
2005-11-16 20:05 ` Trond Myklebust
2005-11-16 20:56 ` Kenny Simpson
2005-11-16 21:02 ` Kenny Simpson
2005-11-16 21:09 ` Trond Myklebust
2005-11-16 21:17 ` Kenny Simpson
2005-11-16 21:41 ` Kenny Simpson
2005-11-16 21:57 ` Trond Myklebust
2005-11-16 22:04 ` Kenny Simpson
2005-11-16 22:39 ` Kenny Simpson
2005-11-16 23:06 ` Trond Myklebust
2005-11-17 15:40 ` Chuck Lever
2005-11-17 16:56 ` Kenny Simpson
2005-11-17 16:01 ` Kenny Simpson
2005-11-17 21:04 ` Andrew Morton
2005-11-17 21:15 ` Kenny Simpson
2005-11-18 16:55 ` Kenny Simpson
2005-11-18 17:26 ` Kenny Simpson
2005-11-18 21:57 ` Kenny Simpson
2005-11-17 17:02 ` Chuck Lever
2005-11-17 17:07 ` Trond Myklebust
2005-11-18 19:59 ` Kenny Simpson
2005-11-16 21:31 ` Andrew Morton
2005-11-16 21:49 ` Trond Myklebust
2005-11-16 22:10 ` Andrew Morton
2005-11-16 22:23 ` Trond Myklebust
2005-11-16 22:38 ` Trond Myklebust
2005-11-16 22:50 ` Andrew Morton
2005-11-16 22:44 ` Andrew Morton
2005-11-16 23:10 ` Trond Myklebust
2005-11-17 0:06 ` Trond Myklebust
2005-11-17 0:25 ` Andrew Morton
2005-11-17 0:28 ` Trond Myklebust
2005-11-17 0:38 ` Andrew Morton
2005-11-17 0:47 ` Trond Myklebust
2005-11-16 18:48 ` Kenny Simpson
2005-11-16 19:06 ` Kenny Simpson
-- strict thread matches above, loose matches on Subject: below --
2005-11-08 18:47 Kenny Simpson
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20051108205755.37541.qmail@web34105.mail.mud.yahoo.com \
--to=theonetruekenny@yahoo.com \
--cc=linux-kernel@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox