• <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>
            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            統計

            • 隨筆 - 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 泡泡牛 閱讀(1006) 評論(0)  編輯 收藏 引用 所屬分類: Develop

            久久精品国产只有精品66| 久久久久国产精品嫩草影院| 91亚洲国产成人久久精品| 97久久超碰成人精品网站| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 无码AV波多野结衣久久| 99久久精品国产麻豆| 久久亚洲AV无码精品色午夜| 老司机国内精品久久久久| 欧美大香线蕉线伊人久久| 亚洲精品无码久久久| 久久福利青草精品资源站免费| 思思久久99热只有频精品66| 欧美日韩成人精品久久久免费看| 1000部精品久久久久久久久| 精品国产乱码久久久久久人妻| 久久久久久国产a免费观看黄色大片| 色综合久久天天综合| 久久天天躁狠狠躁夜夜av浪潮| 97r久久精品国产99国产精| 国产精品久久久久无码av| 久久99热精品| 久久人人爽人人人人爽AV| 亚洲AV无码久久精品狠狠爱浪潮| 婷婷五月深深久久精品| 欧美激情精品久久久久| 久久久久九国产精品| 欧美午夜A∨大片久久| 一级a性色生活片久久无| 亚洲综合日韩久久成人AV| 97久久超碰国产精品旧版| 日韩亚洲国产综合久久久| 91视频国产91久久久| 四虎久久影院| 欧美久久综合九色综合| 久久国产精品久久久| 99久久免费国产精精品| 亚洲午夜久久久久久久久久| 开心久久婷婷综合中文字幕| 久久婷婷人人澡人人| 久久成人18免费网站|