• <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>
            <2008年12月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            統計

            • 隨筆 - 44
            • 文章 - 0
            • 評論 - 86
            • 引用 - 0

            常用鏈接

            留言簿(6)

            隨筆分類(31)

            隨筆檔案(44)

            Mining

            最新隨筆

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            Pythong logging 到 Logging4cplus 的適配器

            Python 的logging 模塊的Socket 和 Logging4cplus 的 socket 的格式是不一樣的, 現實中需要將日志發送到logging4cplus 的服務器, 不得已, 寫了個 Python logging 模塊到 logging4cplus的Adapter

             1 #!/usr/bin/env python
             2 #-*- coding: gbk -*-
             3 from struct import pack, unpack 
             4 
             5 class BufferPack(object):    
             6     def __init__(self):
             7         self.buffer = ''
             8         
             9     def addChar(self, s, unsigned=False):
            10         self.buffer += pack(unsigned and '>b' or '>c', s )
            11 
            12     def addShort(self, s, unsigned=False):
            13         self.buffer += pack(unsigned and '>H' or '>h', s )
            14     
            15     def addInt(self, s, unsigned=False):
            16         self.buffer += pack(unsigned and '>I' or '>i', s )
            17     
            18     def addLong(self, s, unsigned=False):
            19         self.buffer += pack(unsigned and '>L' or '>l', s )
            20     
            21     def addString(self, s):
            22         self.addInt( len(s) ) 
            23         self.buffer += s 
            24     
            25     def addBuffer(self, s):
            26         self.buffer += s.buffer 
            27 
            28 class BufferUnpack(object):
            29     
            30     char_bits     = len( pack('>b', 0) ) 
            31     short_bits     = len( pack('>H', 0) ) 
            32     int_bits    = len( pack('>I', 0) ) 
            33     long_bits     = len( pack('>L', 0) )    
            34     
            35     def __init__(self, buffer):
            36         self.buffer = buffer 
            37         self.pos = 0
            38     
            39     def _read_item(self, unpackstr, len):
            40         v = unpack(unpackstr, self.buffer[self.pos:self.pos+len] )
            41         self.pos += len 
            42         return v 
            43     
            44     def readChar(self, unsigned=False):
            45         return self._read_item(unsigned and '<b' or '<c', self.char_bits)
            46     
            47     def readShort(self, unsigned=False):    
            48         return self._read_item(unsigned and '<H' or '<h', self.short_bits )
            49         
            50     def readInt(self, unsigned=False):
            51         return self._read_item(unsigned and '<I' or '<i', self.int_bits )
            52     
            53     def readLong(self, unsigned=False):
            54         return self._read_item(unsigned and '<L' or '<l', self.long_bits )
            55     
            56     def readString(self):
            57         len = self.readInt()
            58         v = self.buffer[self.pos:self.pos+len] 
            59         self.pos += len
            60         return v 
            61 
            62 def PackMessage( record ):
            63     bp = BufferPack()
            64     bp.addChar(2, True) 
            65     bp.addChar(1, True) 
            66     
            67     bp.addString("{log.servername}"
            68     bp.addString(record.name) 
            69     bp.addInt(record.levelno*1000
            70     bp.addString("")
            71     bp.addString(record.msg)
            72     bp.addString(str(record.threadName))
            73     bp.addString(str(record.process))
            74     bp.addInt( record.created ) 
            75     bp.addInt( record.msecs ) 
            76     bp.addString(record.filename)
            77     bp.addInt( 1 )     
            78     
            79     pkg = BufferPack()
            80     pkg.addInt(len(bp.buffer), True) 
            81     pkg.addBuffer( bp ) 
            82     
            83     return pkg.buffer
            84 
            85 if __name__=="__main__":
            86     import logging, logging.handlers 
            87     
            88     logger = logging.getLogger()
            89     logging.handlers.SocketHandler.makePickle = lambda self,rc : PackMessage(rc) 
            90     
            91     hdlr = logging.handlers.SocketHandler('{logserver.ip}'8888
            92     formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
            93     hdlr.setFormatter(formatter)
            94     logger.addHandler(hdlr)
            95     logger.setLevel(logging.NOTSET)
            96     
            97     logger.info("hello")

            使用的時候.
            1. 在logging 創建SocketHandler 的時候, 需要修改logging.handlers.SocketHandler.makePickle 為方法 PackMessage
            logging.handlers.SocketHandler.makePickle = lambda self,rc : PackMessage(rc)

            2. 需要修改代碼中的兩部分內容 {log.servername} 和 {logserver.ip}

            posted on 2008-12-19 18:13 泡泡牛 閱讀(998) 評論(0)  編輯 收藏 引用 所屬分類: Develop

            区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 国内精品久久久久久野外| 国产精品久久久久影院色 | 久久久久亚洲AV成人网人人网站| 国产精品一区二区久久精品无码 | 无码人妻久久一区二区三区免费 | 久久久久久国产精品无码超碰| 99久久国产综合精品五月天喷水 | 久久夜色精品国产噜噜麻豆 | 久久精品中文騷妇女内射| 国产精品成人无码久久久久久 | 久久久久久久人妻无码中文字幕爆 | 久久亚洲高清观看| 久久精品成人欧美大片| 欧美激情精品久久久久久| 国产亚洲精品自在久久| 一本色道久久88—综合亚洲精品| 亚洲欧美精品伊人久久| 国产午夜免费高清久久影院| 欧美精品九九99久久在观看| 狠狠人妻久久久久久综合| 色综合色天天久久婷婷基地| 久久精品中文騷妇女内射| 久久人人爽人人爽人人片AV麻烦| 久久五月精品中文字幕| 超级碰久久免费公开视频| 久久精品国产99国产精品澳门| 乱亲女H秽乱长久久久| 亚洲综合伊人久久综合| 97精品依人久久久大香线蕉97| 婷婷久久精品国产| 久久亚洲国产成人影院| 久久精品国产亚洲AV影院| 久久久久久曰本AV免费免费| 久久综合亚洲鲁鲁五月天| 亚洲色婷婷综合久久| 久久婷婷五月综合色奶水99啪| 一级a性色生活片久久无| 国产精品99久久久精品无码| 99久久免费国产精品特黄| 伊人久久大香线蕉综合Av|