RE: libcrush.so

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

 



On Sat, 9 May 2015, Zhou, Yuan wrote:
> Hi James,
> 
> This happens usually when the storage platform and applications are in segmented networks. For example, in a cluster with multiple RGW instances, if we could know the which RGW instance is the closest to primary copy, then we can do more efficient local read/write through some particular deployment. 
> There's one feature in Openstack Swift [1] which is able to provide the location of objects inside a cluster.

I think the place for this is librados--and I believe there is already a 
method to do this (I think... I know there is in libcephfs as the hadoop 
bindings use it).  That way you don't have to deal with the annoying 
details of getting an up to date map and so on.

sage


> 
> Thanks, -yuan
> 
> [1] https://github.com/openstack/swift/blob/master/swift/common/middleware/list_endpoints.py
> 
> -----Original Message-----
> From: James (Fei) Liu-SSI [mailto:james.liu@xxxxxxxxxxxxxxx] 
> Sent: Saturday, May 9, 2015 1:40 AM
> To: Zhou, Yuan; Ceph Development
> Cc: Cohen, David E; Yu, Zhidong
> Subject: RE: libcrush.so
> 
> Hi Yuan,
>    Very interesting. Would be possible to know why application needs to access the cursh map directly instead of accessing through ceph tool?
> 
>   Regards,
>   James
> 
> -----Original Message-----
> From: ceph-devel-owner@xxxxxxxxxxxxxxx [mailto:ceph-devel-owner@xxxxxxxxxxxxxxx] On Behalf Of Zhou, Yuan
> Sent: Thursday, May 07, 2015 6:29 PM
> To: Ceph Development
> Cc: Cohen, David E; Yu, Zhidong
> Subject: libcrush.so
> 
> Ceph use crush algorithm to provide the mapping of objects to OSD servers. This is great for clients so they could talk to with these OSDs directly. However there are some scenarios where the application needs to access the crush map, for load-balancing as an example. 
> 
> Currently Ceph doesn't provides any API to render the layout. If your application needs to access the crush map you'll going to rely on the command 'ceph osd map pool_name obj_name'. With this libcrush.so we could let the application to choose which nodes to access. The other advantage is we could provide some other bindings(python, go) based on this also.
> 
> >From the git log we find libcrush was there before but removed out since Argonaut. Can anyone kindly share us the background of this change?
> 
> 
> Thanks, -yuan
> 
> --
> 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
> 
> 
--
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




[Index of Archives]     [CEPH Users]     [Ceph Large]     [Information on CEPH]     [Linux BTRFS]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]
  Powered by Linux