《Ceph源码分析》——第2章,第5节Throttle

简介:

本节书摘来自华章出版社《Ceph源码分析》一书中的第2章,第2.5节Throttle,作者常涛,更多章节内容可以访问云栖社区“华章计算机”公众号查看

2.5 Throttle
类Throttle用来限制消费的资源数量(也常称为槽位“slot”),当请求的slot数量达到max值时,请求就会被阻塞,直到有新的槽位释放出来,代码如下:
`class Throttle {
CephContext *cct;
const std::string name;
PerfCounters *logger;
ceph::atomic_t count, max;
// count:当前占用的slot的数量
// max:sloct数量的最大值
Mutex lock; //等待的锁
list cond; //等待的条件变量
……
}`
函数get用于获取数量为c个slot,参数c默认为1,参数m默认为0,如果m不为默认的0值,就用m值重新设置slot的max值。如果成功获取数量为c个slot,就返回true,否则就阻塞等待。例如:
bool Throttle::get(int64_t c, int64_t m)
函数get_or_fail当获取不到数量为c个slot时,就直接返回false,不阻塞等待:
bool Throttle::get_or_fail(int64_t c)
函数put用于释放数量为c个slot资源:
int64_t Throttle::put(int64_t c)

相关文章
|
12月前
|
监控 前端开发 JavaScript
shin-monitor源码分析
shin-monitor源码分析
|
存储 监控 算法
《Ceph源码分析》——导读
本节书摘来自华章出版社《Ceph源码分析》一书中的导读,作者常涛,更多章节内容可以访问云栖社区“华章计算机”公众号查看 目  录序言第1章 Ceph整体架构 **1.1 Ceph的发展历程1.2 Ceph的设计目标1.
6635 1
|
负载均衡 算法 API
Envoy源码分析之Load balancing Priority
# Priority Level 在上一篇文章中我提到`Priority`,一个集群可以包含多个`Priority`,每一个`Priority`下可以有很多主机,默认的`Priority`是0,也是最高的优先级,如果一个集群同时存在多个`Priority`,Envoy是如何来进行处理呢? Envoy默认只从`Priority`为0的的主机中进行负载均衡,直到`Priority`为0的主机其健
1344 0
|
JavaScript 前端开发 C++
《Ceph源码分析》——第2章,第6节SafeTimer
本节书摘来自华章出版社《Ceph源码分析》一书中的第2章,第2.6节SafeTimer,作者常涛,更多章节内容可以访问云栖社区“华章计算机”公众号查看 2.6 SafeTimer 类SafeTimer实现了定时器的功能,代码如下: class SafeTimer { CephConte
1610 0
《Ceph源码分析》——第2章,第4节Finisher
本节书摘来自华章出版社《Ceph源码分析》一书中的第2章,第2.4节Finisher,作者常涛,更多章节内容可以访问云栖社区“华章计算机”公众号查看 2.4 Finisher 类Finisher用来完成回调函数Context的执行,其内部有一个FinisherThread线程来用于执行Conte
1438 0
《Ceph源码分析》——第3章,第2节Simple实现
本节书摘来自华章出版社《Ceph源码分析》一书中的第3章,第3.2节Simple实现,作者常涛,更多章节内容可以访问云栖社区“华章计算机”公众号查看 3.2 Simple实现 Simple在Ceph里实现比较早,目前也比较稳定,是在生产环境中使用的网络通信模块。
2013 0

热门文章

最新文章