惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

T
Threatpost
V
Vulnerabilities – Threatpost
TaoSecurity Blog
TaoSecurity Blog
C
Cybersecurity and Infrastructure Security Agency CISA
P
Proofpoint News Feed
G
GRAHAM CLULEY
S
Securelist
P
Palo Alto Networks Blog
MongoDB | Blog
MongoDB | Blog
A
Arctic Wolf
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
WordPress大学
WordPress大学
Project Zero
Project Zero
T
Threat Research - Cisco Blogs
L
Lohrmann on Cybersecurity
C
Cyber Attacks, Cyber Crime and Cyber Security
F
Fortinet All Blogs
博客园 - 叶小钗
B
Blog RSS Feed
C
Cisco Blogs
Google DeepMind News
Google DeepMind News
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
Apple Machine Learning Research
Apple Machine Learning Research
G
Google Developers Blog
K
Kaspersky official blog
D
Docker
Latest news
Latest news
Cisco Talos Blog
Cisco Talos Blog
T
Tor Project blog
Cyberwarzone
Cyberwarzone
Security Latest
Security Latest
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
D
Darknet – Hacking Tools, Hacker News & Cyber Security
Spread Privacy
Spread Privacy
Microsoft Azure Blog
Microsoft Azure Blog
C
Check Point Blog
J
Java Code Geeks
Simon Willison's Weblog
Simon Willison's Weblog
T
Tenable Blog
Recent Announcements
Recent Announcements
T
Tailwind CSS Blog
H
Help Net Security
L
LINUX DO - 热门话题
T
The Exploit Database - CXSecurity.com
Jina AI
Jina AI
S
SegmentFault 最新的问题
MyScale Blog
MyScale Blog
NISL@THU
NISL@THU
美团技术团队
腾讯CDC

博客园 - 太白飞仙

.Net网络资源 CI创意的方法与技巧 可控人生核聚变 用c#备份和还原sql server 2000数据库 论文先睹:关于科学的生命哲学的思考 蚂蚁造山的思考 语言争霸VS魔兽争霸 :: IT世界VS魔兽世界 第九章 SQL Server的简单应用 [导入]类型MSN窗体行为的实现(.NET 2.0) - 太白飞仙 - 博客园 [导入]文章藏金阁 [导入]敏捷实验室的一次争论 [导入]Netron研究(四)----"移动和联通"之联通篇 [导入]Netron研究(二)----"容器"登场 [导入]Netron研究(一)----初识 [导入]Netron研究(三)----"移动和联通"之移动篇 [导入]Agile Framework工作流服务的设计思路 [导入]KISS原则 [导入]WWF工作流引擎的一个奇怪现象 - 太白飞仙 - 博客园 [导入]时刻提防过度设计
[导入]Agile Framework的日志服务
太白飞仙 · 2006-01-16 · via 博客园 - 太白飞仙

说明

在企业应用程序开发中,日志记录是一个非常关键的且必不可少的步骤。一份详细清晰的日志会非常容易的进行错误定位,给项目后期的维护工作起到很好的帮助作用,能极大的降低系统维护成本。Agile Framework框架采用了有名的Log4Net日志组件,本身就集成了优秀的基础日志功能,在框架之上开发的应用程序,不需要再自己重新编写日志服务。

基本用法

Agile Framework的日志组件已经被系统自动加载到了IoC容器之中,所以任何需要日志服务的商业组件只需要在构造函数中声明一个ILog的参数,就可以自动获得日志服务。代码如下所示:

public class BusinessComponent { ILog logger = null; public BusinessComponent(ILog log) { logger = log; } public void DoSomething() { logger.Info("logging infomation"); } }

日志策略

Agile Framework提供的日志级别共有五级,分别为:

  • Debug(调试信息):一般用于打印某些变量值,调试应用程序。
  • Info(事务信息):一般用于记录程序的正常流程中的操作信息,以备将来查询之用。
  • Warn(警告信息):当程序运行中出现了一些小错误,但是可以被系统处理,没有影响系统功能的时候,请加上一条警告信息。
  • Error(错误信息):应用程序中出现的某些无法处理的错误,会影响一定范围内的业务功能,但不影响整个应用系统。
  • Fatal(致命错误):一般发生于某些基础性服务之中,例如数据库连接错误,会导致整个系统崩溃,无法让应用系统继续运行。

由于Agile Framework本身会自动记录所有的的错误信息,所以推荐的日志记录策略为仅记录Warn、Info及Debug级别的信息。如果出现了错误,假如自己无法处理该异常,则不要截获异常。这个异常最后会被框架捕获并自动记录到日志中,所以为了避免信息的重复记录,保持日志的清晰,请不要为异常记录错误日志信息。

日志驱动开发(LDD)

所谓“日志驱动开发”的概念,既在开发中不采用IDE提供的下断点进行单步跟踪的调试方式。而是完全采用框架提供的日志功能进行调试!这种方式对一些习惯采用断点进行调试的程序员养成写详细日志的习惯有一定帮助作用。许多程序员在解决问题时已经习惯了用IDE下断点来Debug错误,但是一旦当程序发布给用户之后,由于缺少必要的调试环境,所以往往对程序在实际中运行发生的异常错误束手无策。

Agile Framework有插件式编程的特点,因为开发的插件没有程序入口,所以要进行单步跟踪调试会非常困难。所以可以在一定程度上强制程序员养成采用日志来进行调试的习惯,采用Agile Framework框架和LDD开发方式开发出来的应用程序,日志会自然而然的非常详细和清晰。

但是在开发中频繁的察看日志来观察程序的运行过程会显得比较麻烦和低效,所以Agile Framework还提供了一个日志跟踪器的开发辅助工具,可以实时的跟踪和察看日志信息,提高了开发效率。详细情况请参考:实时日志跟踪器。此外,为了最有效的提高效率,Agile Framework也还是允许在开发的初期以利用单元测试功能来方便的进行单步跟踪调试的。


文章来源:http://www.agilelabs.cn/blogs/linkin/archive/2005/12/28/366.aspx