Python日志syslog使用原理详解
这篇文章主要介绍了Python日志syslog使用原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
syslog的官方说明在:
https://docs.python.org/2/library/syslog.html#module-syslog
该模块的主要方式为:
#!/usr/bin/python #-*-coding:utf-8-*- importsyslog syslog.openlog([ident[,logoption[,facility]]]) syslog.syslog(priority,message) syslog.closelog()
ident的信息为/bluedon/test.py
logoption的信息为[4642]
facility的信息为记录日志文件的位置,本文选取的facility=syslog.LOG_USER,即日志输出在/var/log/messages
源码为:
#!/usr/bin/python #-*-coding:utf-8-*- importsyslog importos if__name__=='__main__': #https://docs.python.org/2/library/syslog.html #syslog.openlog([ident[,logoption[,facility]]]) #ident filename=os.path.abspath(__file__) #logoption #LOG_CONS:如果将信息发送给守护进程时发生错误,直接将相关信息输入到相关信息输出到终端。 #LOG_NDELAY:立即打开与系统日志的连接(通常情况下,只有在产生第一条日志信息的情况下才会打开与日志系统的连接) #LOG_NOWAIT:在记录日志信息时,不等待可能的子进程的创建 #LOG_ODELAY:类似于LOG_NDELAY参数,与系统日志的连接只有在syslog函数调用时才会创建 #LOG_PID:每条日志信息中都包括进程号 #LOG_PID,LOG_CONS,LOG_NDELAY,LOG_NOWAIT,LOG_PERROR pid=syslog.LOG_PID #facility #LOG_KERN,LOG_USER,LOG_MAIL,LOG_DAEMON,LOG_AUTH,LOG_LPR,LOG_NEWS,LOG_UUCP,LOG_CRON,LOG_SYSLOG,LOG_LOCAL0toLOG_LOCAL7 filepath=syslog.LOG_USER #Priority #LOG_EMERG,LOG_ALERT,LOG_CRIT,LOG_ERR,LOG_WARNING,LOG_NOTICE,LOG_INFO,LOG_DEBUG level=syslog.LOG_NOTICE #messages messages="teststart14" #syslog.openlog([ident[,logoption[,facility]]]) syslog.openlog(filename,pid,filepath) #syslog.syslog(priority,message) syslog.syslog(level,messages) #closesyslog syslog.closelog() #vimvar/log/message #tail-f/tmp/syslog.txt
在不同机器上面查看结果:
将其写成了类
#!/usr/bin/python #-*-coding:utf-8-*- importsyslog classmysyslog(object): #level #LOG_EMERG,LOG_ALERT,LOG_CRIT,LOG_ERR,LOG_WARNING,LOG_NOTICE,LOG_INFO,LOG_DEBUG debug=syslog.LOG_DEBUG info=syslog.LOG_INFO notice=syslog.LOG_NOTICE warning=syslog.LOG_WARNING err=syslog.LOG_ERR crit=syslog.LOG_CRIT alert=syslog.LOG_ALERT emerg=syslog.LOG_EMERG #logoption #LOG_PID,LOG_CONS,LOG_NDELAY,LOG_NOWAIT,LOG_PERROR #LOG_CONS:如果将信息发送给守护进程时发生错误,直接将相关信息输入到相关信息输出到终端。 #LOG_NDELAY:立即打开与系统日志的连接(通常情况下,只有在产生第一条日志信息的情况下才会打开与日志系统的连接) #LOG_NOWAIT:在记录日志信息时,不等待可能的子进程的创建 #LOG_ODELAY:类似于LOG_NDELAY参数,与系统日志的连接只有在syslog函数调用时才会创建 #LOG_PID:每条日志信息中都包括进程号 cons=syslog.LOG_CONS ndelay=syslog.LOG_NDELAY nowait=syslog.LOG_NOWAIT pid=syslog.LOG_PID #facility #LOG_KERN,LOG_USER,LOG_MAIL,LOG_DAEMON,LOG_AUTH,LOG_LPR,LOG_NEWS,LOG_UUCP,LOG_CRON,LOG_SYSLOG,LOG_LOCAL0toLOG_LOCAL7 #kern=syslog.LOG_KERN #user=syslog.LOG_USER #mail=syslog.LOG_MAIL #daemon=syslog.LOG_DAEMON #auth=syslog.LOG_AUTH #lpr=syslog.LOG_LPR #news=syslog.LOG_NEWS #uucp=syslog.LOG_UUCP #cron=syslog.LOG_CRON #_syslog=syslog.LOG_SYSLOG @classmethod def__init__(self): pass @staticmethod defbasicConfig(name,logoption): facility=syslog.LOG_USER syslog.openlog(name,logoption,facility) @staticmethod deftosyslog(level,ip,messages): newmessages="["+ip+"]"+""+messages syslog.syslog(level,newmessages)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。