Re: Linux Raid performance

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 03/04/2010 01:39, Mark Knecht wrote:
On Fri, Apr 2, 2010 at 10:55 AM, Learner Study <learner.study@xxxxxxxxx> wrote:
<SNIP>
2. Secondly, I would like to understand how raid stack (md driver)
scales as we add more cores...if single core gives ~500MB/s, can two
core give ~1000MB/s? can four cores give ~2000MB/s? etc....
<SNIP>

More cores by themselves certainly won't do it for you.

1) More disks in parallel. (striped data)

2) More ports to attach those drives.

3) More bandwidth on those ports. SATA3 is better than SATA2 is better
than SATA is better than PATA, etc. (Obviously disks must match ports,
right? SATA1 disks on SATA3 ports isn't the right thing...)

4) More bus bandwidth getting to those ports. PCI-Express16 is better
than PCI-Express1 is better than PCI, etc.

5) Faster RAID architectures for the number of disks chosen.

Once all of that is in place then possibly more cores will help, but I
suspect even then it probably hard to use 4 billion CPU cycles/second
doing nothing but disk I/O. SATA controllers are all doing DMA so CPU
overhead is relatively *very* low.

Right. As has recently been demonstrated on this list, one core on a slow Xeon can do about 8TB/s of RAID-6 calculations, whereas the theoretical limit on memory bandwidth for the platform is about 6TB/s, so one CPU thread is already faster than the whole system's memory bandwidth. After that, current discs manage about 150MB/s at their peak so you'd need 40+ discs in one array to reach the memory bandwidth limit. The upshot appears to me to be that with current architectures and discs, there's no need for multi-core/multi-threading. Having said that, individual arrays currently run single-threaded, but multiple arrays can run on separate CPU cores if necessary, with traditional process scheduling.

There is experimental support for multi-threading in the kernel right now, which was awful because the threading model didn't work, and which has even more recently been replaced with another experimental multi-threading patch using btrfs thread pooling, which is as yet unproved. So, multi-core / multi-threading support is on the way, but at the moment is not required.

I haven't included references because a quick search of the last month's archives of this list will reveal all of them.

Overall, the bottleneck right now is the discs, as has been the case since ooh forever.

Cheers,

John.
--
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

[Index of Archives]     [Linux RAID Wiki]     [ATA RAID]     [Linux SCSI Target Infrastructure]     [Linux Block]     [Linux IDE]     [Linux SCSI]     [Linux Hams]     [Device Mapper]     [Device Mapper Cryptographics]     [Kernel]     [Linux Admin]     [Linux Net]     [GFS]     [RPM]     [git]     [Yosemite Forum]


  Powered by Linux