log4cxx日志库RedHat下安装
今天领导交给我一个任务:把log4cxx库在Redhat系统上面安装起来
首先。我得到信息,安装这个库一共须要三个软件
apr-1.4.6.tar.gz
apr-util-1.4.1.tar.gz
apache-log4cxx-0.10.0.tar.gz
安装顺序是从上到下的,为什么,由于后者的安装依赖前者。
我整理了一下思路,有例如以下几个问题:
1.安装log4cxx库到哪个文件夹?
2.安装好之后怎么用?
我首先想到的是网上查资料,结果非常多结果都显示:
1.针对问题1,99%的都安装在/usr/local文件夹下(我的权限是普通用户。安装在/usr/local文件夹下须要root权限,我顿时打了个寒战。万一我安装错了,server暴了怎么办)
2.针对问题2,由于99%的都是安装在/usr/local文件夹下。结果就是随便提供一个測试程序。直接来g++ test.cpp 其它简单參数
我想了又想,终于依照第一步做了(在此之前我向领导要了管理员权限),安装好后。没什么问题,只是。接下来,在进行敲代码測试的时候,关于log4cxx库的文件都找不到。我崩溃了。这和网上说的不一样啊。
遇到了一些挫折。终于我是搞出来了,就来详细说说我的步骤吧。
1.把三个压缩包放置到一个你喜欢的文件夹下。比方/home/mac/log4cxx这个文件夹下
2.在/home/mac/log4cxx文件夹下解压三个压缩包得到三个文件夹(解压缩命令tar zxvf 你的目标)
3.在/home/mac/log4cxx文件夹下新建三个文件夹apr apr-util log4cxx作为三个包的安装文件夹(运行make install时的安装文件夹)
4.首先进入apr-1.4.6文件夹运行./configure --prefix=/home/mac/log4cxx/apr配置apr包的安装文件夹为/home/mac/log4cxx/apr
5.运行make
6.运行make install
7.进入apr-util-1.4.1文件夹运行./configure --prefix=/home/mac/log4cxx/apr-util --with-apr=/home/mac/log4cxx/apr意义和上面一步一样,只是多了个依赖关系
8.运行make
9.运行make install
10.进入apache-log4cxx-0.10.0文件夹运行./configure --prefix=/home/mac/log4cxx/log4cxx --with-apr=/home/mac/log4cxx/apr --with-apr-util=/home/mac/log4cxx/apr-util意义和上面一步一样,依赖关系又体现了
11.运行make
12.运行make install
13.此时使用命令ls 浏览新建的三个目录apr apr-util log4cxx,会发现里面有一些include啊。lib啊之类的目录
14.由于測试程序要用到log4cxx的库文件,所以还须要一步。运行vi /home/mac/.bashrc 在里面加入两句
LD_LIBRARY_PATH=/home/mac/log4cxx/log4cxx/lib
export LD_LIBRARY_PATH 然后保存
15.运行source /home/mac/.bashrc使刚刚做的变动生效
16.编写一个測试程序main.cpp
#include <log4cxx/logger.h>
#include <log4cxx/logstring.h>
#include <log4cxx/propertyconfigurator.h> int main(int argc, char* argv[])
{
using namespace log4cxx; // 读取配置文件
PropertyConfigurator::configure("conf.log"); // 建立两个logger
LoggerPtr logger1 = Logger::getLogger("TraceYourMama");
LoggerPtr logger2 = Logger::getLogger("Patch"); LOG4CXX_TRACE(logger1, "跟踪");
LOG4CXX_WARN(logger1, "警告");
LOG4CXX_DEBUG(logger1, "调试");
LOG4CXX_ASSERT(logger1, false, "断言");
LOG4CXX_FATAL(logger1, "致命"); LOG4CXX_TRACE(logger2, "跟踪");
LOG4CXX_ERROR(logger2, "错误");
return 0;
}
17.编写文件conf.log这个log4cxx配置文件
log4j.rootLogger=TRACE, stdout, logfile log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d [%t] %-5p %c - %m%n log4j.appender.logfile=org.apache.log4j.RollingFileAppender
log4j.appender.logfile.File=./ZW.log
log4j.appender.logfile.MaxFileSize=100KB
log4j.appender.logfile.MaxBackupIndex=10
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=%d [%t] %-5p %c - %m%
18.运行g++ -I/home/mac/log4cxx/log4cxx/include -L/home/mac/log4cxx/log4cxx/lib -llog4cxx main.cpp
19.会生成a.out文件
20.运行./a.out 终端输出
2014-07-21 23:14:06,735 [0xb7fe4700] TRACE TraceYourMama - trace
2014-07-21 23:14:06,736 [0xb7fe4700] WARN TraceYourMama - warn
2014-07-21 23:14:06,736 [0xb7fe4700] DEBUG TraceYourMama - debug
2014-07-21 23:14:06,736 [0xb7fe4700] ERROR TraceYourMama - assert
2014-07-21 23:14:06,736 [0xb7fe4700] FATAL TraceYourMama - fatal
2014-07-21 23:14:06,736 [0xb7fe4700] TRACE Patch - trace
2014-07-21 23:14:06,736 [0xb7fe4700] ERROR Patch - error
同一时候,当前文件夹下也会有后缀名为log的文件产生
再来从头回答那两个问题
1.随你安装在哪个文件夹,是要gcc的时候指定好正确路径即可了
2.还是gcc的 -I -L -i的參数运用值得深究
好了。到眼下为止,最终让这个库起作用了。下一步就是分析怎样配置这个库。
后记:
1.为了支持中文。即能够输出中文到控制台或者文件,要在安装log4cxx时加上 --with-charset=utf-8 --with-logchar=utf-8,比如:
./configure --prefix=/home/mac/log4cxx/log4cxx --with-apr=/home/mac/log4cxx/apr --with-apr-util=/home/mac/log4cxx/apr-util--with-charset=utf-8 --with-logchar=utf-8
2.为了输出Qt的QString类型的字符串,要这样用,LOG4CXX_INFO(logger,qstring.toStdString()),用LOG4CXX_INFO(logger,qstring.toStdString().c_str())会出问题
log4cxx日志库RedHat下安装的更多相关文章
- RedHat下安装Python开发环境
Linux RedHat下安装Python2.7.pip.ipython环境.eclipse和PyDev环境 准备工作,源Python2.6备份: 根据which python具体目录而定,进行备份 ...
- 如何在redhat下安装WineQQ
使用过redhat的朋友都知道在redhat下要使用聊天工具例如:腾讯QQ只能是用网页QQ,但网页QQ始终用得不尽人意,下面我将给大家介绍一种在redhat下安装WineQQ的方法,让你能在redha ...
- 如何在redhat下安装办公软件(openoffice)
在redhat的client版本中自带有办公软件libreoffice,而在server版的redhat中却没有自带的办公软件,那么,如何在redhat的server版下安装办公软件呢? 方法一:配置 ...
- RedHat下安装OPENCV
1.解压 unzip opencv-2.4.9.zip 2.进入目录,cmake CMakeLists.txt 生成build文件 3.使用命令 make 编译 4.使用命令 make instal ...
- [学习OpenCV攻略][016][RedHat下安装OpenCV]
安装环境 操作系统: Red Hat Enterprise Linux Server 6.3 相关软件: ffmpeg-0.8.15.tar.bz2.cmake-3.5.1.tar.gz.OpenCV ...
- RedHat下安装MySQL5.5
MYSQL在windows下面安装可能一帆风顺,但是如果真的到纯图形界面的redhat服务器上,可能就不是那么容易了, 这里我就详细的介绍一下MYSQL5.5在linux下的安装以及注意的问题,避免后 ...
- RedHat下安装Ecshop
1. 设置虚拟机 2. 创建文件夹 mkdir /mnt/cdrom 3. 加载LINUX安装光盘 mount /dev/cdrom /mnt/cdrom 4. 进入安装程序目录 cd /mnt/cd ...
- RedHat下安装Telnet服务端及客户端远程连接配置
Telnet协议是TCP/IP协议族中的一员,是Internet远程登陆服务的标准协议和主要方式.它为用户提供了在本地计算机上完成远程主机工作的能力. 配置之前请确保网络连通,如防火墙影响连接,请先关 ...
- redhat下安装mysql 5.6.20,解压zip包,查看已经安装过的mysql,卸载rpm安装包,安装mysqlserver端和client,改动mysqlusername,登陆mysql,启动关闭mysql
1 将相关的mysql rpm包上传到redhat上 2 我的电脑是Redhat 6.*版本号.所以这里使用上面一个 3 解压zip包 4 安装下面几个rpm MySQL-client-a ...
随机推荐
- 1.2(java学习笔记)类与对象
对象:是指具体的事物.比如学生 张三,老师 李四,代表一个单一的个体. 比如 学生 张三,这时张三就是具体的对象. 类:将对象中共有特征抽象出,可以理解为某种特性的集合. 世界上的事物可以分解成一 ...
- int和Integer,String和String(包装类)
1.int和Integer的值如果是一样的,则是在内存中开辟相同的内存空间 2.但是String和String(包装类)是不一样的 代码演示: int a=1; Integer b = new Int ...
- 集群Cluster介绍
来源:http://www.ibm.com/developerworks/cn/linux/cluster/lw-clustering.html简单的说,集群(cluster)就是一组计算机,它们作为 ...
- 在Delphi中使用键盘勾子获取键盘输入(译--5月7日)
http://blog.sina.com.cn/s/blog_502b2e970100949s.html 获取键盘输入以控制无法接受输入焦点的控件考虑一些游戏,显示图片在TPainBox,但是TPai ...
- SVN安装中遇到的问题
新的版本:1.9.5 必须使用Apache Portable Runtime Utility 1.5.4 Released没有安装的话需要先安装 需要安装apr.apr-util sqlite zli ...
- HashMap深度解析(二)
本文来自:高爽|Coder,原文地址:http://blog.csdn.net/ghsau/article/details/16890151,转载请注明. 上一篇比较深入的分析了HashM ...
- HTMLTestRunner美化
https://www.cnblogs.com/findyou/p/6925733.html 参考这个,美化的不错,进入了汉化,及加入了一些样式,
- 'dict_values' object does not support indexing, Python字典dict中由value查key
Python字典dict中由value查key 众所周知,字典dict最大的好处就是查找或插入的速度极快,并且不想列表list一样,随着key的增加越来越复杂.但是dict需要占用较大的内存空间,换句 ...
- 安装完office2016 64位后,在安装visio时,报错,无法安装,
安装环境要求: 系统要求:win8,win10等: office要求:sw(批量版)不能和cn(零售版).365版混装.-------重点注意事项 一定要注意批量版和零售版的区别,各版本之间绝对不允许 ...
- mipmap 二
mipmap 之前讲了生成 原理 这个讲下我对性能的理解 mipmap 对性能的影响 包含两方面 minification时,采样多个textel得到1个pixel颜色,如果是mipmap形成相邻两个 ...