OpenStack_Swift源代码分析——Object-auditor源代码分析(1)
1 Object-auditor 的启动
Object-auditor的启动和object-replicator的启动过程是一样的,首先是运行启动脚本
- swift-init object-auditor start
启动脚本会执行swift源代码bin文件夹下的swift-ojbect-auditor
- if __name__ == '__main__':
- parser = OptionParser("%prog CONFIG [options]")
- parser.add_option('-z', '--zero_byte_fps',
- help='Audit only zero byte files at specified files/sec')
- parser.add_option('-d', '--devices',
- help='Audit only given devices. Comma-separated list')
- conf_file, options = parse_options(parser=parser, once=True)
- run_daemon(ObjectAuditor, conf_file, **options)
这里是传入的ObjectAuditor类。并且ObjectorAuditor相同继承Daemon类,其的过程和 Replicator类似,以下看Auditor类中runforever方法。其代码为:
- def run_forever(self, *args, **kwargs):
- """Run the object audit until stopped."""
- # zero byte only command line option
- zbo_fps = kwargs.get('zero_byte_fps', 0)
- parent = False
- if zbo_fps:
- # only start parent
- parent = True
- kwargs = {'mode': 'forever'}
- while True:
- try:
- #循环审计
- self.audit_loop(parent, zbo_fps, **kwargs)
- except (Exception, Timeout) as err:
- self.logger.exception(_('ERROR auditing: %s' % err))
- #每隔30秒运行一次
- self._sleep()
while循环在运行完audit_loop方法后会睡眠30秒,让后继续运行。
重点看循环审计方法aduit_loop方法
- def audit_loop(self, parent, zbo_fps, override_devices=None, **kwargs):
- """Audit loop"""
- self.clear_recon_cache('ALL')
- self.clear_recon_cache('ZBF')
- kwargs['device_dirs'] = override_devices #获得须要重写的设备
- #第一次启动 parent 为false
- if parent:
- kwargs['zero_byte_fps'] = zbo_fps
- #执行 run_audit方法
- self.run_audit(**kwargs)
- else:
- pids = []
- # self.conf_zero_byte_fps = int(conf.get('zero_byte_files_per_second', 50))
- if self.conf_zero_byte_fps:
- zbf_pid = self.fork_child(zero_byte_fps=True, **kwargs)
- #将子进程增加到pids中
- pids.append(zbf_pid)
- pids.append(self.fork_child(**kwargs))
- #
- while pids:
- pid = os.wait()[0]
- # ZBF scanner must be restarted as soon as it finishes
- if self.conf_zero_byte_fps and pid == zbf_pid and \
- len(pids) > 1:
- kwargs['device_dirs'] = override_devices
- zbf_pid = self.fork_child(zero_byte_fps=True, **kwargs)
- pids.append(zbf_pid)
- pids.remove(pid)
在audit_loop中主要是执行fork_child方法。其返还子进程的pid。以下为fork_child的详细实现
- def fork_child(self, zero_byte_fps=False, **kwargs):
- """Child execution"""
- #返回子进程的进程号
- pid = os.fork()
- if pid:
- return pid
- else:
- signal.signal(signal.SIGTERM, signal.SIG_DFL)
- if zero_byte_fps:
- kwargs['zero_byte_fps'] = self.conf_zero_byte_fps
- #执行审计
- self.run_audit(**kwargs)
- sys.exit()
首先是获得子进程的pid,并返回,若果没有此进程pid这须要创建子进程。子进程的创建是是执行run_audit方法。当中run_audit方法的实现代码例如以下:
- def run_audit(self, **kwargs):
- """Run the object audit"""
- mode = kwargs.get('mode')
- zero_byte_only_at_fps = kwargs.get('zero_byte_fps', 0)
- device_dirs = kwargs.get('device_dirs')
- worker = AuditorWorker(self.conf, self.logger, self.rcache,
- self.devices,
- zero_byte_only_at_fps=zero_byte_only_at_fps)
- #审计全部的对象
- worker.audit_all_objects(mode=mode, device_dirs=device_dirs)
首先是获得mode。此时的mode为 forever然后是获得设备中之前挂载的存储文件的设备。创建AuditorWorker类的实例,并运行audit_all_objects。审计器是不停的扫描当前server存储设备下的全部对象,并将损坏的文件放入隔离区,等待replicate用完善的来替代。
下一篇博客中重点介绍详细运行审计的AuditorWorker类的实现以及对于损坏的文件是怎样创建隔离区的。
因为本人水平有限。文中难免出现理解错误,敬请指正、交流,谢谢!
OpenStack_Swift源代码分析——Object-auditor源代码分析(1)的更多相关文章
- 分析 JUnit 框架源代码
本文转载至http://www.ibm.com/developerworks/cn/java/j-lo-junit-src/ 分析 JUnit 框架源代码 理解 JUnit 测试框架实现原理和设计模式 ...
- 【Java收集的源代码分析】Hashtable源代码分析
Hashtable简单介绍 Hashtable相同是基于哈希表实现的,相同每一个元素是一个key-value对,其内部也是通过单链表解决冲突问题,容量不足(超过了阀值)时.相同会自己主动增长. Has ...
- 【Java集合源代码剖析】HashMap源代码剖析
转载请注明出处:http://blog.csdn.net/ns_code/article/details/36034955 您好,我正在參加CSDN博文大赛,假设您喜欢我的文章.希望您能帮我投一票.谢 ...
- nodejs的Express框架源码分析、工作流程分析
nodejs的Express框架源码分析.工作流程分析 1.Express的编写流程 2.Express关键api的使用及其作用分析 app.use(middleware); connect pack ...
- 一、SDWebImage分析--库处理流程分析
二.SDWebImage分析--源码具体分析 这阵子看了SDWebImage的实现跟源代码.也看了下网上的一些总结. 这里我自己画了个流程图来辅助理解下SDWebImage这个库的实现流程.相信也是有 ...
- SVN-项目 XXX 受源代码管理。向源代码管理注册此项目时出错。建议不要对此项目进行任何修改
错误描述: 项目 XXX 受源代码管理.向源代码管理注册此项目时出错.建议不要对此项目进行任何修改 解决办法: 使用记事本打开,项目csproj文件删除图中几行,重新打开解决方案就可以了 原因分析: ...
- 手机自动化测试:Appium源码分析之跟踪代码分析六
手机自动化测试:Appium源码分析之跟踪代码分析六 poptest是国内唯一一家培养测试开发工程师的培训机构,以学员能胜任自动化测试,性能测试,测试工具开发等工作为目标.poptest推出手机自 ...
- 【Java集合源代码剖析】ArrayList源代码剖析
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/mmc_maodun/article/details/35568011 转载请注明出处:http:// ...
- 【Java集合源代码剖析】Hashtable源代码剖析
转载请注明出处:http://blog.csdn.net/ns_code/article/details/36191279 Hashtable简单介绍 Hashtable相同是基于哈希表实现的,相同每 ...
- 【Java集合源代码剖析】LinkedList源代码剖析
转载请注明出处:http://blog.csdn.net/ns_code/article/details/35787253 您好.我正在參加CSDN博文大赛.假设您喜欢我的文章,希望您能帮我投一票,谢 ...
随机推荐
- Servlet基础知识(四)——Servlet过滤器Filter
一.什么是过滤器: 政府大楼的安检保安,它既能对进入政府大楼的人员进行检查,只允许检查符合要求的进入:同时他也负责对出大楼的人进行检查,看他带出的东西是否符合要求. 同样的,Servlet中的过滤器既 ...
- 保存属性至xml并读取
import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import ja ...
- ZOJ 3209 Treasure Map 精确覆盖
题目链接 精确覆盖的模板题, 把每一个格子当成一列就可以. S忘记初始化TLE N次, 哭晕在厕所...... #include<bits/stdc++.h> using namespac ...
- iOS开发的准备
一.程序设计语言 上一讲已经说到:要想开发一款软件,首先得学习一些相应的程序设计语言.至于iOS开发,需要学习的语言主要有:C.C++.Objective-C. 二.是否需要计算机专业知识 可能很多人 ...
- 《转》使用JAVA如何对图片进行格式检查以及安全检查处理
本文出自冯立彬的博客,原地址:http://www.fenglibin.com/use_java_to_check_images_type_and_security.html 一.通常情况下,验证一个 ...
- mysql null值问题
mysql> create table test( sn int, -> `createdTime` datetime NOT NULL COMMENT '创建时间', -> `up ...
- [PHP] PHP初学者想了解"伪静态",必须看这个贴 [复制链接] [推荐]
一.何为“伪静态”? 以传智播客bbs论坛为例,这篇帖子的链接地址原本应该是“http://bbs.itcast.cn/forum.php?mod=post&action=newthread& ...
- HDU 4464 Browsing History(最大ASCII的和)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4464 Problem Description One day when you are going t ...
- CD key 生成
题目描述如下: 某欧软件需要实现简易的CD-KEY算法,输入3个正整数,以空格隔开,根据者3个正整数生成的cd-key字符串.输出格式:xxxx-xxxx-xxxx-xxyy. 包含16个字符,以短划 ...
- 使用PHP实现用户登录和注册的功能
登陆界面 login.php <form action="logincheck.php" method="post"> 用户名:<input ...