flask多线程,线程池,序列化和反序列化

多线程与多进程

默认的情况下,flask自带的web服务器是以单进程单线程来响应我们的客户端请求。大家很容易想到,10个请求进来是没有办法同时执行的,已给请求执行完之后才能执行另一个请求。

flask自带多线程和多进程,但是有个缺点是无法实现异步。

ps:
1.多进程或多线程只能选择一个,不能同时开启
2.windows环境不支持多进程,只能在linux上使用。
若在windows环境开启多进程,即设置processes 大于1,即报错。
# 1.threaded : 多线程支持,默认为False,即不开启多线程;
app.run(threaded=True)
# 2.processes:进程数量,默认为1.
app.run(processes=True)

线程池

概念:
线程池就是首先创建一些线程,它们的集合称为线程池。使用线程池可以很好地提高性能。
线程池在系统启动时即创建大量空闲的线程,程序将一个任务传给线程池,线程池就会启动一条线程来执行这个任务,执行结束以后,该线程并不会死亡,而是再次返回线程池中成为空闲状态,等待执行下一个任务。

python中的线程池:
从 Python3.2 开始,标准库为我们提供了 concurrent.futures 模块,它提供了 ThreadPoolExecutor 和 ProcessPoolExecutor两个类,实现了对 threading 和 multiprocessing 的进一步抽象,不仅可以自动调度线程,还可以做到:

1.主线程可以获取某一个线程(或者任务的)的状态,以及返回值。
2.当一个线程完成的时候,主线程能够立即知道。
3.让多线程和多进程的编码接口一致。

下面展示线程池的 例子

1.task=executor.submit() #提交任务到线程池中
2.task.done() #判断任务是否完成
3.task.cancel() #取消任务,已在线程池运行的无法取消
4.task.result() #获得执行结果
from concurrent.futures import ThreadPoolExecutor
executor = ThreadPoolExecutor(4)

task=executor.submit(get_return,re_url,result)#子线程
return json.dumps()#主线程

def get_return(re_url,result):
	requests.post(re_url, json=result)

JSON序列化和反序列化

序列化: json的dumps方法可以把dict类型转化成str的类型。
反序列化:json的loads方法可以把str类型转化成dic的类型。
下面展示 例子

在调用接口传输json时,如果不进行序列化和反序列化,接收方可能会无法准确收到数据。
result = {"res":res,"res2":res2}
json_data = json.dumps(result)
new_data = json.loads(json_data)
requests.post(url=re_url, json=new_data)
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
序列化反序列化是用于在不同系统或者不同语言之间传输对象或者保存对象状态的过程。序列化将对象转换为字节流的形式,以便于传输或者保存到文件中。而反序列化则是将字节流重新转换为对象的过程。 序列化反序列化的应用场景有很多,以下是一些常见的应用场景: 1. 网络传输:当我们需要在网络上传输对象时,可以将对象进行序列化,然后通过网络传输字节流,接收方再进行反序列化恢复成对象。这在分布式系统、远程调用等场景中非常常见。 2. 持久化存储:将对象序列化后保存到文件或者数据库中,以便于下次读取和使用。这在缓存、日志记录、数据备份等场景中经常使用。 3. 分布式缓存:将对象序列化后存储到分布式缓存中,以提高系统性能和可扩展性。这在大规模分布式系统中非常常见。 4. 消息队列:将对象序列化后发送到消息队列中,以实现异步通信和解耦。这在微服务架构、事件驱动架构等场景中广泛应用。 5. 对象复制:通过序列化反序列化可以实现对象的深拷贝,即创建一个与原对象完全相同的新对象。这在多线程环境下保证对象的线程安全性非常重要。 实现序列化反序列化的方式有多种,其中最常见的是使用Java的Serializable接口。通过实现Serializable接口,可以告诉Java虚拟机该类是可序列化的,并且可以使用Java的序列化机制进行序列化反序列化操作。此外,还可以使用其他序列化框架如JSON、XML等进行序列化反序列化。 #### 引用[.reference_title] - *1* *2* [什么是序列化?反序列化? 场景使用? 怎么实现???](https://blog.csdn.net/qq_43705131/article/details/107064184)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Java对象的序列化(Serialization)和反序列化详解](https://blog.csdn.net/yaomingyang/article/details/79321939)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

江小皮不皮

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值