2010/6/4 Mikael Abrahamsson <swmike@xxxxxxxxx>: > On Fri, 4 Jun 2010, hank peng wrote: > >> I created a raid5 array which consists of 4 SATA disks, then I make a >> XFS on it. Now, I pre-allocate a file using posix_fallocate, its size >> is 512MB. So I think the file space allocated by file system is >> sequential. After that , I am filling data into this file from the >> start position, for example, every time I write 64KB data, but there >> are 1 seconds interval between two writes. >> >> As for RAID5 layer in kernel, due to the 1s interval between writes, >> extra read operation(write penalty) maybe caused although the >> following writes is sequential in this file's space. >> So, in my case, is there some parameters to adjust in order to >> decrease this kind of write penalty? Can we tell raid5 layer to delay >> the read operation for that stripe parity computation because we know >> that the following writes start at the previous writes's end point? > > Please verify that the reads are actually taking place for instance by using > "iostat -x 5". I'd imagine the first write will cause reads, but after that > the whole stripe is going to be in the block cache and thus you avoid any > other reads for that stripe (you'll of course still have to do the writes to > disk). yes, I have used iostat and find that there is no read on /dev/md0 but on the member disks. write(64K) .. 1s .. write(64K) ..1s .. write(64K) .. 1s .. write(64K).. 1s .. write(64K) ..1s .. write(64K) .. 1s .. write(64K) this is my usage pattern. > > Also, why do you worry about the read operations, unless this is combined > with a lot of other IO, I don't see how your above usage pattern would cause > any problems? > > -- > Mikael Abrahamsson email: swmike@xxxxxxxxx > -- The simplest is not all best but the best is surely the simplest! -- To unsubscribe from this list: send the line "unsubscribe linux-raid" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html