本文介绍: INFO = 0,WARINIG,ERROR,MAX_LEVELchar* str;if (g_fp!= NULL) {return;return;return;return;if (g_fp!= NULL) {return;if (!g_debug) {return;

目录

支持的功能点

具体实现


支持功能

  1. 支持Error、Warning、Info、Debug、Trace五种日志级别
  2. 日志格式化,日志输出格式为[日志级别]  [时间] [文件名]  [函数名] 日志,时间精确日期毫秒
  3. 日志输出,日志文件名支持自定义,若没有定义日志文件,则丢弃日志信息
  4. 日志记录,提供日志记录接口

具体实现

#include <stdio.h>
#include <stdint.h>
#include <sys/types.h>
#include <string.h>
#include <fcntl.h>
#include <errno.h>
#include<unistd.h>
#include<stdlib.h>

static FILE *g_fp = NULL;
#define MAX_FILE_SZIE (30000000)
#define TIME_BUF_LEN (100)
#define LOG_BUF_LEN (2048)

typedef enum _log_level_e {
    INFO = 0,
    WARINIG,
    ERROR,
    MAX_LEVEL
} log_level_t;

typedef struct __level_str_s{
    log_level_t level;
    char* str;
} level_str_t;

level_str_t g_level_strs[MAX_LEVEL] = {
        {INFO, “INFO”},
        {WARINIG, “WARNING”},
        {ERROR, “ERROR”}
};

static char* log_name = “./test.log“;
static char* bak_log = “./test_bak.log“;
static int g_debug = 1;

void logger_init(uint32_t ip_addr);

void logger_write(log_level_t level, char *fmt, …);

void logger_set_debug(int debug);

void logger_uninit();

#define log_write(level, format, …)
    logger_write(level, “[%s:%d][%s] “format, __FILE__, __LINE__, __func__, ##__VA_ARGS__)

void logger_init(uint32_t ip_addr)
{
    char log[105] = {0};
    if (g_fp != NULL) {
        return;
    }
    struct in_addr addr;
    addr.s_addr = ip_addr;
    snprintf(log, sizeof(log), “%s-ipc.log”, inet_ntoa(addr));
    g_fp = fopen(log, “wb+”);
    return;
}

void logger_set_debug(int debug)
{
    g_debug = debug;

    return;
}

static void check_file_size()
{
    struct stat st;
    stat(log_name, &amp;st);
    if (st.st_size < MAX_FILE_SZIE) {
        return;
    }
    if (g_fp != NULL) {
        fclose(g_fp);
        g_fp = NULL;
    }

    if (access(bak_log, F_OK) == 0) {
        remove(bak_log);
    }

    rename(log_name, bak_log);
    g_fp = fopen(log_name, “wb“);

    return;
}

void logger_write(log_level_t level, char *fmt, …)
{
    if (!g_debug) {
        return;
    }
    char out[LOG_BUF_LEN] = {0};
    char date[TIME_BUF_LEN] = {0};
    char logStr[1500] = {0};
    va_list args;
    struct tm *tp = NULL;

    check_file_size();
    // 转化日志数据
    va_start(args, fmt);
    vsprintf(logStr, fmt, args);
    va_end(args);

    // 获取当前日期
    time_t tt;
    time(&amp;tt);
    tp = localtime(&amp;tt);
    snprintf(date, sizeof(date),”%02d/%02d/%02d %02d:%02d:%02d“,
             tp->tm_year+1900, tp->tm_mon+1, tp->tm_mday, tp->tm_hour, tp->tm_min, tp->tm_sec);
    // 生成完成日志
    snprintf(out, sizeof(out),”%s [%s] %s”,date, g_level_strs[level].str, logStr);

    fprintf(g_fp, “%sn“, out);
    fflush(g_fp);

    printf(“%sn”, out);

    return;
}

void logger_uninit()
{
    if (g_fp != NULL) {
        fclose(g_fp);
    }
    return;
}

原文地址:https://blog.csdn.net/s18098934396/article/details/134693488

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_44662.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注