《Ceph源码分析》——第2章,第6节SafeTimer

简介: 本节书摘来自华章出版社《Ceph源码分析》一书中的第2章,第2.6节SafeTimer,作者常涛,更多章节内容可以访问云栖社区“华章计算机”公众号查看 2.6 SafeTimer 类SafeTimer实现了定时器的功能,代码如下: class SafeTimer { CephConte

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

2.6 SafeTimer
类SafeTimer实现了定时器的功能,代码如下:

class SafeTimer
{
  CephContext *cct;
  Mutex& lock;
  Cond cond;
  bool safe_callbacks;      //是否是safe_callbacks

  SafeTimerThread *thread;  //定时器执行线程

  std::multimap<utime_t, Context*> schedule;
                            //目标时间和定时任务执行函数Context
  std::map<Context*, std::multimap<utime_t, Context*>::iterator> events;
                            //定时任务<-->定时任务在shedule中的位置映射
  bool stopping;            //是否停止
}

添加定时任务的命令如下:
void SafeTimer::add_event_at(utime_t when, Context *callback)
取消定时任务的命令如下:
bool cancel_event(Context *callback);
定时任务的执行如下:
void SafeTimer::timer_thread()
本函数一次检查scheduler中的任务是否到期,其循环检查任务是否到期执行。任务在schedule中是按照时间升序排列的。首先检查,如果第一任务没有到时间,后面的任务就不用检查了,直接终止循环。如果第一任务到了定时时间,就调用callback函数执行,如果是safe_callbacks,就必须在获取lock的情况下执行Callback任务。

相关文章
|
11月前
|
存储 固态存储 数据管理
Ceph 简介
Ceph 简介
300 0
|
存储 监控 算法
《Ceph源码分析》——导读
本节书摘来自华章出版社《Ceph源码分析》一书中的导读,作者常涛,更多章节内容可以访问云栖社区“华章计算机”公众号查看 目  录序言第1章 Ceph整体架构 **1.1 Ceph的发展历程1.2 Ceph的设计目标1.
6583 1
|
存储 算法 关系型数据库
|
网络协议
Etcd源码分析: 启动篇
启动 启动从源码 /etcdmain/main.go 中的main函数开始 func Main() { checkSupportArch() // 检查系统是否支持 if len(os.
7187 0
|
存储 算法 对象存储
《Ceph源码分析》——第2章,第4节Finisher
本节书摘来自华章出版社《Ceph源码分析》一书中的第2章,第2.4节Finisher,作者常涛,更多章节内容可以访问云栖社区“华章计算机”公众号查看 2.4 Finisher 类Finisher用来完成回调函数Context的执行,其内部有一个FinisherThread线程来用于执行Conte
1438 0