python logger 服务器_一个简单的python日志服务器

#-*- coding: utf-8 -*-

'''Created on 2012-06-14 19:50

@summary: a simple logging server. use gevent and logging modules

@author: JerryKwan'''

importosimportpickleimportloggingimportlogging.handlersimportstructfrom gevent.server importStreamServer#logger collection

_loggers_ ={}defget_logger(address, name):

address= address.replace(".", "_")

logger_name= address + "_" +nameif_loggers_.has_key(logger_name):return_loggers_[logger_name]else:print os.path.dirname(__file__)

logs_dir= os.path.join(os.path.dirname(__file__), "logs", address)if os.path.exists(logs_dir) andos.path.isdir(logs_dir):pass

else:

os.makedirs(logs_dir)

file_name= os.path.join(logs_dir, name+".log")#print file_name

#define a rotating file handler

rotatingFileHandler = logging.handlers.RotatingFileHandler(filename =file_name,

maxBytes= 1024 * 1024 * 50,

backupCount= 5)

formatter= logging.Formatter("%(message)s")

rotatingFileHandler.setFormatter(formatter)

console=logging.StreamHandler()#console.setLevel(logging.NOTSET)

#set a format which is simple for console use

formatter = logging.Formatter("%(message)s")#tell the handler to use this format

console.setFormatter(formatter)

logger=logging.getLogger(logger_name)

logger.addHandler(rotatingFileHandler)

logger.addHandler(console)

logger.setLevel(logging.DEBUG)

_loggers_[logger_name]=loggerreturnloggerdefhandle_log_record(address, record):'''@summary: handle log record

@param address: address[ip] of the record generated from

@param record: log record'''

#construct logger name

process_name =record.processName

process_id=record.process#print "process_name = %s, process_id = %s"%(process_name, process_id)

logger_name = "%s_%s" %(process_name, process_id)

logger=get_logger(address, logger_name)

formatter=logging.Formatter(

fmt="%(asctime)s %(name)-12s %(levelname)-8s %(message)s")

record_str=formatter.format(record)#print record_str

logger.info(record_str)#print "write"

#print address, record

#print record.filename

defhandle(socket, address):#get client ip

try:whileTrue:

chunk= socket.recv(4)if len(chunk) < 4:breakslen= struct.unpack(">L", chunk)[0]

chunk=socket.recv(slen)while len(chunk)

chunk+= socket.recv(slen -len(chunk))

obj=pickle.loads(chunk)

record=logging.makeLogRecord(obj)#handle_log_record(address[0], record)exceptException, e:pass

finally:

socket.close()#chunk = socket.recv(1024)

#print "handle invoked"

#socket.close()

if __name__ == '__main__':

port= 8888server= StreamServer(('0.0.0.0', port), handle)print ('Starting logging service on port %s'%port)

server.serve_forever()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值