網(wǎng)站首頁 編程語言 正文
交換機等網(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ù)器上就可以看到日志了。
原文鏈接:https://blog.csdn.net/thinklog2018/article/details/126378424
相關(guān)推薦
- 2022-05-10 C++構(gòu)造函數(shù)+復(fù)制構(gòu)造函數(shù)+重載等號運算符調(diào)用_C 語言
- 2022-08-14 Redis+Caffeine兩級緩存的實現(xiàn)_Redis
- 2022-07-11 UVM中超時退出set_timeout函數(shù)
- 2022-05-25 Properties與ResourceBundle的基本使用以及區(qū)別
- 2023-06-18 C#?Marshal類基本概念和入門實例講解_C#教程
- 2022-11-19 React組件的應(yīng)用介紹_React
- 2022-09-12 詳解APScheduler如何設(shè)置任務(wù)不并發(fā)_python
- 2022-09-10 Python數(shù)據(jù)結(jié)構(gòu)樹與算法分析_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支