python 异步写日志_Python如何异步发送日志到远程服务器?

现在我们考虑一个问题,当日志发送到远程服务器过程中,如果远程服务器处理的很慢,会耗费一定的时间, 那么这时记录日志就会都变慢修改服务器日志处理类,让其停顿5秒钟,模拟长时间的处理流程

async def post(self):

print(self.getParam('log'))

await asyncio.sleep(5)

self.write({"msg": 'ok'})

此时我们再打印上面的日志

logger.debug("今天天气不错")

logger.debug("是风和日丽的")

得到的输出为

[2020-09-23 11:47:33] [DEBUG] 今天天气不错

[2020-09-23 11:47:38] [DEBUG] 是风和日丽的

我们注意到,它们的时间间隔也是5秒。

那么现在问题来了,原本只是一个记录日志,现在却成了拖累整个脚本的累赘,所以我们需要异步的来 处理远程写日志。

1

使用多线程处理

首先想的是应该是用多线程来执行发送日志方法

def emit(self, record):

msg = self.format(record)

if self.method == "GET":

if (self.url.find("?") >= 0):

sep = '&'

else:

sep = '?'

url = self.url + "%c%s" % (sep, urllib.parse.urlencode({"log": msg}))

t = threading.Thread(target=requests.get, args=(url,))

t.start()

else:

headers = {

"Content-type": "application/x-www-form-urlencoded",

"Content-length": str(len(msg))

}

t = threading.Thread(target=requests.post, args=(self.url,), kwargs=

{"data":{'log': msg},

这种方法是可以达到不阻塞主目的,但是每打印一条日志就需要开启一个线程,也是挺浪费资源的。

我们也 可以使用线程池来处理

2

使用线程池处理

python 的 concurrent.futures 中有ThreadPoolExecutor, ProcessPoolExecutor类,是线程池和进程池, 就是在初始化的时候先定义几个线程,之后让这些线程来处理相应的函数,这样不用每次都需要新创建线程

线程池的基本使用

exector = ThreadPoolExecutor(max_workers=1) # 初始化一个线程池,只有一个线程

exector.submit(fn, args, kwargs) # 将函数submit到线程池中

如果线程池中有n个线程,当提交的task数量大于n

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: CMDB平台是一种用于IT资产管理的工具,可以帮助企业管理和跟踪IT设备、软件和服务的信息。下面是一些步骤和建议,可以帮助您使用Python一个简单的CMDB平台: 1. 确定需要跟踪的信息:在开始编代码之前,您需要确定要在CMDB中跟踪哪些信息。例如,您可能需要跟踪服务器的型号、IP地址、操作系统、软件版本等。 2. 设计数据库模型:在确定要跟踪的信息后,您需要设计一个数据库模型来存储这些信息。您可以使用Python中的SQLAlchemy或Django ORM来帮助您设计和管理数据库。 3. 编代码:一旦您设计好数据库模型,就可以开始编代码来创建、读取、更新和删除数据库中的记录。您可以使用Python的Flask或Django框架来构建一个Web应用程序,用户可以使用它来管理CMDB中的数据。 4. 部署应用程序:完成编和测试后,您需要将应用程序部署到服务器上,以便用户可以访问它。 5. 维护和升级:一旦应用程序部署成功,您需要定期维护和升级它,以确保它始终保持最新状态并且不断改进。 请注意,以上步骤仅为指导,实际编一个CMDB平台需要更多的细节和努力。 ### 回答2: CMDB(配置管理数据库)是一种用于管理和追踪计算机系统和网络资源的工具,Python是一种高级编程语言,非常适合用于快速开发应用程序。下面是使用Python一个CMDB平台的一般步骤和思路: 1. 数据库设计:首先需要设计与CMDB相关的数据库结构。可以使用Python的SQLAlchemy等ORM框架来创建数据库表,定义表的字段、关联关系等。 2. 用户认证与权限管理:通过添加用户注册、登录等功能进行用户认证,并设计权限管理模块,控制用户在CMDB平台上的操作权限。 3. 资产管理:设计资产管理功能,包括对设备、服务器、网络设备等进行添加、修改、删除、查询等操作。可以使用Python的Flask等Web框架来构建资产管理的API接口,同时也可以开发web页面来展示和操作资产信息。 4. 资源关系管理:设计与资产相关的关系管理功能,如资产与资产之间、资产与用户之间的关联关系。这可以通过定义数据库的外键关联或者创建额外的关系表来实现。 5. 日志记录与审计:为了保证系统的安全性和可追溯性,需要设计日志记录与审计功能。可以使用Python日志库来记录用户的操作行为,并定期对日志进行审计。 6. 自动发现与监控:可以使用Python的第三方库来实现自动发现网络设备、监控服务器运行状态等功能。例如,可以使用Paramiko库来连接和执行远程命令,或使用SNMP库来获取网络设备信息等。 7. 报表与统计:设计统计图表和报表展示资产数据,以帮助用户更好地了解和分析资产状况。可以使用Python的数据可视化库(如Matplotlib、Plotly等)来生成图表,并结合模板引擎(如Jinja2)来生成报表页面。 总的来说,Python作为一种灵活且易于使用的编程语言,可以有效地支持开发一个功能完善的CMDB平台。同时,Python社区中丰富的第三方库和框架也为开发者提供了许多便捷的功能和工具,使开发工作更加高效。 ### 回答3: CMDB(配置管理数据库)是用于管理和跟踪IT基础设施配置信息的平台。Python是一种高级编程语言,具有简单易学、代码规范和丰富的开源库等特点,非常适合用于快速开发CMDB平台。 首先,我们可以使用Python的web框架(如Django或Flask)来构建CMDB平台的后端。通过定义模型类来表示不同的资源类型,例如服务器、网络设备、数据库等。每个资源类型都有相应的属性,如IP地址、操作系统、厂商等。可以通过使用数据库(如MySQL或MongoDB)来存储和管理这些数据。 其次,通过编相应的视图函数和路由来处理与前端页面之间的交互。Python的模板引擎可以用来构建动态的网页,方便展示和操作资源数据。通过使用表单来收集用户输入,并运用表单验证机制来确保输入的安全性和有效性。 此外,为了提供友好的用户界面,可以使用Python的数据可视化库(如matplotlib或plotly)来生成图表和可视化报告,以便用户更直观地查看和分析数据。 另外,在CMDB平台中,可能需要进行一些自动化的操作,如自动发现和扫描网络设备。Python的网络编程库(如Paramiko和NAPALM)可以帮助我们与网络设备进行交互,执行命令并获取配置信息。 最后,为了增加系统的可扩展性和灵活性,可以使用Python的消息队列(如RabbitMQ或Kafka)来实现异步任务处理。例如,当用户提交一个资源修改请求时,可以将该请求放入消息队列中进行处理,以提高系统的性能和并发性。 总结起来,利用Python的强大功能和广泛的库,我们可以使用该语言来开发一个功能齐全的CMDB平台。Python的易学性和丰富的生态系统,使得开发者可以更加高效地构建和维护这样一个系统。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值