支持的功能点
- 支持Error、Warning、Info、Debug、Trace五种日志级别;
- 日志格式化,日志输出格式为[日志级别] [时间] [文件名] [函数名] 日志,时间精确日期的毫秒;
- 日志输出,日志文件名支持自定义,若没有定义日志文件,则丢弃日志信息;
- 日志记录,提供日志记录接口。
具体实现
#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);
#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;
static void check_file_size()
{
struct stat st;
stat(log_name, &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“);
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(&tt);
tp = localtime(&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进行投诉反馈,一经查实,立即删除!