《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)

相关文章
Ansible-playbook 并发运行async、poll(学习笔记二十二)
ansible默认只会创建5个进程,所以一次任务只能同时控制5台机器执行.那如果你有大量的机器需要控制,或者你希望减少进程数,那你可以采取异步执行.ansible的模块可以把task放进后台,然后轮询它.
4522 0
|
8月前
|
前端开发 JavaScript
Node——fs模块、异步
Node——fs模块、异步
Node——fs模块、异步
|
12月前
|
监控 前端开发 JavaScript
shin-monitor源码分析
shin-monitor源码分析
|
存储 监控 算法
《Ceph源码分析》——导读
本节书摘来自华章出版社《Ceph源码分析》一书中的导读,作者常涛,更多章节内容可以访问云栖社区“华章计算机”公众号查看 目  录序言第1章 Ceph整体架构 **1.1 Ceph的发展历程1.2 Ceph的设计目标1.
6644 1
|
存储 算法 关系型数据库
《Ceph源码分析》——第3章,第2节Simple实现
本节书摘来自华章出版社《Ceph源码分析》一书中的第3章,第3.2节Simple实现,作者常涛,更多章节内容可以访问云栖社区“华章计算机”公众号查看 3.2 Simple实现 Simple在Ceph里实现比较早,目前也比较稳定,是在生产环境中使用的网络通信模块。
2013 0
《Ceph源码分析》——第2章,第6节SafeTimer
本节书摘来自华章出版社《Ceph源码分析》一书中的第2章,第2.6节SafeTimer,作者常涛,更多章节内容可以访问云栖社区“华章计算机”公众号查看 2.6 SafeTimer 类SafeTimer实现了定时器的功能,代码如下: class SafeTimer { CephConte
1610 0