求一个在linux下的函数:将日志打印到文件中 (重点实现要求1、2即可)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了求一个在linux下的函数:将日志打印到文件中 (重点实现要求1、2即可)相关的知识,希望对你有一定的参考价值。

函数具体要求如下:
1、日志文件的存放路径要可配置
2、日志的大小要可配置
3、日志的名字要按今天日期命名+今天的日志个数。例如:20120822_0.log
4、日志大小达到配置要求要重新生成一个新的日志,日志名字要在原来的基础上加1。例如:按3要求,新生成的文件名为:20120822_1.log
5、日志要分3个等级、debug调试、info信息、release释放 级
6、日志等级要可配置。
7、日志信息的开头要加 日期+时间+毫秒:。例如:2012-08-22 10:32:34.234:

参考技术A Python 的 loggong模块能完美完成你的要求。追问

用C语言怎么实现呢?

第十章

一、打印内核调试信息:printk

printk函数的原型如下:

asmlinkage int printk(const char * fmt, ... )

printk文件是一个简单的有4个数字组成的文本文件,该文件的默认值如下:6 4 1 7

6:将消息输出到控制台的级别。

4:默认的消息日志级别。

1:控制台日志级别可被设置的最小值

7:控制台日志级别的默认值.

(二)  防止printk函数降低Linux驱动性能

虽然使用printk函数可以很方便地将消息写入日志文件或控制台。但大量使用printk函数频繁操作日志问阿金或控制台设备文件会严重影响Linux驱动的性能。因此,这就要求Linux驱动只在开发阶段使用printk函数输出消息,在正式发布Linux驱动时将可能影响性能的printk函数去掉。最好的方法无疑是利用C语言中的编译指令。(#if、#else、#endif等)。如果不想使用printk输出消息,只要将#if中的1改为0即可不使用printk输出消息。

(三)  通过虚拟文件系统(/pron)进行数据交互

/pron用来作为内核空间与用户空间进行数据交互的工具,它的文件系统的行为凡是与设备文件系统(/dev)类似,/pron是虚拟文件系统,是内存映射,所有读写/pron的操纵都是对内存的读写,因此,它也可以作为Linux驱动与用户空间程序交互的工具。

/pron 文件系统主要通过proc_dir_entry.read_proc和proc_dir_entry.read_write函数指针来设置读写/pron目录中的虚拟文件的动作处理函数,proc_dir_entry结构体代表一个虚拟目录或文件

四、调试工具

1.用gdb调试用户空间程序

2.用gdbserver远程调试用户空间程序

3.用kgdb远程调试内核程序

以上是关于求一个在linux下的函数:将日志打印到文件中 (重点实现要求1、2即可)的主要内容,如果未能解决你的问题,请参考以下文章

javasystem.out打印日志在linux不打印

如何在Linux中将日志打印到文件和cli中[重复]

如何实时查看linux下的日志

Linux /var/log下的各种日志文件

linux 日志文件大小怎么调整,求高手!!

linux下的一个超大日志文件有18G,用啥工具能打开查看里面的内容呀?