在C语言中使用syslog打印日志到日志文件

参见 《unix 环境高级编程》第13 章 精灵进程

Syslog为每个事件赋予几个不同的优先级:

LOG_EMERG——紧急情况 
LOG_ALERT——应该被立即改正的问题,如系统数据库破坏
LOG_CRIT——重要情况,如硬盘错误
LOG_ERR——错误
LOG_WARNING——警告信息
LOG_NOTICE——不是错误情况,但是可能需要处理
LOG_INFO——情报信息
LOG_DEBUG——包含情报的信息,通常旨在调试一个程序时使用
#include<stdio.h>
#include<stdlib.h>
#include <syslog.h>

syslog(LOG_INFO, "hello %s","woring");
syslog(LOG_ERR, "hello %s","test");

范例:

复制代码
#include<stdio.h>
#include<stdlib.h>
#include <syslog.h>

void main(void)
{
    for(int i=0;i<3;i++){
    syslog(LOG_USER|LOG_EMERG,"syslog programming test %d times/n", i);
  }
}
复制代码

➜ c git:(master) ✗ gcc logtest.c -std=c99
➜ c git:(master) ✗ ./a.out

检验:

tail -f /var/log/syslog

Mar 6 17:37:45 brian a.out: syslog programming test 0 times/n
Mar 6 17:37:45 brian a.out: syslog programming test 1 times/n
Mar 6 17:37:45 briana.out: syslog programming test 2 times/n

 

Ubuntu:
/ect/rsyslog.conf
tail -f /var/log/syslog

Other linux:
/etc/syslog.conf
/etc/syslog-ng/syslog-ng.conf
tail -f /var/log/messages

参考:
c语言库函数syslog--将信息记录至系统日志文件
https://blog.csdn.net/jiangxinyu/article/details/1473356

posted @   船长博客  阅读(4422)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
永远相信美好的事情即将发生!
点击右上角即可分享
微信分享提示