python3使用socket模块实现简易syslog服务器

废话不多说直接上代码:

import socket
import time


def socket_bind(server_socket, host, port=514, max_retries=5):
    retries = 0
    while retries < max_retries:
        try:
            server_socket.bind((host, port))
            print(f"syslog服务器已启动,监听端口{port}")
            break  # 如果绑定成功,跳出循环
        except OSError:
            port = input(f"当前端口 {port} 可能被占用,请重新输入一个端口(500-65500):")
            while True:
                if not port.isdigit():
                    port = input("输入无效,不是一个有效的整数,请重新输入:")
                    continue
                port = int(port)
                if not 500 <= port <= 65500:
                    port = input("输入无效,数字不在范围内,请重新输入:")
                    continue
                break
            retries += 1
    else:
        print("绑定端口失败,即将退出...")
        time.sleep(3)
        exit()


def udp_server(host, port):
    # 创建UDP套接字
    with socket.socket(socket.AF_INET, socket.SOCK_DGRAM) as server_socket:
        # 将套接字绑定到指定的地址和端口
        socket_bind(server_socket, host, port)
        with open("syslog.log", mode="w", encoding="utf-8") as s:
            while True:
                # 接收数据
                data, client_address = server_socket.recvfrom(10000)
                print(f"接收到来自 {client_address} 的日志: {data.decode('utf-8')}", flush=True)
                s.write(f"接收到来自 {client_address} 的日志: {data.decode('utf-8')}")
                s.flush()


if __name__ == "__main__":
    # 设置服务器的主机和端口
    server_host = "0.0.0.0"  # 监听所有网络接口
    server_port = 514

    # 启动UDP服务器
    udp_server(server_host, server_port)

  • 11
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值