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

牽著老婆滿街逛

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

開源日志系統log4cplus(七)

 

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

### NDC ###
首先我們先了解一下log4cplus中嵌入診斷上下文(Nested Diagnostic Context),即NDC。對log系統而言,
當輸入源可能不止一個,而只有一個輸出時,往往需要分辯所要輸出消息的來源,比如服務器處理來自不同
客戶端的消息時就需要作此判斷,NDC可以為交錯顯示的信息打上一個標記(stamp), 使得辨認工作看起來
比較容易些,呵呵。這個標記是線程特有的,利用了線程局部存儲機制,稱為線程私有數據(Thread-specific
 Data,或TSD)。 看了一下源代碼,相關定義如下,包括定義、初始化、獲取、設置和清除操作:
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();


   
當設定輸出格式(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")

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

   
/* do sth. */ 
    
}

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

【注】 這里對宏的調用其實是調用了SocketAppender::append,里面有一個數據傳輸約定,即先發送
一個后續數據的總長度,然后再發送實際的數據:
     
    SocketBuffer buffer 
= convertToBuffer(event, serverName);
    SocketBuffer msgBuffer(LOG4CPLUS_MAX_MESSAGE_SIZE);
    msgBuffer.appendSize_t(buffer.getSize());
    msgBuffer.appendBuffer(buffer);        
				
2. 服務器端程序需要做的工作:
/* 定義一個ServerSocket */ServerSocket serverSocket(port);
 
/* 調用accept函數創建一個新的socket與客戶端連接 */Socket sock = serverSocket.accept();
				
此后即可用該sock進行數據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;
}

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

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

評論

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

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

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

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

# re: 開源日志系統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>
            欧美综合国产| 免费在线看一区| 久久综合婷婷| 欧美亚洲综合在线| 欧美一级网站| 久久精品中文字幕免费mv| 欧美亚洲一区二区在线| 久久精品亚洲精品| 欧美一区免费| 女同性一区二区三区人了人一| 免费h精品视频在线播放| 老司机一区二区三区| 亚洲毛片av在线| 亚洲自拍偷拍网址| 久久日韩粉嫩一区二区三区| 久久精品亚洲精品| 欧美日韩三级| 永久免费毛片在线播放不卡| 一本久道久久综合中文字幕| 欧美在线一二三四区| 欧美激情第10页| 欧美一区深夜视频| 国产精品久久久999| 在线电影国产精品| 久久www免费人成看片高清| 亚洲欧洲日本在线| 久久精品主播| 激情视频亚洲| 欧美一区二区国产| 夜夜爽99久久国产综合精品女不卡 | 91久久精品国产91性色| 99v久久综合狠狠综合久久| 亚洲综合导航| 欧美日韩免费网站| 中国女人久久久| 亚洲精品自在久久| 欧美精品一区二区三区蜜桃| 好男人免费精品视频| 欧美一级理论性理论a| 亚洲女优在线| 国产欧美一区二区白浆黑人| 欧美一区二区成人| 久久久久九九视频| 亚洲丰满少妇videoshd| 欧美国产精品劲爆| 欧美日本韩国| 欧美一区三区三区高中清蜜桃 | 在线观看日韩专区| 欧美成人黄色小视频| 欧美精品1区| 先锋影音久久久| 欧美电影免费网站| 一区二区三区国产精华| 亚洲欧洲99久久| 亚洲国产精品尤物yw在线观看| 亚洲大胆av| 国产一区亚洲| 亚洲性线免费观看视频成熟| 国产欧美精品一区二区色综合| 久久综合精品一区| 国产精品成人一区二区三区吃奶| 久久精品观看| 国产精品国内视频| 91久久精品一区| 亚洲精品三级| 亚洲深夜激情| 91久久黄色| 久久se精品一区精品二区| 亚洲主播在线播放| 欧美另类69精品久久久久9999| 狼狼综合久久久久综合网| 国产女主播一区二区| 亚洲一区自拍| 久久精品综合网| 国产亚洲精品久久久久动| 亚洲欧美在线观看| 免费在线看成人av| 亚洲高清不卡在线观看| 麻豆freexxxx性91精品| 欧美大尺度在线| 日韩一级网站| 国产精品视频yy9299一区| 亚洲一区欧美激情| 久久成人免费视频| 亚洲国产三级网| 国产精品久久久久婷婷| 亚洲一区二区三区国产| 久久久久久久综合色一本| 在线日韩视频| 国产精品伦理| 欧美福利小视频| 欧美一级黄色录像| 亚洲美女av在线播放| 久久久亚洲一区| 亚洲永久免费av| 亚洲激情综合| 国产女主播一区二区三区| 久久阴道视频| 欧美中文字幕精品| 亚洲一区二区在线免费观看| 亚洲国产99精品国自产| 亚洲免费在线视频一区 二区| 国产女主播在线一区二区| 中文一区字幕| 欧美成人亚洲成人日韩成人| 亚洲视频1区2区| 亚洲精选在线| 伊人婷婷欧美激情| 国产日韩欧美一区二区三区在线观看| 久久久久久网站| 久久精品青青大伊人av| 欧美一级片久久久久久久| av成人国产| 中国成人亚色综合网站| 国产精品99久久久久久有的能看| 亚洲激情综合| 亚洲国产一区二区三区在线播| 理论片一区二区在线| 久久夜色精品国产欧美乱极品| 欧美呦呦网站| 理论片一区二区在线| 欧美国产第一页| av成人免费| 久久久久久久久久久一区 | 亚洲精品影院| 在线亚洲一区二区| 久久国产精品久久国产精品| 久久精品中文字幕一区| 欧美高清在线一区二区| 国产精品久久久久久久久婷婷| 欧美香蕉大胸在线视频观看| 国产精品私人影院| 亚洲韩日在线| 久久黄色级2电影| 亚洲美女色禁图| 亚洲欧美在线看| 欧美精品亚洲二区| 亚洲午夜av在线| 欧美一区二区三区啪啪| 欧美~级网站不卡| 一本色道久久综合亚洲精品不卡 | 久久久亚洲一区| 国产精品看片资源| 亚洲综合欧美| 亚洲精品国产欧美| 久久国产福利| 国内久久视频| 欧美在线不卡| 亚洲视频你懂的| 国产精品视频xxx| 午夜国产精品视频| 亚洲精品日韩综合观看成人91| 久久一二三国产| 亚洲国产日韩一区| 亚洲激情视频网| 欧美午夜精品久久久久免费视| 亚洲激情另类| 亚洲精品一区在线| 欧美人在线观看| 欧美一区二区视频免费观看| 亚洲欧美激情四射在线日| 国产精品视频不卡| 久久免费国产精品| 免费在线亚洲| 亚洲制服av| 久久久天天操| 亚洲欧美日韩另类| 欧美一区国产二区| 亚洲伦理精品| 欧美在线影院| 宅男在线国产精品| 久久er99精品| 亚洲五月六月| 欧美 日韩 国产一区二区在线视频| 亚洲人成免费| 久久精品视频亚洲| 亚洲影院在线| 欧美日韩国内| 欧美风情在线| 久久久久久夜| 久久久久久国产精品mv| 一级成人国产| 六十路精品视频| 久久亚洲精品伦理| 欧美三级黄美女| 91久久精品美女高潮| 韩国成人福利片在线播放| 亚洲一区二区网站| 一个色综合av| 欧美日韩国产bt| 亚洲电影在线| 亚洲乱码国产乱码精品精可以看 | 久久久噜噜噜久久人人看| 欧美国产日韩一区二区三区| 久久深夜福利| 亚洲激情在线观看| 欧美视频不卡中文| 亚洲自拍偷拍视频| 久久久国产成人精品| 激情久久影院|