Re: [Gluster-users] User-serviceable snapshots design

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

 



Answers inline.


On 05/07/2014 10:52 PM, Jeff Darcy wrote:
Attached is a basic write-up of the user-serviceable snapshot feature
design (Avati's). Please take a look and let us know if you have
questions of any sort...
A few.

The design creates a new type of daemon: snapview-server.

* Where is it started?  One server (selected how) or all?
snapview-server is the same of the server side xlator. snapd is the (glusterfsd) daemon that when started and is running, looks like this: /usr/local/sbin/glusterfsd -s localhost --volfile-id snapd/vol2 -p /var/lib/glusterd/vols/vol2/run/snapd.pid -l /usr/local/var/log/glusterfs/snapd.log --xlator-option *-posix.glusterd-uuid=bd3b0111-33db-499c-8497-f455db729394 --brick-name vol2-server -S /var/run/2301b86236cdb9bd09c7f3988ac5c29f.socket --brick-port 49164 --xlator-option vol2-server.listen-port=49164

where vol2 is the name of the glusterfs vol in question.

The snapd is started by nodesvc start (as of today) and is started when the vol is started. It includes the protocol-server, io-threads and the snapview-server xlators.


* How do clients find it?  Are we dynamically changing the client
   side graph to add new protocol/client instances pointing to new
   snapview-servers, or is snapview-client using RPC directly?  Are
   the snapview-server ports managed through the glusterd portmapper
   interface, or patched in some other way?

As Varun mentioned in his response, snapd gets a port through the glusterd pmap_registry calls. Client side xlator as usual does the pmap client query to find out the port it needs to connect to. Nothing different from the norm here.


* Since a snap volume will refer to multiple bricks, we'll need
   more brick daemons as well.  How are *those* managed?

This is infra handled by the "core" snapshot functionality/feature. When a snap is created, it is treated not only as a lvm2 thin-lv but as a glusterfs volume as well. The snap volume is activated and mounted and made available for regular use through the native fuse-protocol client. Management of these is not part of the USS feature. But handled as part of the core snapshot implementation. USS (mainly snapview-server xlator) talks to the snapshot volumes (and hence the bricks) through the glfs_t *, and passing a glfs_object pointer. Each of these glfs instances represents the gfapi world for an individual snapshotted volume - accessing any of the snap vol bricks etc. is handled within the gfapi world. So to that extent, snapview-server xlator is yet another consumer of the handle-based gfapi calls like nfs-ganesha.

* How does snapview-server manage user credentials for connecting
   to snap bricks?  What if multiple users try to use the same
   snapshot at the same time?  How does any of this interact with
   on-wire or on-disk encryption?

No interaction with on-disk or on-wire encryption. Multiple users can always access the same snapshot (volume) at the same time. Why do you see any restrictions there? Maybe you want to know if userA can access the .snaps directory of another user userB? Today the credentials are passed as is ie. snapview-server does not play around with user-creds. If the snapshot volume access allows it, it goes through. Let me get back with more details on this one and thanks for bringing it up.

Remember that the snapshot vol is read-only. And snapview-server has many glfs_t * pointers, each one pointing to each of the snapshot volumes (through the gfapi world).


I'm sure I'll come up with more later.  Also, next time it might
be nice to use the upstream feature proposal template *as it was
designed* to make sure that questions like these get addressed
where the whole community can participate in a timely fashion.
Umm...this wasn't exactly a feature "proposal" was it ;-) ? But that said, point taken. Will do that. Next time.

Please do send all questions you come up with and thanks for these. Certainly helped clarify several imp points here.


Anand

_______________________________________________
Gluster-devel mailing list
Gluster-devel@xxxxxxxxxxx
http://supercolony.gluster.org/mailman/listinfo/gluster-devel




[Index of Archives]     [Gluster Users]     [Ceph Users]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Security]     [Bugtraq]     [Linux]     [Linux OMAP]     [Linux MIPS]     [eCos]     [Asterisk Internet PBX]     [Linux API]

  Powered by Linux