热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

linuxc日志功能实现

一般linux下的c语音项目都会通过打印进行调试,简单临时的可能就使用printf函数进行凑合了,但是对于大一点的项目就不是很方便了,现在也有很多开源软件里面都有进行相应的日志功能的封装,不过

一般linux 下的c语音项目都会通过打印进行调试,简单临时的可能就使用printf函数进行凑合了,但是对于大一点的项目就不是很方便了,现在也有很多开源软件里面都有进行相应的日志功能的封装,不过那对于自己开发的项目调用就没那么简单了,所以基于此背景,写下自己的一点思路供大家参考,欢迎对不足的地方指出完善。

下面就把代码贴出来。

log.h

#ifndef _LOG_H
#define _LOG_H

#include
#include

#define MAX_LOG_LEN 1024

/* 添加了打印语句所在的文件、行号、函数信息 */
#define C_LOG(level, fmt, argc...) log_message(level, "[file:%s,line:%d,func:%s]" fmt, __FILE__, __LINE__, __FUNCTION__, ##argc)

#endif

log.c

#include 
#include
#include "log.h"

static const char *log_level_str[] = {
[LOG_EMERG] = "EMERG",
[LOG_ALERT] = "ALERT",
[LOG_CRIT] = "CRIT",
[LOG_ERR] = "ERR",
[LOG_WARNING] = "WARNING",
[LOG_NOTICE] = "NOTICE",
[LOG_INFO] = "INFO",
[LOG_DEBUG] = "DEBUG",
};

static void get_current_time(char *buf, int len)
{
time_t timep;
struct tm *p;

time(&timep);
p = gmtime(&timep);
snprintf(buf, len - 1, "%d/%d/%d %d-%d-%d", (1900 + p->tm_year), (1 + p->tm_mon), p->tm_mday, p->tm_hour, p->tm_min, p->tm_sec);
}

static void vlog_message(const int level, const char* fmt, va_list args)
{
char buf[MAX_LOG_LEN+1] = {0};
char time[128] = {0};

get_current_time(time, sizeof(time) - 1);
vsnprintf(buf, sizeof(buf), fmt, args);
/* 可以在这里组装需要的信息 */
fprintf(stderr, "%s[%s]%s\n", time, log_level_str[level], buf); /* 时间,级别,位置,日志内容 */
/* cat /var/log/messages 进行日志查看 */
syslog(level, "%s", buf);
}

void log_message(const int level, const char *fmt, ...)
{
va_list args;

va_start(args, fmt);
vlog_message(level, fmt, args);
va_end(args);
}
main..c

/*
*
* 说明: 日志模块调用测试使用,仅供参考。
* 函数使用可以网上查询具体参数含义
*
*/

#include "log.h"

int main(int argc, char **argv)
{
/* 打开一个到系统日志记录程序的连接,打开之后就可以用syslog或vsyslog函数向系统日志里添加信息了 */
openlog("APP", LOG_PID, 0);

/* 用来设置记录日志的优先级,即只记录指定优先级的日志消息 */
setlogmask(LOG_UPTO(LOG_INFO));

C_LOG(LOG_INFO, "ABC LOG_NOTICE");
C_LOG(LOG_INFO, "ABC LOG_INFO");
C_LOG(LOG_DEBUG, "ABC LOG_DEBUG");

/* 关闭被用于与syslog守护进程通信的描述符 */
closelog();

return 0;
}

编译:gcc main.c  log.c -o main

运行:./main
2016/12/14 13-34-23[INFO][file:main.c,line:18,func:main]ABC LOG_NOTICE
2016/12/14 13-34-23[INFO][file:main.c,line:19,func:main]ABC LOG_INFO
2016/12/14 13-34-23[DEBUG][file:main.c,line:20,func:main]ABC LOG_DEBUG
查看结果:tail -f /var/log/messages
Dec 14 05:11:54 localhost NetworkManager[1971]:    prefix 24 (255.255.255.0)
Dec 14 05:11:54 localhost NetworkManager[1971]:    gateway 192.168.0.1
Dec 14 05:11:54 localhost NetworkManager[1971]:    nameserver '222.246.129.80'
Dec 14 05:11:54 localhost NetworkManager[1971]:    nameserver '59.51.78.210'
Dec 14 05:11:54 localhost NetworkManager[1971]:    domain name 'DHCP'
Dec 14 05:11:54 localhost NetworkManager[1971]:    domain name 'HOST'
Dec 14 05:17:29 localhost APP[26091]: [file:main.c,line:18,func:main]ABC LOG_NOTICE
Dec 14 05:17:29 localhost APP[26091]: [file:main.c,line:19,func:main]ABC LOG_INFO
Dec 14 05:34:23 localhost APP[26372]: [file:main.c,line:18,func:main]ABC LOG_NOTICE
Dec 14 05:34:23 localhost APP[26372]: [file:main.c,line:19,func:main]ABC LOG_INFO




推荐阅读
  • Linux环境变量函数getenv、putenv、setenv和unsetenv详解
    本文详细解释了Linux中的环境变量函数getenv、putenv、setenv和unsetenv的用法和功能。通过使用这些函数,可以获取、设置和删除环境变量的值。同时给出了相应的函数原型、参数说明和返回值。通过示例代码演示了如何使用getenv函数获取环境变量的值,并打印出来。 ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Commit1ced2a7433ea8937a1b260ea65d708f32ca7c95eintroduceda+Clonetraitboundtom ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了PE文件结构中的导出表的解析方法,包括获取区段头表、遍历查找所在的区段等步骤。通过该方法可以准确地解析PE文件中的导出表信息。 ... [详细]
  • 本文介绍了一个题目的解法,通过二分答案来解决问题,但困难在于如何进行检查。文章提供了一种逃逸方式,通过移动最慢的宿管来锁门时跑到更居中的位置,从而使所有合格的寝室都居中。文章还提到可以分开判断两边的情况,并使用前缀和的方式来求出在任意时刻能够到达宿管即将锁门的寝室的人数。最后,文章提到可以改成O(n)的直接枚举来解决问题。 ... [详细]
  • 本文讨论了clone的fork与pthread_create创建线程的不同之处。进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合。在调用系统调用fork创建一个进程时,子进程只是完全复制父进程的资源,这样得到的子进程独立于父进程,具有良好的并发性。但是二者之间的通讯需要通过专门的通讯机制,另外通过fork创建子进程系统开销很大。因此,在某些情况下,使用clone或pthread_create创建线程可能更加高效。 ... [详细]
  • 预备知识可参考我整理的博客Windows编程之线程:https:www.cnblogs.comZhuSenlinp16662075.htmlWindows编程之线程同步:https ... [详细]
  • 本文讨论了一个数列求和问题,该数列按照一定规律生成。通过观察数列的规律,我们可以得出求解该问题的算法。具体算法为计算前n项i*f[i]的和,其中f[i]表示数列中有i个数字。根据参考的思路,我们可以将算法的时间复杂度控制在O(n),即计算到5e5即可满足1e9的要求。 ... [详细]
  • 负载均衡_Nginx反向代理动静分离负载均衡及rewrite隐藏路径详解(Nginx Apache MySQL Redis)–第二部分
    nginx反向代理、动静分离、负载均衡及rewrite隐藏路径详解 ... [详细]
author-avatar
44要和自己交个朋友
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有