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權限,我頓時打了個寒戰,萬一我安裝錯了,服務器暴了怎麼辦)

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())會出問題

發佈了87 篇原創文章 · 獲贊 21 · 訪問量 16萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章