91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在Python中使用syslog日志

發布時間:2021-03-20 17:01:10 來源:億速云 閱讀:406 作者:Leah 欄目:開發技術

這篇文章將為大家詳細講解有關如何在Python中使用syslog日志,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

該模塊的主要方式為:

#!/usr/bin/python
# -*- coding: utf-8 -*-
import syslog
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

如何在Python中使用syslog日志

源碼為:

#!/usr/bin/python
# -*- coding: utf-8 -*-
import syslog
import os

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_LOCAL0 to LOG_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 = "test start14"

  # syslog.openlog([ident[, logoption[, facility]]])
  syslog.openlog(filename, pid, filepath)
  # syslog.syslog(priority, message)
  syslog.syslog(level, messages)
  # close syslog
  syslog.closelog()
  
  # vim var/log/message
  # tail -f /tmp/syslog.txt

在不同機器上面查看結果:

如何在Python中使用syslog日志

如何在Python中使用syslog日志

將其寫成了類

#!/usr/bin/python
# -*- coding: utf-8 -*-
import syslog


class mysyslog(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_LOCAL0 to LOG_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
  def basicConfig(name, logoption):
    facility = syslog.LOG_USER
    syslog.openlog(name, logoption, facility)

  @staticmethod
  def tosyslog(level, ip, messages):
    newmessages = "[" + ip + "]" + " " + messages
    syslog.syslog(level, newmessages)

關于如何在Python中使用syslog日志就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

永仁县| 阿坝| 元阳县| 太和县| 南丰县| 江西省| 融水| 华蓥市| 鹤壁市| 安徽省| 秦皇岛市| 太仆寺旗| 康马县| 鄱阳县| 德兴市| 台南市| 普格县| 水富县| 海原县| 新竹县| 永昌县| 乌兰察布市| 文水县| 绥棱县| 大兴区| 平定县| 福泉市| 营山县| 增城市| 峡江县| 长子县| 澄迈县| 桓台县| 山东| 綦江县| 民县| 贡嘎县| 平湖市| 大荔县| 嫩江县| 广丰县|