On Wed, Sep 19, 2012 at 05:16:46PM +1000, NeilBrown wrote: > On Wed, 19 Sep 2012 13:51:06 +0800 Shaohua Li <shli@xxxxxxxxxx> wrote: > > > On Tue, Sep 18, 2012 at 02:57:10PM +1000, NeilBrown wrote: > > > On Wed, 12 Sep 2012 13:29:41 +0800 Shaohua Li <shli@xxxxxxxxxx> wrote: > > > > > > > On Tue, Sep 11, 2012 at 10:59:08AM +1000, NeilBrown wrote: > > > > > On Tue, 31 Jul 2012 16:12:04 +0800 Shaohua Li <shli@xxxxxxxxxx> wrote: > > > > > > > > > > > 2012/7/31 NeilBrown <neilb@xxxxxxx>: > > > > > > > On Thu, 26 Jul 2012 16:01:50 +0800 Shaohua Li <shli@xxxxxxxxxx> wrote: > > > > > > > > > > > > > >> Write has some impacts to SSD: > > > > > > >> 1. wear out flash. Frequent write can speed out the progress. > > > > > > >> 2. increase the burden of garbage collection of SSD firmware. If no space > > > > > > >> left for write, SSD firmware garbage collection will try to free some space. > > > > > > >> 3. slow down subsequent write. After write SSD to some extents (for example, > > > > > > >> write the whole disk), subsequent write will slow down significantly (because > > > > > > >> almost every write invokes garbage collection in such case). > > > > > > >> > > > > > > >> We want to avoid unnecessary write as more as possible. raid sync generally > > > > > > >> involves a lot of unnecessary write. For example, even two disks don't have > > > > > > >> any data, we write the second disk for the whole disk size. > > > > > > >> > > > > > > >> To reduce write, we always compare raid disk data and only write mismatch part. > > > > > > >> This means sync will have extra IO read and memory compare. So this scheme is > > > > > > >> very bad for hard disk raid and sometimes SSD raid too if mismatch part is > > > > > > >> majority. But sometimes this can be very helpful to reduce write, in that case, > > > > > > >> since sync is rare operation, the extra IO/CPU usage is worthy paying. People > > > > > > >> who want to use the feature should understand the risk first. So this ability > > > > > > >> is off by default, a sysfs entry can be used to enable it. > > > > > > >> > > > > > > >> Signed-off-by: Shaohua Li <shli@xxxxxxxxxxxx> > > > > > > >> --- > > > > > > >> drivers/md/md.c | 41 +++++++++++++++++++++++++++++++ > > > > > > >> drivers/md/md.h | 3 ++ > > > > > > >> drivers/md/raid1.c | 70 +++++++++++++++++++++++++++++++++++++++++++++++++---- > > > > > > >> 3 files changed, 110 insertions(+), 4 deletions(-) > > > > > > >> > > > > > > >> Index: linux/drivers/md/md.h > > > > > > >> =================================================================== > > > > > > >> --- linux.orig/drivers/md/md.h 2012-07-25 13:51:00.353775521 +0800 > > > > > > >> +++ linux/drivers/md/md.h 2012-07-26 10:36:38.500740552 +0800 > > > > > > >> @@ -325,6 +325,9 @@ struct mddev { > > > > > > >> #define MD_RECOVERY_FROZEN 9 > > > > > > >> > > > > > > >> unsigned long recovery; > > > > > > >> +#define MD_RECOVERY_MODE_REPAIR 0 > > > > > > >> +#define MD_RECOVERY_MODE_DISCARD 1 > > > > > > >> + unsigned long recovery_mode; > > > > > > > > > > > > > > You have not documented the meaning of these two flags at all, and I don't > > > > > > > feel up to guessing. > > > > > > > > > > > > > > The patch looks more complex that it should be. The behaviour you are > > > > > > > suggesting is exactly the behaviour you get when MD_RECOVERY_REQUESTED is > > > > > > > set, so at most I expect to see a few places where that flag is tested > > > > > > > changed to test something else as well. > > > > > > > > > > > > > > How would this be used? It affects resync and resync happens as soon as the > > > > > > > array is assembled. So when and how would you set the flag which says > > > > > > > "prefer reads to writes"? It seems like it needs to be set in the metadata. > > > > > > > > > > > > > > BTW RAID10 already does this - it reads and compares for a normal sync. So > > > > > > > maybe just tell people to use raid10 if they want this behaviour? > > > > > > > > > > > > It's true, the behavior likes MD_RECOVERY_REQUESTED, ie, read all disks, > > > > > > only do write if two disk data not match. But I hope it works as soon as the > > > > > > array is assembled. Surely we can set in the metadata, but I didn't want to > > > > > > enable it by default, since even with SSD, the read-compare-write isn't optimal > > > > > > some times, because it involves extra IO read and memory compare. > > > > > > > > > > > > It appears MD_RECOVERY_REQUESTED assumes disks are insync. > > > > > > It doesn't read disk !insync, so it doesn't work for assemble. > > > > > > > > > > > > In my mind, user frozen the sync first (with sync_action setting), and then > > > > > > enable read-compare-write, and finally continue the sync. I can't stop > > > > > > a recovery and set MD_RECOVERY_REQUESTED, so I added a flag. > > > > > > Anyway, please suggest what the preferred way for this. > > > > > > > > > > I guess I just don't find this functionality at all convincing. It isn't > > > > > clear when anyone would use it, or how they would use it. It seems best not > > > > > to provide it. > > > > > > > > The background is: For SSD, writting a hard formatted disk and fully filled > > > > disk, the first case could be 300% faster than the second case depending on SSD > > > > firmware and how fragmented the filled disk is. So this isn't a trival > > > > performance issue. > > > > > > > > The usage model is something like this: one disk is borken, add a new disk to > > > > the raid. Currently we copy the whole disk of the first disk to the second. For > > > > SSD, if the first disk and second disk have most data identical or most content > > > > of the first is 0, the copy is very bad. In this scenario, we can avoid some > > > > copy, which will make latter write to the disk faster. Thinking about 300% > > > > faster :). > > > > > > > > I don't think we can do this in underlayer. We don't want to do it always. > > > > Detecting 0 is very expensive. > > > > > > > > And this isn't intrusive to me. We only do the 'copy avoidness' in sync, and > > > > sync is rare event. > > > > > > > > I hope to convince you this is a useful functionality, then we can discuss the > > > > implementation. > > > > > > > > > > Let's start with "when would someone use it". > > > > > > You said that you don't want to make it the default. If something isn't a > > > default it will not be used very often, and will only be used at all if it is > > > reasonably easy to use. > > > So how would someone use this? What would make them choose to use it, and > > > what action would that take to make it happen? > > > > Ok, let me explain the usage model. > > > > For 'compare and avoid write if equal' case: > > 1. update SSD firmware. This doesn't change the data, but we need take one disk > > off from the raid one time. > > 2. One disk has errors, but these errors don't ruin most of the data (for > > example, a pcie error) > > 3. driver/os crash. > > In all these cases, two raid disks must be resync, and they have almost identical > > data. write avoidness will be very helpful for these. > > This is all valid, but doesn't explain how it actually happens. Those are real use cases actually. > Maybe the rsync should initially do a comparison and write-if-different. If > at any time after the first megabyte the fraction of blocks that requires a > write exceeds (say) 10%, we switch to "read one, write the others". > ?? Not sure, but this will limit the usage. For example, in my case 1, the first disk can be written slightly when the second disk is doing firmware upgrade. The write can be in the first 1M for sure. > > For 'compare and trim if source disk data is 0' case: > > If filesystem support trim, this can be enabled always (or at least we can > > enable it if used capacity of the disk is less than 80% for example). > > One of my concerns about this is that I would expect smart flash drives to > actually do this zero-detection internally. Maybe they don't now, but surely > they will soon. By the time we get this feature into production there seems > a reasonably chance that it won't be needed - at least on new hardware. Doesn't make sense to me. zero-detection is very expensive. blindly doing it for every request is insane. While my proposal is just doing it for sync, which is a rare scenario. > And on old hardware I believe that 'discard' isn't particularly fast (as it > cannot be queued ... or something). So I would only want to send a discard > request if it was very large, though I'm not sure how large is large enough. Yep, discard speed varies between SSDs. Some are very slow, much slower than write, some SATA SSD discard speed is even slower than harddisk write. While our card is very fast, faster than write. > > User enables these features and then add disk to downgrade raid. raid resync > > then avoids write or does trim. > > This is the bit that concerns me the most - expecting the user to enable this > sort of feature. In many cases they won't making the code pointless. If an > optimisation is needed, we should use it automatically. Maybe we can for the > first first case. Not sure yet about the second one. I understood your concerns. Giving this feature can harm/benefit, depending on different SSDs and workload/usage model, an interface to enable is preferred. Thanks, Shaohua -- 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