一)下载源文件
log4cxx的官方下载地址是http://logging.apache.org/log4cxx/index.html,我用的是0.10.0版本。
可以直接取下面的链接版本
http://www.apache.org/dyn/closer ... g4cxx-0.10.0.tar.gz
下载后解压
二)安装log4cxx需要apr支持,apr官网地址是:http://apr.apache.org/,需要下载apr和apr_util两个组件。
地址: http://apr.apache.org/download.cgi
我用的版本分别是apr-1.5.1.tar.gz和apr-util-1.5.4.tar.gz。
[注意]不要放在共享的windows目录下解压安装,./configure会出现:./config.status: line 331: syntax error near unexpected token `newline' 的错误
三)第一步安装apr-1.5.1.tar,顺序不能错,它必须首选安装
$tar zxvf apr-1.5.1.tar.gz
$cd apr-1.5.1
$./configure --prefix=/usr/local/apr
$make
$su root
$make install
四)然后安装apr-util-1.5.4
$./configure --prefix=/usr/local --with-apr=/usr/local/apr
$make
$su root
$make install
configure选项 --with-apr=/usr/local/apr指定apr库的位置
五)最后就可以安装log4cxx了
$tar zxvf apache-log4cxx-0.10.0.tar.gz
$cd apache-log4cxx-0.10.0
$./configure --prefix=/usr/local
$make
$su root
$make install
六)因为编译成的是共享库,最后还要设置下搜索目录,编辑~/.bashrc,添加下面两行
LD_LIBRARY_PATH=/usr/local/lib
export LD_LIBRARY_PATH
OK,至此log4cxx就安装完毕了。
七)最后写个程序,测试下。
#include <log4cxx/logger.h>
#include <log4cxx/logstring.h>
#include <log4cxx/propertyconfigurator.h>
int main(int argc, char* argv[])
{
using namespace log4cxx;
// 读取配置文件
PropertyConfigurator::configure("log4cxx.cfg");
// 建立两个logger
LoggerPtr logger1 = Logger::getLogger("TraceYourName");
LoggerPtr logger2 = Logger::getLogger("Patch");
LOG4CXX_TRACE(logger1, "TRACE");
LOG4CXX_WARN(logger1, "WARNING");
LOG4CXX_DEBUG(logger1, "DEBUG");
LOG4CXX_ASSERT(logger1, false, "ASSERT");
LOG4CXX_FATAL(logger1, "FATAL");
LOG4CXX_TRACE(logger2, "TRACE");
LOG4CXX_ERROR(logger2, "ERROR");
return 0;
}
编译链接
$g++ -o main main.cpp -llog4cxx -lapr-1 -laprutil-1 -lexpat
因为log4cxx需要依赖arp和aprutil两个库,而这两个库又需要依赖 expat库,所以在链接的时候需要将/usr/local/lib下的这三个库链接进可执行程序
八)最后在运行程序的时候会报如下错误
log4cxx: Could not read configuration file [log4cxx.cfg].
log4cxx: No appender could be found for logger (TraceYourMama).
log4cxx: Please initialize the log4cxx system properly.
这是因为没有配置log4cxx.cfg文件,在可执行程序目录下手动创建以配置文件log4cxx.cfg
填充内如如下
log4j.rootLogger=debug, R
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
# Pattern to output the caller's file name and line number.
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=./hello.log
log4j.appender.R.MaxFileSize=100KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=10
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%5p %c [%t] (%F:%L) - %m%n
九)上面配置了一个名字为hello.log,大小100K的日志文件,再次运行可执行程序,发现当前目录下生成了一个hello.log文件,打开内容如下:
WARN TraceYourMama [0x2aafe4193ac0] (../src/main.cpp:196) - WARNING
DEBUG TraceYourMama [0x2aafe4193ac0] (../src/main.cpp:197) - DEBUG
ERROR TraceYourMama [0x2aafe4193ac0] (../src/main.cpp:198) - ASSERT
FATAL TraceYourMama [0x2aafe4193ac0] (../src/main.cpp:199) - FATAL
ERROR Patch [0x2aafe4193ac0] (../src/main.cpp:201) - ERROR |