一個協(xié)助調(diào)試的日志頭文件

在平時調(diào)試ceph代碼的時候藐翎,gdb并不是特別的好用嘀掸,尤其是在業(yè)務(wù)邏輯比較復(fù)雜的時候紫岩,這時候最好能加上日志,原生的ceph日志特別多睬塌,不方便泉蝌,這時候,一個簡單的日志頭文件就可以幫我們增加額外的我們自己感興趣的日志揩晴。

下面這個日志頭文件勋陪,只有包含這個頭文件就可以了。使用的方法如下:

LOG(INFO) << "Hello World!" << std::endl;

或者使用C語言的打印的格式

LOG_MESSAGE("Hello %s\n", name.c_str());

日志頭文件完整的源代碼如下:

#ifndef LOG_MESSAGE_H
#define LOG_MESSAGE_H

#include <stdint.h>
#include <stdio.h>
#include <time.h>
#include <sys/time.h>
#include <sys/types.h>
#include <unistd.h>
#include <pthread.h>
#include <sys/syscall.h>   /* For SYS_xxx definitions */
#include <iostream>
#include <sstream>

#define LOG_MESSAGE(format, ...)                                                                \
    do {                                                                                        \
        FILE* ffff = fopen("/tmp/debug.log", "a");                                              \
        if (ffff == NULL) {                                                                     \
            break;                                                                              \
        }                                                                                       \
        struct timeval tv = {0};                                                                \
        struct tm tm = {0};                                                                     \
        gettimeofday(&tv, NULL);                                                                \
        localtime_r(&(tv.tv_sec), &tm);                                                         \
        fprintf(ffff, "[%d-%02d-%02d %02d:%02d:%02d.%03d][%d:%d][%s:%d] " format "\n",          \
                1900 + tm.tm_year, tm.tm_mon + 1, tm.tm_mday, tm.tm_hour, tm.tm_min, tm.tm_sec, \
                static_cast<int>(tv.tv_usec / 1000),                                            \
                static_cast<int>(getpid()), static_cast<int>(syscall(SYS_gettid)),              \
                __FILE__, __LINE__,                                                             \
                ##__VA_ARGS__);                                                                 \
        fclose(ffff);                                                                           \
    } while (false)

class LogMessage {
public:
    LogMessage(const char* file, int line) {
        Init(file, line);
    }

    ~LogMessage() {
        FILE* fp = fopen("/tmp/debug.log", "a");
        if (fp == NULL) {
            return;
        }
        fprintf(fp, "%s\n", stream_.str().c_str());
        fclose(fp);
    }

    std::ostream& stream() { return stream_; }

private:
    void Init(const char* file, int line) {
        char buf[256] = {0};
        struct timeval tv = {0};
        struct tm tm = {0};
        gettimeofday(&tv, NULL);
        localtime_r(&(tv.tv_sec), &tm);
        sprintf(buf, "[%d-%02d-%02d %02d:%02d:%02d.%03d][%d:%d][%s:%d] ",
                1900 + tm.tm_year, tm.tm_mon + 1, tm.tm_mday, tm.tm_hour, tm.tm_min, tm.tm_sec,
                static_cast<int>(tv.tv_usec / 1000),
                static_cast<int>(getpid()), static_cast<int>(syscall(SYS_gettid)),
                file, line);
        stream_ << buf;
    }

    std::ostringstream stream_;
};

#define LOG(INFO) LogMessage(__FILE__, __LINE__).stream()

#endif // LOG_MESSAGE_H
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末文狱,一起剝皮案震驚了整個濱河市粥鞋,隨后出現(xiàn)的幾起案子缘挽,更是在濱河造成了極大的恐慌瞄崇,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,734評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件壕曼,死亡現(xiàn)場離奇詭異苏研,居然都是意外死亡,警方通過查閱死者的電腦和手機腮郊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評論 3 394
  • 文/潘曉璐 我一進店門摹蘑,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人轧飞,你說我怎么就攤上這事衅鹿∪鲎伲” “怎么了?”我有些...
    開封第一講書人閱讀 164,133評論 0 354
  • 文/不壞的土叔 我叫張陵大渤,是天一觀的道長制妄。 經(jīng)常有香客問我,道長泵三,這世上最難降的妖魔是什么耕捞? 我笑而不...
    開封第一講書人閱讀 58,532評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮烫幕,結(jié)果婚禮上俺抽,老公的妹妹穿的比我還像新娘。我一直安慰自己较曼,他們只是感情好磷斧,可當(dāng)我...
    茶點故事閱讀 67,585評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著诗芜,像睡著了一般瞳抓。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上伏恐,一...
    開封第一講書人閱讀 51,462評論 1 302
  • 那天孩哑,我揣著相機與錄音,去河邊找鬼翠桦。 笑死横蜒,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的销凑。 我是一名探鬼主播丛晌,決...
    沈念sama閱讀 40,262評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼斗幼!你這毒婦竟也來了澎蛛?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,153評論 0 276
  • 序言:老撾萬榮一對情侶失蹤蜕窿,失蹤者是張志新(化名)和其女友劉穎谋逻,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體桐经,經(jīng)...
    沈念sama閱讀 45,587評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡毁兆,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,792評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了阴挣。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片气堕。...
    茶點故事閱讀 39,919評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出茎芭,到底是詐尸還是另有隱情揖膜,我是刑警寧澤,帶...
    沈念sama閱讀 35,635評論 5 345
  • 正文 年R本政府宣布梅桩,位于F島的核電站次氨,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏摘投。R本人自食惡果不足惜煮寡,卻給世界環(huán)境...
    茶點故事閱讀 41,237評論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望犀呼。 院中可真熱鬧幸撕,春花似錦、人聲如沸外臂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,855評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽宋光。三九已至貌矿,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間罪佳,已是汗流浹背逛漫。 一陣腳步聲響...
    開封第一講書人閱讀 32,983評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留赘艳,地道東北人酌毡。 一個月前我還...
    沈念sama閱讀 48,048評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像蕾管,于是被迫代替她去往敵國和親枷踏。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,864評論 2 354

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,117評論 25 707
  • ceph簡介 Ceph是一個分布式存儲系統(tǒng)掰曾,誕生于2004年旭蠕,是最早致力于開發(fā)下一代高性能分布式文件系統(tǒng)的項目。隨...
    愛吃土豆的程序猿閱讀 6,023評論 0 21
  • 道是花前月下旷坦,怎奈孤芳自賞掏熬。 不堪秋風(fēng)冷月,冷落多少鮮花塞蹭。
    北塔雪松閱讀 516評論 5 22
  • 衰老是過程孽江,死亡是結(jié)局讶坯。
    桐花爛漫閱讀 86評論 0 0
  • 我不憚以最大的惡意來揣度任何人番电。 然而并沒有多大意義,別人不會因為你的揣度而改變什么,也不會因為你的揣度而受到...
    簡o淺閱讀 612評論 0 0