On Thu, Jan 23, 2014 at 11:13:41PM -0600, Stan Hoeppner wrote: > Well, no, not really. I know there are some real quality issues with a > lot of cheap PMP JBODs out there. I was just surprised to see an > experienced Linux sysadmin have bad luck with 3/3 of em. Most folks > using Silicon Image HBAs with SiI PMPs seem to get good performance. I've worked with the raw chips on silicon, have the firmware flashing tool for the PMP, and never saw better than that. So I'm not sure who those most folks are, or what chips they have, but obviously the experience you describe is very different from the one I've seen, or even from what the 2 kernel folks I know who used to maintain them have, since they've abandonned using them due to them being more trouble than they're worth and the performance poor. To be fair, at the time I cared about performance on PMP, I was also using snapshots on LVM and those were so bad that they actually were the performance issue sometimes I got as slow as 5MB/s. Yes, LVM snapshots were horrible for performance, which is why I switched to brtfs now. > Personally, I've never used PMPs. Given the cost ratio between drives > and HBA ports, a quality 4/8 port SAS HBA such as one of the LSIs is a > better solution all around. 4TB drives average $200 each. A five drive > array is $1000. An LSI 8 port 12G SAS HBA with guaranteed > compatibility, quality, support, and performance is $300. A cheap 2 You are correct. When I started with PMPs there was not a single good SATA card that had 10 ports or more and didn't cost $900. That was 4-5 years ago though. Today, I don't use PMPs anymore, except for some enclosures where it's easy to just have one cable and where what you describe would need 5 sata cables to the enclosure, would it not? (unless you use something like USB3, but that's another interface I've had my share of driver bug problems with, so it's not a net win either). > port SATA HBA and 5 port PMP card gives sub optimal performance, iffy > compatibility, and low quality, and is ~$130. $1300 vs $1130. Going > with a cheap SATA HBA and PMP makes no sense. I generally agree. Here I was using it to transfer data off some drives, but indeed I wouldn't use this for a main array. > > Let me think about this: the resync is done at build array time. > > If all the drives are full of 0's indeed there will be nothing to write. > > Given that, I think you're right. > > The initial resync is read-only. It won't modify anything unless > there's a discrepancy. So the stripe cache isn't in play. The larger > stripe cache should indeed increase rebuild rate though. Right, I understood that the first time you explained it. > Actually, instead of me making an educated guess, I'd suggest you run > > ~$ cryptsetup benchmark > > This will tell you precisely what your throughput is with various > settings and ciphers. Depending on what this spits back you may want to > change your setup, assuming we get the IO throughput where it should be. Sigh, debian unstable doesn't have the brand new cryptsetup with that option yet, will have to get it. Either way, I already know my CPU is not a bottleneck, so it's not that important. > > I use btrfs for LV management, so it's easier to encrypt the entire pool. I > > also encrypt any data on any drive at this point, kind of like I wash my > > hands. I'm not saying it's the right thing to do for all, but it's my > > personal choice. I've seen too many drives end up on ebay with data, and I > > don't want to have to worry about this later, or even erasing my own drives > > before sending them back to warranty, especially in cases where maybe I > > can't erase them, but the manufacturer can read them anyway. > > You get the idea... > > So be it. Now let's work to see if we can squeeze every ounce of > performance out of it. Since I get the same speed writing through all the layers as raid5 gets doing a resync without writes and the other layers, I'm not sure how you're suggesting that I can get extra performance. Well, unless you mean just raw swraid5 can be made faster with my drives still. That is likely possible if I get a better sata card to put in my machine or find another way to increase cpu to drive throughput. > You said you had pulled the PMP and connected direct to an HBA, bumping > from 19MB/s to 99MB/s. Did you switch back to the PMP and are now > getting 100MB/s through the PMP? We should be able to get much higher > if it's 3/6G SATA, a little higher if it's 1/5G. No, I did not. I'm not planning on having my destination array (the one I'm writing to) behind a PMP for the reasons we discussed above. The ports are 3MB/s. Obviously I'm not getting the right speed, but I think there is something wrong with the motherboard of the system this is in, causing some bus conflicts and slowdowns. This is something I'll need to investigate outside of this list since it's not related to raid anymore. > > For now, I put dmcrypt on top of md5, I get 100MB/s raw block write speed (actually > > just writing a big file in btrfs and going through all the layers) even > > though it's only using one CPU thread for encryption instead of 2 or more if > > each disk were encrypted under the md5 layer. > > 100MB/s sequential read throughput is very poor for a 5 drive RAID5, > especially with new 4TB drives which can stream well over 130MB/s each. Yes, I totally agree. > > As another test > > gargamel:/mnt/btrfs_pool1# dd if=/dev/md5 of=/dev/null bs=1M count=1024 > > 1073741824 bytes (1.1 GB) copied, 9.78191 s, 110 MB/s > > dd single stream copies are not a valid test of array throughput. This > tells you only the -minimum- throughput of the array. If the array is idle, how is that not a valid block read test? > > So it looks like 100-110MB/s is the read and write speed limit of that array. > To test real maximum throughput install fio, save and run this job file, > and post your results. Monitor CPU burn of dmcrypt, using top is fine, > while running the job to see if it eats all of one core. The job runs > in multiple steps, first creating the eight 1GB test files, then running > the read/write tests against those files. > > [global] > directory=/some/directory > zero_buffers > numjobs=4 > group_reporting > blocksize=1024k > ioengine=libaio > iodepth=16 > direct=1 > size=1g > > [read] > rw=read > stonewall > > [write] > rw=write > stonewall Yeah, I have fio, didn't seem needed here, but I'll it a shot when I get a chance. > > Thanks for you answers again, > > You're welcome. If you wish to wring maximum possible performance from > this rig I'll stick with ya until we get there. You're not far. Just > takes some testing and tweaking unless you have a real hardware > limitation, not a driver setting or firmware issue. Thanks for your offer, although to be honest, I think I'm hitting a hardware problem which I need to look into when I get a chance. > BTW, I don't recall you mentioning which HBA and PMP you're using at the > moment, and whether the PMP is an Addonics card or integrated in a JBOD. > Nor if you're 1.5/3/6G from HBA through PMP to each drive. That PMP is integrated in the jbod, I haven't torn it apart to check which one it was, but I've pretty much gotten slow speeds from those things and more importantly PMPs have bugs during drive hangs and retries which can cause recovery problems and killing swraid5 arrays, so that's why I stopped using them for serious use. The driver authors know about the issues, and some are in the PMP firmware and not something they can work around. > Post your dmesg output showing the drive link speeds if you would, i.e. > ata3: SATA link up 1.5 Gbps (SStatus 113 SControl 310) Yep, very familiar with that unfortunately from my PMP debugging days [ 6.188660] ata3: SATA link up 3.0 Gbps (SStatus 123 SControl 330) [ 6.211533] ata4: SATA link up 3.0 Gbps (SStatus 123 SControl 330) [ 6.444897] ata1.00: SATA link up 3.0 Gbps (SStatus 123 SControl 330) [ 6.444918] ata1.01: SATA link up 3.0 Gbps (SStatus 123 SControl 330) [ 6.445087] ata2.00: SATA link up 6.0 Gbps (SStatus 133 SControl 330) [ 6.445109] ata2.01: SATA link up 3.0 Gbps (SStatus 123 SControl 330) [ 14.179297] ata9: SATA link up 3.0 Gbps (SStatus 123 SControl 300) [ 14.675693] ata10: SATA link up 3.0 Gbps (SStatus 123 SControl 300) [ 15.516390] ata11: SATA link up 3.0 Gbps (SStatus 123 SControl 300) [ 16.008800] ata12: SATA link up 3.0 Gbps (SStatus 123 SControl 300) [ 19.339559] ata14: SATA link up 3.0 Gbps (SStatus 123 SControl 0) [ 19.692273] ata14.00: SATA link up 3.0 Gbps (SStatus 123 SControl 320) [ 20.705263] ata14.01: SATA link up 3.0 Gbps (SStatus 123 SControl 300) [ 21.785956] ata14.02: SATA link up 3.0 Gbps (SStatus 123 SControl 300) [ 22.899091] ata14.03: SATA link up 3.0 Gbps (SStatus 123 SControl 300) [ 23.935813] ata14.04: SATA link up 3.0 Gbps (SStatus 123 SControl 300) Of course, I'm not getting that speed, but again, I'll look into it. Thanks for your suggestions for tweaks. Best, Marc -- "A mouse is a device used to point at the xterm you want to type in" - A.S.R. Microsoft is to operating systems .... .... what McDonalds is to gourmet cooking Home page: http://marc.merlins.org/ -- 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