Search code examples
linuxcachingiodisk

How to stop page cache for disk I/O in my linux system?


Here is my system based on Linux2.6.32.12:
1 It contains 20 processes which occupy a lot of usr cpu 2 It needs to write data on rate 100M/s to disk and those data would not be used recently.

What I expect:
It can run steadily and disk I/O would not affect my system.

My problem:
At the beginning, the system run as I thought. But as the time passed, Linux would cache a lot data for the disk I/O, that lead to physical memory reducing. At last, there will be not enough memory, then Linux will swap in/out my processes. It will cause I/O problem that a lot cpu time was used to I/O.

What I have try:
I try to solved the problem, by "fsync" everytime I write a large block.But the physical memory is still decreasing while cached increasing.

How to stop page cache here, it's useless for me

More infomation:
When Top show free 46963m, all is well including cpu %wa is low and vmstat shows no si or so.
When Top show free 273m, %wa is so high which affect my processes and vmstat shows a lot si and so.


Solution

  • I'm not sure that changing something will affect overall performance.

    Maybe you might use posix_fadvise(2) and sync_file_range(2) in your program (and more rarely fsync(2) or fdatasync(2) or sync(2) or syncfs(2), ...). Also look at madvise(2), mlock(2) and munlock(2), and of course mmap(2) and munmap(2). Perhaps ionice(1) could help.

    In the reader process, you might perhaps use readhahead(2) (perhaps in a separate thread).

    Upgrading your kernel (to a 3.6 or better) could certainly help: Linux has improved significantly on these points since 2.6.32 which is really old.