开源日志系统log4cplus(一)

log4cplus是C++编写的开源的日志系统,功能非常全面,用到自己开发的工程中会比较专业的,:),本文介绍了log4cplus基本概念,以及如何安装,配置。 

### 简介 ###
log4cplus是C++编写的开源的日志系统,前身是java编写的log4j系统.受Apache Software License
保护。作者是Tad E. Smith。log4cplus具有线程安全、灵活、以及多粒度控制的特点,通过将信息划分
优先级使其可以面向程序调试、运行、测试、和维护等全生命周期; 你可以选择将信息输出到屏幕、文件、
NT event log、甚至是远程服务器;通过指定策略对日志进行定期备份等等。
 
### 下载 ###
最新的log4cplus可以从以下网址下载 
本文使用的版本为:1.0.2
 
### 安装 ###
 
1. linux下安装

tar xvzf log4cplus-x.x.x.tar.gz
cd log4cplus-x.x.x.
/configure --prefix=/where/to/install
make
make install

这里我采用缺省安装路径:/usr/local,下文如无特别说明,均以此路径为准。
 
2. windows下安装
不需要安装,有一个msvc6存放包括源代码和用例在内的开发工程(for VC6 only),使用之前请先编译
"log4cplus_dll class"工程生成dll,或者编译"log4cplus_static class"工程生成lib.
 
### 使用前的配置 ###
1. linux下的配置
确保你的Makefile中包含 /usr/local/lib/liblog4cplus.a(静态库)或  -llog4cplus(动态库)即可,
头文件在/usr/local/include/log4cplus目录下。对于动态库,要想正常使用,还得将库安装路径加入到
LD_LIBRARY_PATH 中,我一般是这样做的:以管理员身份登录,在/etc/ld.so.conf中加入安装路径,这里
是/usr/local/lib,然后执行ldconfig使设置生效即可。
2. windows下的配置
将"log4cplus_dll class"工程或"log4cplus_static class"工程的dsp 文件插入到你的工程中,或者直接
把两个工程编译生成的库以及头文件所在目录放到你的工程的搜索路径中,如果你使用静态库,请在你的工程中
"project/setting/C++"的preprocessor definitions中加入LOG4CPLUS_STATIC。
 
### 构成要素介绍 ###
虽然功能强大,应该说log4cplus用起来还是比较复杂的,为了更好地使用它,先介绍一下它的基本要素。
Layouts      :布局器,控制输出消息的格式.
Appenders    :挂接器,与布局器紧密配合,将特定格式的消息输出到所挂接的设备终端
               (如屏幕,文件等等)。
Logger       :记录器,保存并跟踪对象日志信息变更的实体,当你需要对一个对象进行
               记录时,就需要生成一个logger。
Categories   :分类器,层次化(hierarchy)的结构,用于对被记录信息的分类,层次中
               每一个节点维护一个logger的所有信息。
Priorities   :优先权,包括TRACE, DEBUG, INFO, WARNING, ERROR, FATAL。
本文介绍了log4cplus基本概念,以及如何安装,配置,下一篇将通过例子介绍如何使用log4cplus。
时间: 2024-10-01 16:42:39

开源日志系统log4cplus(一)的相关文章

开源日志系统log4cplus(四)

将log信息记录到文件应该说是日志系统的一个基本功能,log4cplus在此基础上,提供了更多的功能,可以按照你预先设定的大小来决定是否转储,当超过该大小,后续log信息会另存到新文件中,依次类推:或者按照日期来决定是否转储.本文将详细介绍这些用法. ### 如何将log记录到文件 ### 我们在例5中给出了一个将log记录到文件的例子,用的是FileAppender类实现的,log4cplus提供了三个类用于 文件操作,它们是FileAppender类.RollingFileAppender类

开源日志系统log4cplus(五)

日志系统的另一个基本功能就是能够让使用者按照自己的意愿来控制什么时候,哪些log信息可以输出. 如果能够让用户在任意时刻设置允许输出的LogLevel的信息就好了,log4cplus通过LogLevelManager. LogLog.Filter三种方式实现了上述功能. ### 优先级控制 ### 在研究LogLevelManager之前,首先介绍一下log4cplus中logger的存储机制,在log4cplus中,所有 logger都通过一个层次化的结构(其实内部是hash表)来组织的,有一

开源日志系统log4cplus(七)

经过短暂的熟悉过程,log4cplus已经被成功应用到了我的项目中去了,效果还不错,:)除了上文提及的 功能之外,下面将介绍log4cplus提供的线程和套接字的使用情况. ### NDC ### 首先我们先了解一下log4cplus中嵌入诊断上下文(Nested Diagnostic Context),即NDC.对log系统而言, 当输入源可能不止一个,而只有一个输出时,往往需要分辩所要输出消息的来源,比如服务器处理来自不同 客户端的消息时就需要作此判断,NDC可以为交错显示的信息打上一个标记

开源日志系统log4cplus(三)

本文介绍了三种控制输出格式的布局管理器的概念和使用情况,通过掌握这些知识,可以更有效地控制log系统输出尽可能贴近你需求的信息来. ### 如何控制输出消息的格式 ### 前面已经讲过,log4cplus通过布局器(Layouts)来控制输出的格式,log4cplus提供了三种类型的Layouts, 分别是SimpleLayout.PatternLayout.和TTCCLayout.其中: 1. SimpleLayout 是一种简单格式的布局器,在输出的原始信息之前加上LogLevel和一个"-

开源日志系统log4cplus(二)

本文介绍了使用log4cplus有六个步骤,并提供了一些例子引导你了解log4cplus的基本使用. ### 基本使用 ### 使用log4cplus有六个基本步骤: 1. 实例化一个appender对象 2. 实例化一个layout对象 3. 将layout对象绑定(attach)到appender对象 4. 实例化一个logger对象,调用静态函数:log4cplus::Logger::getInstance("logger_name") 5. 将appender对象绑定(atta

Logback 1.0.1发布 开源日志系统

Logback 是一个作为log4j项目的继任者,是由Log4j的创始人Ceki Gulcu设计成一款开源日志系统. Logback 配备基本架构以通用于不同情况下的需求,它分为三个模块:Core module.Classic module 和 Access module.Core module核心模块是为其他两个模块设计的一个基础模块.Classic module类似于log4j的改进版本,实现了SLF4J API使你可以很容易地在logback和其它日志系统(log4j 或 JDK14 )之

开源日志系统比较

原文地址:http://www.cnblogs.com/ibook360/p/3159544.html 1. 背景介绍   许多公司的平台每天会产生大量的日志(一般为流式数据,如,搜索引擎的pv,查询等),处理这些日志需要特定的日志系统,一般而言,这些系统需要具有以下特征: (1) 构建应用系统和分析系统的桥梁,并将它们之间的关联解耦: (2) 支持近实时的在线分析系统和类似于Hadoop之类的离线分析系统: (3) 具有高可扩展性.即:当数据量增加时,可以通过增加节点进行水平扩展. 本文从设计

日志系统之Flume采集加morphline解析

概述 这段时间花了部分时间在处理消息总线跟日志的对接上.这里分享一下在日志采集和日志解析中遇到的一些问题和处理方案. 日志采集-flume logstash VS flume 首先谈谈我们在日志采集器上的选型.由于我们选择采用ElasticSearch作为日志的存储与搜索引擎.而基于ELK(ElasticSearch,Logstash,Kibana)的技术栈在日志系统方向又是如此流行,所以把Logstash列入考察对象也是顺理成章,Logstash在几大主流的日志收集器里算是后起之秀,被Elas

ELK统一日志系统的应用

收集和分析日志是应用开发中至关重要的一环,互联网大规模.分布式的特性决定了日志的源头越来越分散, 产生的速度越来越快,传统的手段和工具显得日益力不从心.在规模化场景下,grep.awk 无法快速发挥作用,我们需要一种高效.灵活的日志分析方式,可以给故障处理,问题定位提供更好的支持.基于全文搜索引擎 Lucene 构建的 ELKstack 平台,是目前比较流行的日志收集方解决方案. ELK系统的部署按照官方文档操作即可,相关资料也很多,这篇文章更多的关注三个组件的设计和实现,帮助大家了解这个流行的