欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python?實現(xiàn)syslog?服務(wù)器的詳細過程

 更新時間:2022年08月18日 15:45:24   作者:thinklog2018  
這篇文章主要介紹了python?實現(xiàn)syslog服務(wù)器的詳細過程,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

交換機等網(wǎng)絡(luò)設(shè)備基本上都支持將本地日志通過syslog 協(xié)議傳輸?shù)胶蠖朔?wù)器上集中查看和存儲,畢竟這類設(shè)備的存儲容量也有限。操作系統(tǒng)也是支持syslog協(xié)議的。從網(wǎng)上看日志集中管理很多都偏向了ELK解決方案,也看了下ELK,總感覺太重了,部署和維護都較為復(fù)雜。所以就想使用python 的socket實現(xiàn)一個syslog服務(wù)器,將接收到的日志按照IP和時間存儲成文件,方便查閱。后續(xù)可以通過python web框架,將接收到的信息通過web界面展現(xiàn)出來,并能夠?qū)邮招畔⑦M行過濾,發(fā)現(xiàn)異常信息后及時進行告警處理。

1. 首先實現(xiàn)一個syslog 日志服務(wù)器,使用python 簡直簡單的不能再簡單。

import socket
from datetime import date
udp = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
udp.bind(('0.0.0.0',514))
 
while True:
    rec_msg, addr = udp.recvfrom(2048)
    client_ip, client_port =addr
    msg =  client_ip + " " + rec_msg.rstrip(b'\x00').decode('utf-8','ignore')
 
    print('msg from client:', msg)    
    filename = client_ip   + '_' +  str(date.today())  + ".log"
    with open(filename,'a+',encoding = "utf-8") as f:
        f.write( msg + "\n") 

2. 先編寫一個發(fā)送syslog的客戶端程序,測試服務(wù)器端是否正常運行。

import socket
from datetime import datetime
udp = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
print(socket.AF_INET, socket.SOCK_DGRAM)
now = str(datetime.today())[:19]
ack_msg= now + ' hello,udp client '  
addr = ('192.168.8.95',514) 
udp.sendto(ack_msg.encode('utf8'),addr)

3. 在交換機上配置將日志發(fā)送到syslog 服務(wù)器。

infor-center localhost 192.168.2.1

這時發(fā)現(xiàn)syslog服務(wù)器是可以接收到消息的,但在vscode中點擊文件時,提示

使用vscode的內(nèi)置編輯器強行打開后,發(fā)現(xiàn)每行記錄后面都帶有一個null字樣的。

讓程序輸出接收到的upd消息,發(fā)現(xiàn)rec_msg是一個bytes類型,且最后帶有\(zhòng)x00的字樣。

<class 'bytes'> b'<134>Aug 17 10:25:57 2022 ACCSW-2.11 %%10SHELL/6/SHELL_CMD: -Line=vty5-IPAddr=192.168.8.68-User=thomas; Command is dis cur\x00'

所以在前面的程序中,將\x00從右側(cè)去除,保存的文本就正常了。

4. 配置linux服務(wù)器發(fā)送syslog日志到服務(wù)器

linux 的大部分發(fā)行版內(nèi)置了rsyslog服務(wù),修改/etc/rsyslog.conf文件,將

module(load="imudp") # needs to be done just once
input(type="imudp" port="514")

這兩行的注釋去掉,讓其啟用。

然后在末尾添加

*.emerg,*.alert,*.crit,*.err,*.warning,*.notice,*.info,*.debug @192.168.2.1

然后重啟rsyslog 服務(wù)。systemctl restart rsyslog

5. 這時在服務(wù)器上就可以看到日志了。

到此這篇關(guān)于python實現(xiàn)syslog服務(wù)器的文章就介紹到這了,更多相關(guān)pythonsyslog服務(wù)器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • ubuntu安裝mysql pycharm sublime

    ubuntu安裝mysql pycharm sublime

    本文給大家匯總介紹了在Ubuntu中如何安裝mysql+pycharm+sublime的方法,有相同需求的小伙伴可以參考下
    2018-02-02
  • python+requests+pytest接口自動化的實現(xiàn)示例

    python+requests+pytest接口自動化的實現(xiàn)示例

    這篇文章主要介紹了python+requests+pytest接口自動化的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Yolov5更換BiFPN的詳細步驟總結(jié)

    Yolov5更換BiFPN的詳細步驟總結(jié)

    將YOLOv5中的PANet層修改為EfficientDet-BiFPN,實現(xiàn)自上而下與自下而上的深淺層特征雙向融合,明顯提升YOLOv5算法檢測精度,下面這篇文章主要給大家介紹了關(guān)于Yolov5更換BiFPN的詳細步驟,需要的朋友可以參考下
    2022-12-12
  • python通過smpt發(fā)送郵件的方法

    python通過smpt發(fā)送郵件的方法

    這篇文章主要介紹了python通過smpt發(fā)送郵件的方法,涉及Python實現(xiàn)發(fā)送郵件的相關(guān)技巧,非常簡單實用,需要的朋友可以參考下
    2015-04-04
  • 使用pandas兩列轉(zhuǎn)換成字典的健和值

    使用pandas兩列轉(zhuǎn)換成字典的健和值

    這篇文章主要介紹了使用pandas兩列轉(zhuǎn)換成字典的健和值方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Python中的異常類型及處理方式示例詳解

    Python中的異常類型及處理方式示例詳解

    今天我們主要來了解一下 Python 中的異常類型以及它們的處理方式。說到異常處理,我們首先要知道什么是異常。其實,異常就是一類事件,當它們發(fā)生時,會影響到程序的正常執(zhí)行,具體內(nèi)容跟隨小編一起看看吧
    2021-08-08
  • Python中的sys.stdout.write實現(xiàn)打印刷新功能

    Python中的sys.stdout.write實現(xiàn)打印刷新功能

    今天小編就為大家分享一篇Python中的sys.stdout.write實現(xiàn)打印刷新功能,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • python?包之?Pillow?圖像處理教程分享

    python?包之?Pillow?圖像處理教程分享

    這篇文章主要介紹了python?包之?Pillow?圖像處理教程分享,文章基于Python的相關(guān)資料展開主題相關(guān)內(nèi)容,需要的小伙伴可以參考一下
    2022-04-04
  • 使用Python進行二進制文件讀寫的簡單方法(推薦)

    使用Python進行二進制文件讀寫的簡單方法(推薦)

    下面小編就為大家?guī)硪黄褂肞ython進行二進制文件讀寫的簡單方法(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09
  • 正確理解python迭代器與生成器

    正確理解python迭代器與生成器

    在Python這門語言中,生成器毫無疑問是最有用的特性之一。與此同時,也是使用的最不廣泛的Python特性之一。究其原因,主要是因為,在其他主流語言里面沒有生成器的概念。本文將詳細介紹python迭代器與生成器
    2021-06-06

最新評論