一个好的系统通常需要日志输出帮助定位问题 。Apache基金会的log4cxx提供的完善的Log分级和输出功能。所以准备把该Log模块加入的系统中。

使用log4cxx需要满足一下功能:

1.提供日志分级输出功能

2.能将日志导出到文件

3.每个Log占一行,在每行的前面输出时间,因为很多时候定位问题需要时间值

4. 每天更换日志文件

5.支持线程安全

6.支持用代码配置Log属性

在网上google了很久,都是零散的信息,对于中文网页,千篇一律都是一样的文章。下面介绍log4cxx的用法。

使用log4cxx 需要引入头文件

#include <log4cxx/logger.h> 
#include <log4cxx/helpers/object.h> 
#include <log4cxx/helpers/pool.h> 
#include <log4cxx/basicconfigurator.h> 
#include <log4cxx/PatternLayout.h> 
#include <log4cxx/DailyRollingFileAppender.h>

如果使用到其他log4cxx的类,也需要include对应的头文件。

同时需要将log4cxx.lib添加到工程中,并且将log4cxx.dll拷贝到exe所在目录。

网上很多例子都是用配置文件来设置Log系统,但是使用外部Log文件可能会暴露过多的信息,导致系统风险。所以改用代码中配置。

log4cxx::PatternLayout提供通过字符串格式化日志;

%r [%t] %-5p - %m\n  用来格式化日志

%r  显示从程序启动到记录本日志经历的毫秒数。

%t 输出该日志的线程ID

%-5p 5个字符宽显示日志的优先级

%m 日志消息

\n  换行输出日志

FileAppender是log4cxx中用于配置日志输出到文件的类,FileAppender只能配置固定的文件作为Log输出,但是DailyRollingFileAppender可以用DatePattern来设置Log系统每日更换Log文件。由于软件需要24×7小时运行,所以必须定时更换Log文件,否则单个日志文件会过于庞大。

DatePattern为  '.'yyyy-MM-dd  将会在进入下一天时将前一天的Log文件,如 jianyu.me 更名为 jianyu.me.2013-07-10  这样就避免在同一个Log文件中输出太多Log信息。

"./Log/jianyu.me" 为当前操作的日志文件名,在Log目录下的 jianyu.me文件

使用前需要创建一个LoggerPtr 对象,

例如:

LoggerPtr  m_logger;

使用以下宏来输出Log,这几个宏代表不同的Log等级

LOG4CXX_DEBUG(logger, message) 
LOG4CXX_TRACE(logger, message) 
LOG4CXX_INFO(logger, message) 
LOG4CXX_WARN(logger, message) 
LOG4CXX_ERROR(logger, message)

关于log4cxx编译可以参考另一篇i帖子

代码如下:

#include <log4cxx/logger.h> 
#include <log4cxx/helpers/object.h> 
#include <log4cxx/helpers/pool.h> 
#include <log4cxx/basicconfigurator.h> 
#include <log4cxx/PatternLayout.h> 
#include <log4cxx/DailyRollingFileAppender.h>

using namespace log4cxx; 
using namespace log4cxx::helpers;

#pragma comment(lib, "log4cxx.lib")

LoggerPtr  m_logger;

log4cxx::LogString    logFile(L"./Log/jianyu.me"); 
log4cxx::LogString    patternStr(L"\%r [\%t] \%-5p - \%m\n"); 
log4cxx::LogString    strDatePattern(L"\'.\'yyyy-MM-dd");

log4cxx::FileAppender* fileAppender = new log4cxx::DailyRollingFileAppender( 
    log4cxx::LayoutPtr(new log4cxx::PatternLayout(patternStr)), 
    logFile, strDatePattern); 
log4cxx::helpers::Pool p; 
fileAppender->activateOptions(p);

log4cxx::BasicConfigurator::configure(log4cxx::AppenderPtr(fileAppender)); 
log4cxx::Logger::getRootLogger()->setLevel(log4cxx::Level::getDebug()); 
m_logger = log4cxx::Logger::getLogger("logger");

LOG4CXX_DEBUG(m_logger, strLog);

Apache log4cxx用法的更多相关文章

  1. how to build apache log4cxx 0.10 by Visual Studio 201*

    Chapter 1 Official Steps  We are going to follow the steps here, http://logging.apache.org/log4cxx/b ...

  2. Apache commons-net用法的一个示例

    jar: commons-io-2.4.jarcommons-net-3.3.jar Code: import java.io.File; import java.io.FileInputStream ...

  3. log4cxx

    1.简介 (1)Apache log4cxx当前是由Apache软件基金会进行维护.它是java中著名开源项目Apache log4j在c++中对应的日志框架.它是借助于APR(Apache Port ...

  4. Apache 项目列表功能分类便于技术选型

    big-data (49):  Apache Accumulo  Apache Airavata  Apache Ambari  Apache Apex  Apache Avro  Apache Be ...

  5. MacBook Apache服务

    想着如何在Mac OS下部署静态网页(纯粹的html,css,js),用惯了windows下的iis,可惜Mac OS下也许只能通过Tomcat或者Apache之类的作为部署容器.听说Mac OS下自 ...

  6. 日志之再说Log4J

    网上关于LOG4J的使用文章太多了,写这篇文章的目的一方面是为了回顾LOG4J的用法,一方面针对配置的使用自动将日志插入数据库,自动发送邮件,还有就是自定义输入实现.后续文章会总结下从LOG4J到LO ...

  7. mac配置php7运行环境

    不用mac自带的apache和php,安装自己想要的版本.配置过程一直采坑,需要有闲时间和好的心理素质才行,哈哈,因为网上很教程都有纰漏之处,所以先把采坑无数后发现的个人认为最好的一个教程链接放在这里 ...

  8. Spring中的BeanUtils与apache commons中的BeanUtils用法[1]

    1. 前言 在开发过程中,经常遇到把要给一个bean的属性赋给另外一个bean.最笨的方法是每个属性都单独写一个,聪明的方法是应用反射写一个工具方法.考虑到这个需求基本每个程序员都会遇到,那么一定已经 ...

  9. Apache自带压力测试工具ab用法简介

    ab命令原理 ab命令会创建很多的并发访问线程,模拟多个访问者同时对某一URL进行访问.它的测试目标是基于URL的,因此,既可以用来测试Apache的负载压力,也可以测试nginx.lighthttp ...

随机推荐

  1. TOPAPI 消息通知机制

    接收用户订阅消息 public class UserSubMain { public static void main(String[] args ) throws ApiException { St ...

  2. Contest2037 - CSU Monthly 2013 Oct (problem A :Small change)

    [题解]:二进制拆分 任意一个整数都可以拆分成 2^0 + 2^1 + 2^2 + 2^3 + ....+ m [code]: #include <iostream> #include & ...

  3. python字符串截取与替换的例子

    python字符串截取与替换的多种方法 时间:2016-03-12 20:08:14来源:网络 导读:python字符串截取与替换的多种方法,以冒号分隔的字符串的截取方法,python字符串替换方法, ...

  4. C#学习笔记(二)

    1.注释:注销,解释2.单行://多行:/**/文档注释:///按enter主食要保证 别人一看就明白3.快速对期待吗:ctrl+k+d,按住ctrl不放,按k,迅速抬起,再按d(按D得时候k已经抬起 ...

  5. What are the advantages of logistic regression over decision trees?FAQ

    What are the advantages of logistic regression over decision trees?FAQ The answer to "Should I ...

  6. Java发送post请求

    package com.baoxiu.test; import java.io.BufferedReader;import java.io.InputStreamReader;import java. ...

  7. 微软在 .NET 3.5 新增了一个 HashSet 类,在 .NET 4 新增了一个 SortedSet 类,本文介绍他们的特性,并比较他们的异同。

    微软在 .NET 3.5 新增了一个 HashSet 类,在 .NET 4 新增了一个 SortedSet 类,本文介绍他们的特性,并比较他们的异同. .NET Collection 函数库的 Has ...

  8. HeadFirst设计模式之工厂模式

    一. 1."工厂模式"不是种真正的设计模式,而是一种编程术语 2.The Factory Method Pattern defi nes an interface for crea ...

  9. POJ2109——Power of Cryptography

    Power of Cryptography DescriptionCurrent work in cryptography involves (among other things) large pr ...

  10. 第一章 CLR的执行模型

    编译器将源代码编译为托管模块.托管木块包含: PE32或PE32+头 CLR头 元数据 IL(中间语言)代码 PE32头的文件可在32或64位的电脑上运行,PE32+的只能在64上运行.Window6 ...