ceph学习(一)——数据结构

本文主要探讨了Ceph MDS(Metadata Server)的数据结构,包括MDS类、Messenger类、MonClient类及其相关组件如MonMap、Finisher、CephContext等。还涉及到了关键的数据结构如MDSMap和OSDMap,以及LogClient、Server、MDCache等对象,这些构成了Ceph存储系统的基石,负责元数据管理和集群通信。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ceph mds端的代码使用C++编写,mds端的重要数据结构:

class MDS : public Dispatcher(<mds.h>)

  包括一个锁,一个定时器,一个消息句柄,客户端的连接,mds map和osd map,server对象,MDS的缓存对象,log对象,负载均衡处理对象等

class Messenger (<messager.h>)

消息处理对象,用于mds和其他节点的通讯

class MonClient : public Dispatcher (<monclient.h>)

包括一个MonMap,消息句柄,一个连接,锁,定时器,Finisher对象,LogClient,是mds与client交互的处理对象

class MonMap (<monmap.h>)

包括一个地址信息map,最后修改时间,创建时间,能够随机选择一个mon,获取时间点,设置时间点,获取mon的地址,通过mon的地址获取它的名字等方法;

class Finisher(<finisher.h>)

包括CephContext句柄,一个互斥锁,条件锁,一个stop和running的标识,一个finisher 的队列;

class CephContext(<ceph_context.h>)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值