Flask应用中如何实现多线程及线程隔离机制?
- 内容介绍
- 文章标签
- 相关推荐
本文共计450个文字,预计阅读时间需要2分钟。
一、进程:线程与进程的关系
进程:CPU调度的基本单位
是进程的一部分,可访问进程的资源,包括:
- 线程间的切换- 资源消耗相对较少
进程:系统内存资源分配的基本单位
进程的切换需要保存应用状态
一、线程、进程
- 线程:cpu调度的基本单位。是进程的一部分,能够访问进程的资源,线程间的切换,资源消耗相对少。
- 进程:系统内存资源分配的基本单位。进程的切换需要保存应用的执行状态(应用的上下文),相对于线程,进程切换的开销大。
二、Flask开启多线程、多进程
- flask自带的服务器默认是单进程、单线程;
- 多线程:app.run(...., threader=True)
- 多进程:app.run(...., processes=1)
三、Flask多线程
- 单线程:request---->请求1 Request,请求2Request,....。请求顺序执行,request总是指向当前请求。
- 多线程:request---->{请求1 Request,请求2 Request,....}。多线程的情况下,在某一时间多个请求会同时存在,此时不清楚request指向哪个请求,带来的问题是造成数据的污染。
本文共计450个文字,预计阅读时间需要2分钟。
一、进程:线程与进程的关系
进程:CPU调度的基本单位
是进程的一部分,可访问进程的资源,包括:
- 线程间的切换- 资源消耗相对较少
进程:系统内存资源分配的基本单位
进程的切换需要保存应用状态
一、线程、进程
- 线程:cpu调度的基本单位。是进程的一部分,能够访问进程的资源,线程间的切换,资源消耗相对少。
- 进程:系统内存资源分配的基本单位。进程的切换需要保存应用的执行状态(应用的上下文),相对于线程,进程切换的开销大。
二、Flask开启多线程、多进程
- flask自带的服务器默认是单进程、单线程;
- 多线程:app.run(...., threader=True)
- 多进程:app.run(...., processes=1)
三、Flask多线程
- 单线程:request---->请求1 Request,请求2Request,....。请求顺序执行,request总是指向当前请求。
- 多线程:request---->{请求1 Request,请求2 Request,....}。多线程的情况下,在某一时间多个请求会同时存在,此时不清楚request指向哪个请求,带来的问题是造成数据的污染。

