前言:

这两天搜文章的时候,发现不少人对tornado有些误解的。只是想说说自己对于这些框架的理解,和实际项目中的对比。

部分有文章说tornado性能很一般,我当时一瞅,很是郁闷,这些人是怎么测试的呢,就直接跑hello world。很直接就用tornado最最基本的功能,那他的性能也就和django flask一样了。这样没太多的意义,个人觉得,应该尽量施展他们的长处,当然也要把他的短处给扔出来。

我想说的是,在一定程度上,你没有用好。tornado最大的优点是大并发下的异步io,他有coroutine,这是个比thread线程切换开销更小的东西,可以让tornado那些回调的代码显得更同步顺眼。还有一个异步回调的东东,这些组成了tornado在高并发下也可以避免网络io堵塞。

在用django、flask的时候,我也喜欢用gevent、Gunicorn、uwsgi。 现在更多的人喜欢用uwsgi,因为简单易用,借助于nginx可以做更多的东西。比如加上lua,就可以做数据接口,用location就可以做读写分离等。但是大家有没有发现,uwsgi在超过一定的连接数后,尤其是那种长连接,他就疯狂的报错,要不是socket pipe出错,要不就索性的502。

线程开启64个,我这里是特意开了64了,官方的推荐是你cpu核数的2-4倍,那是我觉得这个值不靠谱,还是往大了加。ab一个time.sleep(10)的接口,超过150个,就可以挑错。不信的朋友可以自己做做测试。

原文:http://rfyiamcool.blog.51cto.com/1030776/1397495

而tornado就非常适合做这些个高并发,尤其是io堵塞,comet的东西了

新版支持future做并发库,这里完全就可以写同步的代码了。50个线程数,不够那就加到200,200不够加到500、1000。  我加到1000,每个连接耗时间30秒,照样很稳,不会报错。

class IndexHandler(tornado.web.RequestHandler):executor = ThreadPoolExecutor(50)                               @tornado.gen.coroutinedef get(self):print "begin"#time.sleep(10)yield self.pin()self.write('ok')self.finish()@run_on_executordef pin(self):
#        os.system("ping -c 10 www.baidu.com")time.sleep(2)

当然他的缺点也很明显,就是需要你打造轮子。他的文档也特别的少,你会发现跑到官网做demo,他们连个cookie说的都不清不白的,结果还要到github去找几个例子,才搞懂。

django是个好东西呀,你能想到的功能,都可以在django插件index看到你需要的。  各种各样的都有, 做大项目还是需要用django这样较完成的框架。  你要是有知乎那帮团队的实力,你也可以用tornado来支撑你的大项目。  我不喜欢django的原因,只是因为他复杂,不简单而已。

推荐用tornado做接口,而django flask做前后端的开发。 tornado性能虽然高,但是部署有点繁琐( ningx + tornado * 4 的方式),写程序有点蛋疼,需要写异步回调。不像flask那样,你全部同步的写法,最后用nginx uwsgi一引入,就可以多进程了。

他的配置如此的简单。。。

http://xiaorui.cc
[uwsgi]
socket = 127.0.0.1:9090
master = true         //主进程
vhost = true          //多站模式
no-stie = true        //多站模式时不设置入口模块和文件
workers = 64           //子进程数
reload-mercy = 10
vacuum = true         //退出、重启时清理文件
max-requests = 30000
limit-as = 2048
buffer-sizi = 30000
pidfile = /var/run/uwsgi9000.pid
daemonize = /website/uwsgi9000.log
避免文件最大打开数限制
ulimit -SHn 30000

不管是tornaod、django、web.py、flask,他们静态处理能力都一般。最简单的方法测试,你用ab压一个静态文件,流量压根上不去,其次是出broken pipe的标准socket的error。 你正好开了10个uwsgi的worker后。你的页面有好几个css,js,那! 如果有10个人来访问,那就占用了uwsgi的10个线程。如果这个时候有很多用户来访问,你肯定会io堵塞的,你可以试试 !

在一些平台中,要避免静态文件的损耗,这些静态的文件最好是用url的方式引入,这样后期可以做cdn啥的,把这些静态的东西尽量扔给gninx lighttpd处理,如果程序已经成型了,那就用nginx的localtion来做静态文件的分离引入。

django在nginx uwsgi和tornado异步方案在项目中的体验相关推荐

  1. Django 部署(Nginx+uwsgi)

    使用 uwsgi 来部署 安装 uwsgi sudo pip install uwsgi --upgrade 使用 uwsgi 运行项目 uwsgi --http :8001 --chdir /pat ...

  2. mysql 常用优化方案_项目中常用的 19 条 MySQL 优化方案

    声明一下:下面的优化方案都是基于 " Mysql-索引-BTree类型 " 的 一.EXPLAIN 做MySQL优化,我们要善用 EXPLAIN 查看SQL执行计划. 下面来个简单 ...

  3. nginx+uWSGI+django+virtualenv+supervisor发布web服务器

    导论 WSGI是Web服务器网关接口.它是一个规范,描述了Web服务器如何与Web应用程序通信,以及Web应用程序如何链接在一起以处理一个请求,(接收请求,处理请求,响应请求) 基于wsgi运行的框架 ...

  4. 微信抢票环境配置——nginx + uwsgi + django配置服务器

    微信抢票环境配置--nginx + uwsgi + django配置服务器 1 uwsgi配置 2 http协议(80端口)下的nginx配置 1 uwsgi配置 安装uwsgi pip3 insta ...

  5. 腾讯云CentOS7.2+Django2.2+Python3.7+Nginx+Uwsgi 初学者部署教程

    腾讯云CentOS+Django+Python+Nginx+Uwsgi 部署(自用,简单记录) 说明:本人是做前端研发的,最近研究了后台Django框架,并部署到服务的整个流程,为了避免以后忘记,写一 ...

  6. python django + uwsgi+Nginx宝塔centos7的部署方案

    python django的centos7部署 第一步:准备环境 1.准备centos7服务器 服务器可自行购买 2.安装宝塔Linux面板 Centos安装命令: yum install -y wg ...

  7. 【转】Nginx+uWSGI 部署 Django 应用

    原文来自: http://www.oschina.net/question/54100_30386 http://obmem.info/?p=703 常见的django webapp 部署方式采用FC ...

  8. Django + Nginx + Uwsgi + Celery + Rabbitmq 做一个高速响的应网站架构

    Django :渲染页面,站点访问控制,管理网站,网站框架 Nginx:ip访问管理,数据传输控制 Uwsgi:处理链接Diango和Nginx的传输协议,也可以看作是处理客户端数据和Django之间 ...

  9. Nginx uWsgi Django环境搭建

    2019独角兽企业重金招聘Python工程师标准>>> 由于一个监控项目(使用django开发)交接到所在项目组,需要了解python的web开发和环境搭建. 这里记录环境的搭建流程 ...

最新文章

  1. java开放源码_开放源码的第一周:我是如何参与的,以及我学到的东西
  2. 百度盯上媒体生意?百度CTO王海峰详解智能媒体中台
  3. html里面执行js跳转页面,JS函数执行和指定跳转其他页面
  4. Java中Object.equals与String.equals的区别
  5. hdu 3449(依赖背包)
  6. views display a summary count number
  7. 许昌:让便捷支付成为智慧城市新名片
  8. FileSystemMap:与文件系统交互的自然方法
  9. 让模块支持“导入”“导出”功能
  10. 技术演讲的技巧和经验
  11. PJblog跨站漏洞利用及修补
  12. 5.七个重点网络协议
  13. 网络蜘蛛及搜索引擎基本原理
  14. java反射机制面试详解
  15. 视觉SLAM十四讲 第9讲 卡尔曼滤波
  16. 扇贝计算机英语单词,扇贝英语单词
  17. vbs编程中 on error resume next的意思
  18. vue实现网络监控摄像头直播拍照功能
  19. 百度地图开发:H5获取GPS-wg84经纬度与百度定位API的偏差测试
  20. JAVA——eclipes的下载步骤

热门文章

  1. CSS3 Media Queries在iPhone4和iPad上的运用
  2. AFNetWorking网络请求
  3. HDU- 最大报销额
  4. 程序员买房与程序员转型
  5. 什么是“GB/T ”? 计算机术语你又知道多少? 想不想别人听不懂的语言搞定别人!...
  6. 只有汇编能告诉你为什么
  7. MFC改变对话框背景图片实例
  8. 关于winodows下编程c++遇到的引用文件路径问题
  9. IOS开发基础之团购案例17-xib和UITableView两种方式实现
  10. c++输入了后边不继续_医疗:连涨多日,后边还能加仓吗?直接说答案!