Hi Sage, You are correct. I was trying to find certain IO plugin architecture so that I get a chance to insert my code/module to change read/write operations' behavior. I'd suggest such kind of plugin architecture to ceph. It will make it easy to add new function to ceph. A good example is MS Windows IO Manager, it's designed to give user chance to insert code/modules at every layers of IO path. It's helpful for enlarging its ecosystem. Of course, it's much complicated for a distributed storage system. Thanks Zhiye -----Original Message----- From: Sage Weil [mailto:sage@xxxxxxxxxxxx] Sent: Friday, March 3, 2017 10:51 PM To: Wang, Zhiye <Zhiye.Wang@xxxxxxxxxxxx> Cc: ceph-devel@xxxxxxxxxxxxxxx Subject: RE: Document about ceph object class APIs On Fri, 3 Mar 2017, Wang, Zhiye wrote: > Thank you Sage. > > Yes, I am looking at the example code. " cls_register_cxx_method" > seems pretty clear. Especially, there is a good blog > (http://ceph.com/rados/dynamic-object-interfaces-with-lua/) which > explains it well. > > I am interested in function "cls_register_cxx_filter". What is exactly > the function, and what is a PGLS filter? I will look into more code, > but I will appreciate if you can give it an introduction. The filter is for PGLS, which lists objects. It lets you define a selection function so that onyl certain objects are included in the result. It's used for cephfs repair when it is searching for unlinked objects/files (roughly speaking). > Actually, I am looking for something like this: (data comes from > CephFS), before OSD writes file data to underlying storage, my filter > code get a chance to modify the data content, and then write to the > current object in current pool, or write to another object in another > pool. I guess this somehow can be achieved using > "cls_register_cxx_method" related methods, but I don't want to change > anything on client side (because it's difficult to > modify/incorporate/distribute modify code to all clients). Ah, this unfortunatey isn't possible with the cls mechanism. The class methods are intended to work like methods on objects (in teh OOP sense) in that they only operate on a single object and must operate in isolation without blocking. (This lets us bury it into a complex request processing and replication pipeline with transactional semantics.) Also, since CephFS is issuing the requests, you'd have to change the client to issue a different type of op if you wanted to do something other than write. I'm guessing you're trying to do some sort of tiering or dedup here? That won't be something that cls ops can do... it needs to be built into RADOS. HTH! sage > Is "cls_register_cxx_filter" what I am looking for? > > > Thanks > Mike > > > -----Original Message----- > From: Sage Weil [mailto:sage@xxxxxxxxxxxx] > Sent: Thursday, March 2, 2017 11:28 PM > To: Wang, Zhiye <Zhiye.Wang@xxxxxxxxxxxx> > Cc: ceph-devel@xxxxxxxxxxxxxxx > Subject: Re: Document about ceph object class APIs > > On Thu, 2 Mar 2017, Wang, Zhiye wrote: > > Dear all, > > > > Where can I find document about how to extend ceph? > > > > The only doc I can see is here: > > http://docs.ceph.com/docs/master/architecture/#extending-ceph > > > > And some examples in > > https://github.com/ceph/ceph/tree/master/src/cls > > > > Where can I get document for those APIs? And are those APIs kept > > stable from release to release? > > The example classes are the best documentation currently. The APIs > are quite stable, although in principle they could change. The class > plugins need to be compiled against a specific build of ceph anyway, > so you would discover any future change at build time. The storage > calls (reads and > writes) roughly correspond to the RADOS operations defined in include/rados.h (they map to the operations interpreted by do_osd_ops() in PrimaryLogPG.cc), and those rados operations maintain compatibility across many Ceph releases as they are normally originating from clients connecting to the system that could be running other versions. > > Hope that helps! > 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 > > -- 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