- 需求介绍
- 原理说明
- 模块添加
需求介绍
我先讲一下我的需求,估计我讲完了,大家也就明白为什么要有这么一个模块了,然后后面我再介绍如何给自己的模块中添加它。
我们要在客户端监控一条日志信息,但是由于客户端节点非常多,所以不好实现。有人可能已经想到了,在每个节点写个脚本去监控该日志,如果出现了就把该日志插入到头节点的某个文件里面,然后你再监控这个文件且把这个文件的信息传送给存储节点不就可以了么。但是这样做有一下缺点:
1.客户的计算节点部署额外的监控服务,增加了部署的复杂度,且有的客户不太乐意给他们机器装东西。
2.多个节点往一个节点的某个文件里面放日志,那我们就要考虑多个客户端操作一个文件时的数据完整性,和时间序列是不是和我们需要的一样,考虑的方面比较多。
原理说明
综上所述LogClient就派上用场了,我们发现在/var/log/ceph/下面有一个以集群名称命名的一个日志文件,利用它可以监控集群的健康状态,pgmap状态,甚至可以看到哪些操作slow之类的。这里面的日志是monitor经过paxos协议商量后发给了各个存储节点上面的。大致流程如下图所示:
我们利用它就可以完美解决我们所需要的功能,只需要在客户端的代码中添加这个模块即可。它主要在下面两个文件里面实现
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 模块添加的为例
- Client.h
a.添加头文件 #include "common/LogClient.h”
b.添加类成员变量:LogClient log_client; LogChannelRef clog;
- Client.cc
a.在Client的构造函数里面初始化上面的两个成员变量
b.创建通道
c.在Client::init里面设置monclient的log_clientclog = log_client.create_channel(); clog->set_log_to_monitors(true);
- 执行完上面两步就可以使用了,例如:
stringstream ss; ss << "ivan test ......" ; clog->warn() << ss.str();
欢迎大家提出宝贵意见!