如何通过python获取ceph的磁盘使用情况

时间:2019-09-14 08:46:12

标签: python ceph

我想获取ceph上的卷的磁盘使用情况。

rbd -p volumes list
volume-3968ca3d-d55f-47ac-9174-ff2614b0bde1
volume-493eee5c-3cdb-4c1c-b8d0-a24efba0c884

现在我可以通过其ID获取使用情况

rbd disk-usage volumes/volume-3968ca3d-d55f-47ac-9174-ff2614b0bde1
NAME                                               PROVISIONED USED
volume-3968ca3d-d55f-47ac-9174-ff2614b0bde1@yasin1       1024M 532M

一切正常。 我想通过API执行此命令。我读了https://docs.ceph.com/docs/mimic/rados/api/python/ 数百次,找不到任何解决方案来通过python获取用法。

我该怎么做才能通过pyhton使用?

1 个答案:

答案 0 :(得分:1)

一切都在RadosRBD文档中。

您的代码将类似于以下代码片段。它将连接到群集。它将获得其IO上下文,创建一个RBD实例,该实例又可以检索image_names,并且image_name用于访问最终具有size()方法的图像实例。这将为我们提供图像的最大尺寸。要计算磁盘使用情况,可以使用diff_iterate方法来扫描整个映像,以查找映像的现有/不存在的对象。对于每个对象,都会调用计数器实例的cb_offset方法。如果对象存在,则计数增加对象的长度。对于没有快速差异贴图的图像,这需要一段时间。使用相同的技术来比较快照。在这种情况下,diff_iterate的第三个参数指向快照。在我们的例子中,我们希望与时间的开始(空白图像)进行比较,因此它为None。

import rados
import rbd

class DiffCounter:
    def __init__(self):
        self.count = 0
    def cb_offset(self, offset, length, exists):
        if exists:
            self.count+=length

def disk_usage():
    cluster = rados.Rados(conffile='/etc/ceph/ceph.conf')
    cluster.connect()
    try:
        ioctx = cluster.open_ioctx('rbd')
        try:
            rbd_inst = rbd.RBD()
            try:
                for image_name in rbd_inst.list(ioctx):
                    image = rbd.Image(ioctx, image_name)
                    max_size = image.size()
                    counter = DiffCounter()
                    image.diff_iterate(0,max_size,None,counter.cb_offset)
                    current_size = counter.count
                    print(image_name,max_size,current_size)
            finally:
                image.close()
        finally:
            ioctx.close()
    finally:
        cluster.shutdown()

if __name__ == '__main__':
    disk_usage()