记录程序日志的三种选择

记录程序日志的三种选择,第1张

1、采用Log4CXX等公共开源日志组件:这类日志组件的特点是跨平台且功能比较强大,例如可以把日志发往另一台服务器或记录到数据库中等;另外,可配置性较高,可以通过配置文件或程序代码对日志进行很多个性化设置。但从另外一个角度看,由于这些优点往往也导致了在使用方面的缺点。首先,对于一般应用程序来说,它们并不需要太多的功能,通常只需要把日志记录到文件或反馈到应用程序,功能太多反正让用户使用起来觉得繁琐还得背负很多从来都用不到的代码。其次,这类日志组件通常是跨平台的,并不只是针对 Windows 或 VC 的`应用程序,因此使用起来总会觉得有点别扭,例如他们的字符都是用 char 类型的,对于一个 Unicode 程序来说每次写日志都要做字符转换是很不爽的事情,本座在多年前曾经使用过 Log4Cpp ,程序执行时总是报告日志组件有内存泄露,虽然有可能是误报,但是使用起来总觉得很不舒服。

2、自己写几个简单的类或函数记录日志:这种方法的确很简单,通常都不用一两百行的代码。但这种方法通常缺乏规范性和通用性,其他程序需要记录类似的但有点差异的日志时,通常的作法是:Copy-Paste-Modify;另外,这类方法很可能也没有考虑性能或并发方面的问题,通常是直接在工作线程中写日志,对于那些性能要求较高的应用程序是绝对不允许的。

3、干脆不记录任何日志:的确,现在很多程序由于各种原因并没有记录任何日志。但本座以为,如果一个程序是有用的,具备一定功能,并且需要连续运行较长一段时间,那么记录日志是必须的;否则,得认真考虑该程序是否有存在的必要了。

通常情况下有两件事情常常被程序员忽略,一件事情是写日志,另一件事情是写日报,日志是服务于工作流程的,而日报则是对一天工作内容的总结。日志和日报(周报)共同点都是给人看的,日志往往是给自己或业务流程上的同事看的,而日报(周报)往往是给团队负责人看的。

日志最主要的功能是记录程序的执行流程。日志是对程序执行过程的记录,包括登录角色、触发事件的流程、业务处理的流程、关键事件、数据访问、网络访问、权限获取、对应日期、执行是否成功、返回值等等内容,可以说日志是最真实的记录软件执行流程的文档。

日志可以说是程序的健康监控表。通过日志能够快速发现问题的根源,能够对程序的执行流程进行追踪,同时还可以根据日志进行数据的统计和分析,这其中就包括性能分析等重要的内容。另外,有的程序还要根据相关部门的要求进行一些日志记录,这些内容往往涉及到一些比较敏感的数据资源,比如涉及到个人隐私等数据,像住宿记录、就医记录、金融记录等等。

看日志的人比较多,所以要注意措辞。看日志的人不仅包括开发人员,还包括产品经理、运维人员、测试人员等,所以日志一定要尽量的详细和可靠,输出的内容要清晰明了,理论上是越详细越好,但是也有一个度要把握好,因为日志记录往往要进行IO输出,这也会占用一部分系统资源,有的时候日志记录会占用较大的存储空间,G以上的日志记录也是比较常见的。另外,日志记录往往都要根据业务类型保持一段时间,所以日志记录比较大也是比较普遍的事情。

写好日志是程序员职业素养的一个体现,好的日志也会为程序后期的维护奠定一个好的基础,所以作为开发人员来说,一定要重视日志。

我从事软件开发工作多年,目前也在指导计算机专业的研究生(大数据、AI方向),对计算机感兴趣的朋友可以

写本文的目的是我在写 python 项目的时候需要记录日志,我忘记怎么处理了,每次都需要去网上查一遍, 好记性不如烂笔头 , 这里把查阅的内容记录下来,方便以后查找。

python 项目中记录日志,可以使用 logging 模块,logging 模块定义的函数和类为应用程序和库的开发实现了一个灵活的事件日志系统。logging 模块是Python的一个标准库模块,由标准库模块提供日志记录API的关键好处是所有Python模块都可以使用这个日志记录功能。所以,你的应用日志可以将你自己的日志信息与来自第三方模块的信息整合起来。

在 __init__.py 文件中做如下配置:

控制台输出日志如下:

参考文档

https://www.cnblogs.com/yyds/p/6901864.html


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11938859.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-19
下一篇 2023-05-19

发表评论

登录后才能评论

评论列表(0条)

保存