原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://rfyiamcool.blog.51cto.com/1030776/1397495

前言:

这两天搜文章的时候,发现不少人对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秒,照样很稳,不会报错。

1
2
3
4
5
6
7
8
9
10
11
12
13
class IndexHandler(tornado.web.RequestHandler):
    executor = ThreadPoolExecutor(50)                               
    @tornado.gen.coroutine
    def get(self):
        print "begin"
        #time.sleep(10)
        yield self.pin()
        self.write('ok')
        self.finish()
    @run_on_executor
    def 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一引入,就可以多进程了。

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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. centos6.5+Django+mysql+nginx+uwsgi

    centos6.5+Django+mysql+nginx+uwsgi 1.nginx的安装.这里采用nginx-1.6.0, 建立一个shell脚本然后执行. #!/bin/bash nginx_ve ...

  2. centos7下部署Django(nginx+uwsgi+python3+django)

    系统版本 centos7 python版本 使用官方python3.6.3正式版 django版本 使用本文发布时最新的1.11.7 uwsgi版本 使用本文发布时最新的2.0.15 nginx版本 ...

  3. SLAM+语音机器人DIY系列:(八)高阶拓展——2.centos7下部署Django(nginx+uwsgi+django+python3)

    0.安装步骤预览(1)系统默认自带python2.x,所以需要先安装python3.x(2)python2对应pip,python3对应pip3,用源码安装python3后pip3也自动安装了(3)用 ...

  4. C#~异步编程在项目中的使用

    一些闲话 对异步编程没有了解的同学可以看我的这篇文章<C#~异步编程>,今天主要说一下,在项目中怎么就用到了异步编程!在进行WEB开发时,异步这块我们用的并不多,但当你的项目做到一定规模时 ...

  5. nginx的rewrite ,如何在flask项目中获取重写前的url

    1. 在flask配一个重写到哪的路由,假设是/rewite/,然后到nginx的配置文件写重写规则,我这里重写全部的请求,接着测试能否重写成功 1. 添加一个路由 配置重写规则 测试成功 2.接下来 ...

  6. Django 部署(Nginx+uwsgi)

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

  7. CentOS下 Django部署 nginx+uWSGI+Django(二)

    该篇内容承接CentOS下 Django部署 uWSGI+Django(一),细节流程可参考此篇内容. 1. 当前系统 CentOS Linux release 7.6.1810 Python 2.7 ...

  8. 学习VirtualEnv和Nginx+uwsgi用于django项目部署

    以下叙述中用到的操作系统:Linux CentOS 6.X. 最近几天了解一下VirtualEnv,Apache+Daemon mode,Nginx+uwsgi的概念,并且在项目中实验性部署了一下(目 ...

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

    nginx+uWSGI+django+virtualenv+supervisor发布web服务器   导论 WSGI是Web服务器网关接口.它是一个规范,描述了Web服务器如何与Web应用程序通信,以 ...

随机推荐

  1. 移动Web轮播图IOS卡顿的问题

    晚饭前,被测试吐槽说,banner轮播手动左右滑的时候会卡顿.我一看不科学啊,大水果手机怎么会卡顿.我一看测试手中拿的是iPod,我觉得大概是这小玩意性能不强悍,后来又拿来5S,依然会卡顿,有趣的是, ...

  2. 7款个性化jQuery/HTML5地图插件

    现在我们经常会用到一些地图应用,无论是在网页上还是手机App中,地图貌似是一个不可或缺的应用.本文将带领大家一起来看看一些基于jQuery和HTML5的个性化地图插件,有几款地图比较实用,有些则是具有 ...

  3. Error: An App ID with identifier "*****" is not avaliable. Please enter a different string.

    Error: An App ID with identifier "*****" is not avaliable. Please enter a different string ...

  4. UIScrollView,UIPageControl

    #import <UIKit/UIKit.h> @interface ViewController : UIViewController<UIScrollViewDelegate&g ...

  5. 解析php mysql 事务处理回滚操作(附实例)

    其实用PHP来处理mysql的事务回滚并不难,下面小编就详细的为大家介绍一下.相信大家看完之后都知道如何使用 很多新手在进行项目过程中,会碰到这样一种情况,如:论坛扣币项目中,用户支付论坛币的时候如果 ...

  6. (转)汉字转拼音HanziToPinyin

    本文转载于:http://blog.csdn.net/zhangphil/article/details/47164665 Android系统本身自带有有将汉字转化为英文拼音的类和方法.具体的类就是H ...

  7. sqlserver中distinct的用法(不重复的记录)

    下面先来看看例子: table表 字段1     字段2   id        name   1           a   2           b   3           c   4    ...

  8. ArcGIS For JavaScript API 默认参数

    “esri.config”的是在1.3版中的的“esriConfig”的替代品.如果您使用的是1.2或更低的版本,您应该参阅默认API v1.2和更低的配置.对于版本1.3或更高版本,您可以使用“es ...

  9. IBM MQ Reason 2538(MQRC_HOST_NOT_AVAILABLE) 错误原因一例

    环境: .NET 4.0, MQ .NET客户端 IBM.XMS(v2.0.0.3) 测试代码如下: var factoryFactory = XMSFactoryFactory.GetInstanc ...

  10. 安装Golang 1.6及开发环境

    安装Golang 1.6及开发环境=====================================> 下载软件    * go1.4.2.linux-amd64.tar.gz     ...