libevent::日志

 

LibEvent 能记录内部的错误和警告日志,如果编译进日志支持功能,也会记录调试信息.默认情况下这些消息都是输出 到 stderr,
你也可以通过提供自己的日志函数的方法来覆盖这种行为.

 

为了覆盖 LibEvent 的日志行为,你需要自己编写满足 event_log_cb 格式的函数,然后将函数作为参数传入 event_set_log_callback().

无论什么时候只要 LibEvent 需要写一个日志,都会进入到你提供的日志函数.

你需要让 LibEvent 日志回到默认功能的时候, 只需要再次调用 event_set_log_callback()并且传一个 NULL 即可.

 

通常调试日志都是禁用的,也都不会发送给日志回调函数,
但是如果 libEvent 是编译成支持打开调试日志,你就可以手 动打开调试日志.

#define EVENT_DBG_NONE 0 
#define EVENT_DBG_ALL 0xffffffffu 
void event_enable_debug_logging(ev_uint32_t which);

调用 event_enable_debug_logging() 使用 EVENT_DBG_NONE 得到默认行为,
使用 EVENT_DBG_ALL 开启所有可支持的调试日志

 

处理致命错误 
当 LibEvent 检测到一个不可恢复的致命错误(比如数据结构损坏),它的默认行为是调用 exit()或 abort()来退出
这意味着有一个错误,要么在你的代码中,要么在 LibEvent 中.
可以为 LibEvent 提供退出时候应该调用的函数,覆盖默认行为.
接口 typedef void ( * event_fatal_cb)(int err); 
void event_set_fatal_callback(event_fatal_cb cb);
之后如果 LibEvent 遇到致命错误,它就会调用你提供的函数。

 

 

void log_callback(int severity, const char *msg)
{
    char szBuffer[512];

    FILE *pFd = fopen("./log.txt", "ab+");
    if (pFd == NULL)
        return;

    const char *severity_str;
    switch (severity)
    {
    case EVENT_LOG_DEBUG:
        severity_str = "debug";
        break;
    case EVENT_LOG_MSG:
        severity_str = "msg";
        break;
    case EVENT_LOG_WARN:
        severity_str = "warn";
        break;
    case EVENT_LOG_ERR:
        severity_str = "err";
        break;
    default:
        severity_str = "???";
        break;
    }

    snprintf(szBuffer, sizeof(szBuffer), "[%s]:%s", severity_str, msg);

    (void)fwrite(szBuffer, 1, strlen(szBuffer), pFd);

    fclose(pFd);
}


int main()
{
    //替换记录日志的默认函数
    event_set_log_callback(log_callback);
}

 

posted @ 2019-01-14 23:34  osbreak  阅读(1113)  评论(0编辑  收藏  举报