ceph LogClient 模块介绍

  • 需求介绍
  • 原理说明
  • 模块添加

需求介绍

我先讲一下我的需求,估计我讲完了,大家也就明白为什么要有这么一个模块了,然后后面我再介绍如何给自己的模块中添加它。
我们要在客户端监控一条日志信息,但是由于客户端节点非常多,所以不好实现。有人可能已经想到了,在每个节点写个脚本去监控该日志,如果出现了就把该日志插入到头节点的某个文件里面,然后你再监控这个文件且把这个文件的信息传送给存储节点不就可以了么。但是这样做有一下缺点:
1.客户的计算节点部署额外的监控服务,增加了部署的复杂度,且有的客户不太乐意给他们机器装东西。
2.多个节点往一个节点的某个文件里面放日志,那我们就要考虑多个客户端操作一个文件时的数据完整性,和时间序列是不是和我们需要的一样,考虑的方面比较多。

原理说明

综上所述LogClient就派上用场了,我们发现在/var/log/ceph/下面有一个以集群名称命名的一个日志文件,利用它可以监控集群的健康状态,pgmap状态,甚至可以看到哪些操作slow之类的。这里面的日志是monitor经过paxos协议商量后发给了各个存储节点上面的。大致流程如下图所示:


LogClient

我们利用它就可以完美解决我们所需要的功能,只需要在客户端的代码中添加这个模块即可。它主要在下面两个文件里面实现

src/common/LogClient.cc
src/common/LogClient.h

主要原理就是用LogClient先创建一个通往monitor的channel。假如我们的channel是clog,当你调用clog->warn这个函数的时候把你想要打印的日志暂时放到log_queue里面,它随后会被MonClient的tick线程读出来,并且发送到monitor端,monitor收到之后和其他monitor商量完毕之后就会把该日志分发给所有的存储节点。当然LogChannel对外的接口有

 void debug(std::stringstream &s) {
    do_log(CLOG_DEBUG, s);
  }
  void info(std::stringstream &s) {
    do_log(CLOG_INFO, s);
  }
  void warn(std::stringstream &s) {
    do_log(CLOG_WARN, s);
  }
  void error(std::stringstream &s) {
    do_log(CLOG_ERROR, s);
  }
  void sec(std::stringstream &s) {
    do_log(CLOG_SEC, s);
  }

模块添加

我以我在ceph client 模块添加的为例

  1. Client.h
    a.添加头文件 #include "common/LogClient.h”
    b.添加类成员变量:
     LogClient    log_client;
     LogChannelRef clog;
    
  2. Client.cc
    a.在Client的构造函数里面初始化上面的两个成员变量
    b.创建通道
    clog = log_client.create_channel();
    clog->set_log_to_monitors(true);
    
    c.在Client::init里面设置monclient的log_client
  3. 执行完上面两步就可以使用了,例如:
     stringstream ss;
     ss << "ivan test  ......" ;
     clog->warn() << ss.str();
    

欢迎大家提出宝贵意见!

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,963评论 19 139
  • feisky云计算、虚拟化与Linux技术笔记posts - 1014, comments - 298, trac...
    不排版阅读 3,922评论 0 5
  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 32,036评论 2 89
  • 背景: 阅读新闻 12C CDB模式下RMAN备份与恢复 [日期:2016-11-29] 来源:Linux社区 作...
    阳屯okyepd阅读 3,610评论 0 7
  • 第一章 李木子(一) “用45°抬头的方式看天空,就可以和太阳来个聚焦,眼泪就不会掉下来”一个长发披肩的女孩站在斑...
    云朵默阅读 306评论 0 0