青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

牽著老婆滿街逛

嚴以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

開源日志系統(tǒng)log4cplus(七)

 

經(jīng)過短暫的熟悉過程,log4cplus已經(jīng)被成功應用到了我的項目中去了,效果還不錯,:)除了上文提及的
功能之外,下面將介紹log4cplus提供的線程和套接字的使用情況。

### NDC ###
首先我們先了解一下log4cplus中嵌入診斷上下文(Nested Diagnostic Context),即NDC。對log系統(tǒng)而言,
當輸入源可能不止一個,而只有一個輸出時,往往需要分辯所要輸出消息的來源,比如服務器處理來自不同
客戶端的消息時就需要作此判斷,NDC可以為交錯顯示的信息打上一個標記(stamp), 使得辨認工作看起來
比較容易些,呵呵。這個標記是線程特有的,利用了線程局部存儲機制,稱為線程私有數(shù)據(jù)(Thread-specific
 Data,或TSD)。 看了一下源代碼,相關(guān)定義如下,包括定義、初始化、獲取、設(shè)置和清除操作:
linux pthread
#   define LOG4CPLUS_THREAD_LOCAL_TYPE pthread_key_t*
#   define LOG4CPLUS_THREAD_LOCAL_INIT ::log4cplus::thread::createPthreadKey()
#   define LOG4CPLUS_GET_THREAD_LOCAL_VALUE( key ) pthread_getspecific(
*key)
#   define LOG4CPLUS_SET_THREAD_LOCAL_VALUE( key, value ) pthread_setspecific(
*key, value)
#   define LOG4CPLUS_THREAD_LOCAL_CLEANUP( key ) pthread_key_delete(
*key)

win32
#   define LOG4CPLUS_THREAD_LOCAL_TYPE DWORD
#   define LOG4CPLUS_THREAD_LOCAL_INIT TlsAlloc()
#   define LOG4CPLUS_GET_THREAD_LOCAL_VALUE( key ) TlsGetValue(key)
#   define LOG4CPLUS_SET_THREAD_LOCAL_VALUE( key, value ) \       TlsSetValue(key, static_cast(value))
#   define LOG4CPLUS_THREAD_LOCAL_CLEANUP( key ) TlsFree(key)
				
使用起來比較簡單,在某個線程中:
    NDC& ndc = log4cplus::getNDC();
    ndc.push(
"ur ndc string");
    LOG4CPLUS_DEBUG(logger, 
"this is a NDC test");
     
    ndc.pop();
        
    LOG4CPLUS_DEBUG(logger, 
"There should be no NDC");
    ndc.remove();


   
當設(shè)定輸出格式(Layout)為TTCCLayout時,輸出如下:
10-21-04 21:32:58, [3392] DEBUG test  - this is a NDC test
10-21-04 21:32:58, [3392] DEBUG test <> - There should be no NDC...
也可以在自定義的輸出格式中使用NDC(用%x) ,比如:
     
  std::
string pattern = "NDC:[%x]  - %m %n";
  std::auto_ptr _layout(
new PatternLayout(pattern));
     
 LOG4CPLUS_DEBUG(_logger, 
"This is the FIRST log message")
  NDC
& ndc = log4cplus::getNDC();
  ndc.push(
"ur ndc string"); 
  LOG4CPLUS_WARN(_logger, 
"This is the SECOND log message")
  ndc.pop();
 ndc.remove(); 
    

   
輸出如下:
NDC:[]  - This is the FIRST log message...
NDC:[ur ndc string]  - This is the SECOND log message...
				
另外一種更簡單的使用方法是在線程中直接用NDCContextCreator:
    NDCContextCreator _first_ndc("ur ndc string");
    LOG4CPLUS_DEBUG(logger, 
"this is a NDC test")

   
不必顯式地調(diào)用push/pop了,而且當出現(xiàn)異常時,能夠確保push與pop的調(diào)用是匹配的。
    
### 線程 ###
線程是log4cplus中的副產(chǎn)品, 而且僅作了最基本的實現(xiàn),使用起來也異常簡單,只要且必須要
在派生類中重載run函數(shù)即可:
class TestThread : public AbstractThread
{
public:
    
virtual void run();
}
;
                
void TestThread::run()

   
/* do sth. */ 
    
}

log4cplus的線程沒有考慮同步、死鎖,有互斥,實現(xiàn)線程切換的小函數(shù)挺別致的:
void log4cplus::thread::yield()
{
#if defined(LOG4CPLUS_USE_PTHREADS)
    ::sched_yield();
#elif defined(LOG4CPLUS_USE_WIN32_THREADS)
    ::Sleep(
0);
#endif
}
				
### 套接字 ###
套接字也是log4cplus中的副產(chǎn)品,在namespace log4cplus::helpers中,實現(xiàn)了C/S方式的日志記錄。
1. 客戶端程序需要做的工作:
/* 定義一個SocketAppender類型的掛接器 */SharedAppenderPtr _append(new SocketAppender(host, 8888"ServerName"));
/* 把_append加入到logger中 */Logger::getRoot().addAppender(_append);
/*  SocketAppender類型不需要Layout, 直接調(diào)用宏就可以將信息發(fā)往loggerServer了 */LOG4CPLUS_INFO(Logger::getRoot(), "This is a test: ")

【注】 這里對宏的調(diào)用其實是調(diào)用了SocketAppender::append,里面有一個數(shù)據(jù)傳輸約定,即先發(fā)送
一個后續(xù)數(shù)據(jù)的總長度,然后再發(fā)送實際的數(shù)據(jù):
     
    SocketBuffer buffer 
= convertToBuffer(event, serverName);
    SocketBuffer msgBuffer(LOG4CPLUS_MAX_MESSAGE_SIZE);
    msgBuffer.appendSize_t(buffer.getSize());
    msgBuffer.appendBuffer(buffer);        
				
2. 服務器端程序需要做的工作:
/* 定義一個ServerSocket */ServerSocket serverSocket(port);
 
/* 調(diào)用accept函數(shù)創(chuàng)建一個新的socket與客戶端連接 */Socket sock = serverSocket.accept();
				
此后即可用該sock進行數(shù)據(jù)read/write了,形如:
SocketBuffer msgSizeBuffer(sizeof(unsigned int));
if(!clientsock.read(msgSizeBuffer))
{
    
return;
}

unsigned 
int msgSize = msgSizeBuffer.readInt();
SocketBuffer buffer(msgSize);
if(!clientsock.read(buffer))
{
    
return;
}

為了將讀到的數(shù)據(jù)正常顯示出來,需要將SocketBuffer存放的內(nèi)容轉(zhuǎn)換成InternalLoggingEvent格式:
spi::InternalLoggingEvent event = readFromBuffer(buffer);
然后輸出:
Logger logger = Logger::getInstance(event.getLoggerName());
logger.callAppenders(
event);
				
【注】 read/write是按照阻塞方式實現(xiàn)的,意味著對其調(diào)用直到滿足了所接收或發(fā)送的個數(shù)才返回。

posted on 2006-08-26 04:51 楊粼波 閱讀(5438) 評論(3)  編輯 收藏 引用 所屬分類: Windows編程Linux編程

評論

# re: 開源日志系統(tǒng)log4cplus(七)[未登錄] 2008-04-18 12:17 cppexplore

精彩!多多發(fā)點這種造福大眾的文章啊!  回復  更多評論   

# re: 開源日志系統(tǒng)log4cplus(七) 2008-07-23 14:54 齊全愛

很好,多謝!!!支持你!!!  回復  更多評論   

# re: 開源日志系統(tǒng)log4cplus(七) 2010-05-13 17:22 yacper

perfect  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一本久久青青| 亚洲影院在线观看| 亚洲小视频在线| 99精品热视频只有精品10| 六月丁香综合| 91久久精品国产| 亚洲美女网站| 欧美性jizz18性欧美| 亚洲国产婷婷| 国产精品毛片a∨一区二区三区| 一区二区久久久久久| 欧美在线影院在线视频| 一区免费在线| 欧美片在线播放| 香蕉久久夜色| 亚洲精品国产欧美| 久久精品二区亚洲w码| 亚洲国产视频一区二区| 午夜精品久久久久久久| 国产一区二区三区奇米久涩| 欧美一区二区三区视频在线| 国产一区二区无遮挡| 毛片一区二区三区| 99国产精品久久久久久久成人热| 91久久精品国产91性色| 亚洲国产欧美日韩精品| 亚洲国产日韩美| 亚洲美女av在线播放| 亚洲免费观看视频| 亚洲免费激情| 欧美一区二区三区在线视频| 久久人人爽国产| 亚洲第一搞黄网站| 宅男噜噜噜66国产日韩在线观看| 亚洲图片在线| 久久深夜福利| 欧美日韩理论| 一区二区视频在线观看| 99在线|亚洲一区二区| 久久精品主播| 99热在线精品观看| 久久亚洲一区二区三区四区| 欧美视频免费在线| 国产精品私拍pans大尺度在线| 欧美高清视频www夜色资源网| 亚洲国产三级| 欧美一区二区三区在线播放| 欧美国产日韩一区二区三区| 国产欧美一区二区精品忘忧草| 亚洲精品在线观看视频| 午夜在线一区二区| 国语自产精品视频在线看一大j8| 久久久一区二区三区| 久久久一区二区三区| 亚洲天堂成人| 99ri日韩精品视频| 欧美第一黄色网| 久久蜜桃精品| 欧美日韩网址| 久久xxxx| 一区二区日本视频| 日韩网站在线看片你懂的| 欧美黄色一区二区| 久久手机精品视频| 欧美大片一区二区| 欧美国产精品va在线观看| 久久久精彩视频| 久久久久久久久蜜桃| 久久久天天操| 欧美一区二区三区四区在线| 国产一区二区三区在线观看视频| 欧美日韩在线播放| 一本一道久久综合狠狠老精东影业 | 免费成人性网站| 欧美专区亚洲专区| 欧美国产日韩一区二区| 亚洲欧美国产毛片在线| 国产一区二区三区成人欧美日韩在线观看| 亚洲三级视频| 亚洲午夜精品久久久久久浪潮 | 国产午夜亚洲精品理论片色戒| 亚洲欧美国产va在线影院| 久久精品一区蜜桃臀影院 | 性欧美videos另类喷潮| 久久日韩精品| 亚洲人成人一区二区在线观看| 欧美精品亚洲一区二区在线播放| av不卡在线| 浪潮色综合久久天堂| 日韩一本二本av| 欧美日韩精品在线视频| 香蕉乱码成人久久天堂爱免费| 欧美成人综合网站| 亚洲欧美一级二级三级| 亚洲电影自拍| 国产精品视频大全| 欧美国产另类| 欧美在线观看日本一区| 亚洲乱码国产乱码精品精可以看| 欧美专区中文字幕| 99精品国产一区二区青青牛奶| 国产精品影音先锋| 欧美激情精品久久久久久蜜臀| 亚洲欧美日韩另类| 亚洲黄色av一区| 欧美性生交xxxxx久久久| 乱码第一页成人| 亚洲国产成人精品视频| 久久av一区二区三区| 在线亚洲一区观看| 136国产福利精品导航| 国产精品久久久久免费a∨| 免费观看日韩av| 欧美在线|欧美| 这里只有精品电影| 亚洲欧洲一区二区在线观看| 快射av在线播放一区| 久久国产综合精品| 亚洲综合激情| 这里是久久伊人| 亚洲欧洲另类| 1024成人网色www| 好吊成人免视频| 国产日韩专区| 国产精品久在线观看| 欧美日韩综合精品| 欧美日韩大陆在线| 欧美激情一区二区三区在线| 久久综合色影院| 久久成人18免费观看| 午夜精品久久久久久99热| 亚洲新中文字幕| 亚洲国产日韩在线一区模特| 在线成人中文字幕| 精东粉嫩av免费一区二区三区| 国产精品三级久久久久久电影| 国产精品成人aaaaa网站| 欧美日韩亚洲成人| 欧美日韩亚洲一区三区| 欧美先锋影音| 国产精品色婷婷| 国产视频精品免费播放| 国产一区二区三区自拍| 经典三级久久| 亚洲黄色免费| 一本久道久久综合婷婷鲸鱼| 中文在线资源观看网站视频免费不卡| 日韩视频一区二区| 宅男噜噜噜66一区二区| 亚洲欧美日韩在线综合| 欧美在线资源| 久久亚洲精品视频| 欧美成人中文字幕在线| 亚洲国内精品| 亚洲视频1区2区| 性伦欧美刺激片在线观看| 久久精品国产96久久久香蕉| 久久在线精品| 欧美日韩国产综合久久| 国产精品久久久久影院色老大| 国产精品永久免费| 怡红院精品视频| 日韩视频在线观看免费| 亚洲尤物在线视频观看| 久久久精品国产免费观看同学| 蜜臀av国产精品久久久久| 亚洲激情偷拍| 亚洲免费一在线| 久热成人在线视频| 欧美视频中文在线看 | 欧美激情一区二区三区高清视频| 亚洲国产欧美国产综合一区| 亚洲视频999| 免费成人激情视频| 91久久久在线| 亚洲综合欧美日韩| 久久青青草原一区二区| 欧美精品一区在线播放| 国产精品自拍网站| 亚洲黄网站黄| 午夜久久tv| 欧美国产日韩一二三区| 亚洲第一在线综合在线| 亚洲色图自拍| 麻豆精品在线播放| 国产精品老女人精品视频| 亚洲精品在线三区| 亚洲激情成人在线| 亚洲色图综合久久| 狼人社综合社区| 国产精品久久久久99| 影院欧美亚洲| 亚洲综合成人在线| 欧美国产精品久久| 午夜精品偷拍| 欧美日本乱大交xxxxx| 精品二区视频| 校园激情久久| 亚洲精品中文在线| 蜜桃av一区|