python 实现syslog 服务器的详细过程

 更新时间:2022年08月18日 15:45:24   作者:thinklog2018  
这篇文章主要介绍了python 实现syslog服务器的详细过程,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

交换机等网络设备基本上都支持将本地日志通过syslog 协议传输到后端服务器上集中查看和存储,毕竟这类设备的存储容量也有限。操作系统也是支持syslog协议的。从网上看日志集中管理很多都偏向了ELK解决方案,也看了下ELK,总感觉太重了,部署和维护都较为复杂。所以就想使用python 的socket实现一个syslog服务器,将接收到的日志按照IP和时间存储成文件,方便查阅。后续可以通过python web框架,将接收到的信息通过web界面展现出来,并能够对接收信息进行过滤,发现异常信息后及时进行告警处理。

1. 首先实现一个syslog 日志服务器,使用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. 先编写一个发送syslog的客户端程序,测试服务器端是否正常运行。

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. 在交换机上配置将日志发送到syslog 服务器。

infor-center localhost 192.168.2.1

这时发现syslog服务器是可以接收到消息的,但在vscode中点击文件时,提示

使用vscode的内置编辑器强行打开后,发现每行记录后面都带有一个null字样的。

让程序输出接收到的upd消息,发现rec_msg是一个bytes类型,且最后带有\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从右侧去除,保存的文本就正常了。

4. 配置linux服务器发送syslog日志到服务器

linux 的大部分发行版内置了rsyslog服务,修改/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 服务。systemctl restart rsyslog

5. 这时在服务器上就可以看到日志了。

到此这篇关于python实现syslog服务器的文章就介绍到这了,更多相关pythonsyslog服务器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • ubuntu安装mysql pycharm sublime

    ubuntu安装mysql pycharm sublime

    本文给大家汇总介绍了在Ubuntu中如何安装mysql+pycharm+sublime的方法,有相同需求的小伙伴可以参考下
    2018-02-02
  • python+requests+pytest接口自动化的实现示例

    python+requests+pytest接口自动化的实现示例

    这篇文章主要介绍了python+requests+pytest接口自动化的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • Yolov5更换BiFPN的详细步骤总结

    Yolov5更换BiFPN的详细步骤总结

    将YOLOv5中的PANet层修改为EfficientDet-BiFPN,实现自上而下与自下而上的深浅层特征双向融合,明显提升YOLOv5算法检测精度,下面这篇文章主要给大家介绍了关于Yolov5更换BiFPN的详细步骤,需要的朋友可以参考下
    2022-12-12
  • python通过smpt发送邮件的方法

    python通过smpt发送邮件的方法

    这篇文章主要介绍了python通过smpt发送邮件的方法,涉及Python实现发送邮件的相关技巧,非常简单实用,需要的朋友可以参考下
    2015-04-04
  • 使用pandas两列转换成字典的健和值

    使用pandas两列转换成字典的健和值

    这篇文章主要介绍了使用pandas两列转换成字典的健和值方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05
  • Python中的异常类型及处理方式示例详解

    Python中的异常类型及处理方式示例详解

    今天我们主要来了解一下 Python 中的异常类型以及它们的处理方式。说到异常处理,我们首先要知道什么是异常。其实,异常就是一类事件,当它们发生时,会影响到程序的正常执行,具体内容跟随小编一起看看吧
    2021-08-08
  • Python中的sys.stdout.write实现打印刷新功能

    Python中的sys.stdout.write实现打印刷新功能

    今天小编就为大家分享一篇Python中的sys.stdout.write实现打印刷新功能,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-02-02
  • python 包之 Pillow 图像处理教程分享

    python 包之 Pillow 图像处理教程分享

    这篇文章主要介绍了python 包之 Pillow 图像处理教程分享,文章基于Python的相关资料展开主题相关内容,需要的小伙伴可以参考一下
    2022-04-04
  • 使用Python进行二进制文件读写的简单方法(推荐)

    使用Python进行二进制文件读写的简单方法(推荐)

    下面小编就为大家带来一篇使用Python进行二进制文件读写的简单方法(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • 正确理解python迭代器与生成器

    正确理解python迭代器与生成器

    在Python这门语言中,生成器毫无疑问是最有用的特性之一。与此同时,也是使用的最不广泛的Python特性之一。究其原因,主要是因为,在其他主流语言里面没有生成器的概念。本文将详细介绍python迭代器与生成器
    2021-06-06

最新评论