4-Tornado高并发原理

核心原理就是协程+epoll事件循环,再使用协程之后,开销是特别的小,那具体如何提供高并发的呢?

异步非阻塞IO

python 复制代码
 这意味我们整套开发的模式不在与原来一样,正因为不再一样,所以有时我们在理解代码时就有可能会比较困难。
 之前我们是报耗时的操作交给了系统去调度,也就降低了我们的使用难度,因为如果让我们程序去调度是比较困难的。
 但协程系统是控制不了,所以说就需要程序员来做,一般是由框架完成,就比如说asyncio。
 所以说我需要了解的他的原理。不然出了问题,不好调整

基于epoll事件循环

python 复制代码
底层是基于事件循环的,从线程到协程到高并发,实际是功能上就是个事件循环。
即使是nginx实现并发也是使用的epoll(Linux)的事件循环,所以推荐使用时,使用linux系统,那样才能充分体现性能。

协程提高了代码的可读性

python 复制代码
对于实现协程的肯定一步步从无到有的,慢慢技术的迭代。之前写协程还要写回调,调试还是比叫恶心的。
后来慢慢改善成写成类似同步的代码那样实现异步。但即使这样它的还是提高了难度

Tornado提供的不只是web框架

python 复制代码
异步编码的一整套方案,包含了框架与,也提供了事件循环的功能,也就是服务器功能,在部署时也可以直接部署。

使用了Tornado不一定就是高并发

python 复制代码
如果在代码中使用了同步的IO后,效果也是比较低,甚至会比Flask与Django还要低。

所以在使用Tornado时,我们需要了解什么是事件循环什么是协程。

事件循环的模式是单线程完成的,那就意外着,有一个地方使用了同步IO操作,那整个所有消息都会被堵塞住。

Tornado中尽量不要使用的同步IO

python 复制代码
根据什么之前说的,我们再使用Tornado时,尽量不要使用同步IO,这也就是有的小伙伴在测试Tornado时发现效率没有Flask、Django高的主要原因。
甚至有的小伙伴都不清楚什么样的操作是异步的,什么样的操作是同步的。所以以后我们在使用时,要多加注意

Tronado只需要把耗时的操作放到线程池中就可以达到高并发??

python 复制代码
这个也是不对的。在实际写代码时,遇到耗时比较多,也或者使用别人的库耗时比较多。
他们放到线程池中能否提高效率取决于是否是异步的。如果不是异步只能考虑换库,或者自己写一个。
相关推荐
danplus8 分钟前
node发送邮件:如何实现Node.js发信功能?
服务器·node.js·外贸开发信·邮件群发·蜂邮edm邮件营销·邮件接口·营销邮件
BeyondESH21 分钟前
Linux线程同步—竞态条件和互斥锁(C语言)
linux·服务器·c++
wn53123 分钟前
【Go - 类型断言】
服务器·开发语言·后端·golang
hanniuniu1324 分钟前
详细解读,F5服务器负载均衡的技术优势
运维·服务器·负载均衡
Narutolxy33 分钟前
Python 单元测试:深入理解与实战应用20240919
python·单元测试·log4j
Amo Xiang1 小时前
2024 Python3.10 系统入门+进阶(十五):文件及目录操作
开发语言·python
PatrickYao04221 小时前
记一次安装discuz时遇到的错误
服务器
liangbm31 小时前
数学建模笔记——动态规划
笔记·python·算法·数学建模·动态规划·背包问题·优化问题
B站计算机毕业设计超人1 小时前
计算机毕业设计Python+Flask微博情感分析 微博舆情预测 微博爬虫 微博大数据 舆情分析系统 大数据毕业设计 NLP文本分类 机器学习 深度学习 AI
爬虫·python·深度学习·算法·机器学习·自然语言处理·数据可视化
羊小猪~~1 小时前
深度学习基础案例5--VGG16人脸识别(体验学习的痛苦与乐趣)
人工智能·python·深度学习·学习·算法·机器学习·cnn