> -----Original Message----- > From: Sage Weil [mailto:sage@xxxxxxxxxxxx] > Sent: Thursday, March 17, 2016 10:34 AM > To: Igor Fedotov <ifedotov@xxxxxxxxxxxx> > Cc: Allen Samuels <Allen.Samuels@xxxxxxxxxxx>; ceph-devel <ceph- > devel@xxxxxxxxxxxxxxx> > Subject: Re: Adding compression support for bluestore. > > > > > Just to clarify I understand the idea properly. Are you suggesting > > > > to simply write out new block to a new extent and update block map > > > > (and read procedure) to use that new extent or remains of the > > > > overwritten extents depending on the read offset? And overwritten > > > > extents are preserved intact until they are fully hidden or some > > > > background cleanup procedure merge them. > > > > If so I can see following pros and cons: > > > > + write is faster > > > > - compressed data read is potentially slower as you might need to > > > > decompress more compressed blocks. > > > > - space usage is higher > > > > - need for garbage collector i.e. additional complexity > > Yes. > > > > > Thus the question is what use patterns are at foreground and > > > > should be the most effective. IMO read performance and space > > > > saving are more important for the cases where compression is needed. > > Any feedback on the above please! > > I'd say "maybe". It's easy to say we should focus on read performance now, > but as soon as we have "support for compression" everybody is going to > want to turn it on on all of their clusters to spend less money on hard disks. > That will definitely include RBD users, where write latency is very important. > > I'm hesitant to take an architectural direction that locks us in. With > something layered over BlueStore I think we're forced to do it all in the initial > phase; with the monolithic approach that integrates it into BlueStore's write > path we have the option to do either one--perhaps based on the particular > request or hints or whatever. I completely agree with Sage. I think it's useful to separate mechanism from policy here. Specifically, I would push to have an onode/extent mechanism representation that supports a wide range of physical representation options (overlays in KV store, overlays in block store, overlapping extents, lazy space recovery, etc.) and allow the policy (i.e., RMW compression before ack, lazy space recovery later, etc...) evolve. It may turn out that the best policies aren't apparent right now or that they may vary based on device and resource characteristics and constraints. Over time there are likely to be many places in the code that become aware of the specifics of the mechanism (integrity checkers, compactors, inspectors, etc.) but could remain ignorant of the policy (i.e., adopt whatever policy was chosen). > > > > > > What do you think? > > > > > > > > > > It would be nice to choose a simpler strategy for the first pass > > > > > that handles a subset of write patterns (i.e., sequential > > > > > writes, possibly > > > > > unaligned) that is still a step in the direction of the more > > > > > robust strategy we expect to implement after that. > > > > > > > > > I'd probably agree but.... I don't see a good way how one can > > > > implement compression for specific write patterns only. > > > > We need to either ensure that these patterns are used exclusively > > > > ( append only / sequential only flags? ) or provide some means to > > > > fall back to regular mode when inappropriate write occurs. > > > > Don't think both are good and/or easy enough. > > > Well, if we simply don't implement a garbage collector, then for > > > sequential+aligned writes we don't end up with stuff that needs > > > sequential+garbage > > > collection. Even the sequential case might be doable if we make it > > > possible to fill the extent with a sequence of compressed strings > > > (as long as we haven't reached the compressed length, try to restart > > > the decompression stream). > > It's still unclear to me if such specific patterns should be > > exclusively applied to the object. E.g. by using specific object creation > mode mode. > > Or we should detect them automatically and be able to fall back to > > regular write ( i.e. disable compression ) when write doesn't conform > > to the supported pattern. > > I think initially supporting only the append workload is a simple check for > whether the offset == the object size (and maybe whether it is aligned). No > persistent flags or hints needed there. > > > And I'm not following the idea about "a sequence of compressed > > strings". Could you please elaborate? > > Let's say we have 32KB compressed_blocks, and the client is doing 1000 byte > appends. We will allocate a 32 chunk on disk, and only fill it with say ~500 > bytes of compressed data. When the next write comes around, we could > compress it too and append it to the block without decompressing the > previous string. > > By string I mean that each compression cycle looks something like > > start(...) > while (more data) > compress_some_stuff(...) > finish(...) > > i.e., there's a header and maybe a footer in the compressed string. If we are > decompressing and the decompressor says "done" but there is more data in > our compressed block, we could repeat the process until we get to the end > of the compressed data. > > But it might not matter or be worth it. If the compressed blocks are smallish > then decompressing, appending, and recompressing isn't going to be that > expensive anyway. I'm mostly worried about small appends, e.g. by rbd > mirroring (imaging 4 KB writes + some metadata) or the MDS journal. One possible policy would be "lazy compression", wherein data was stored "in the clear" initially and only gets compressed in the background. This logically equivalent to the current WAL scheme. This points out the benefits of my previous rant of separating mechanism from policy. > > sage -- To unsubscribe from this list: send the line "unsubscribe ceph-devel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html