专栏首页python3python web.py使用flup

python web.py使用flup

前文用Python实现CRUD功能REST服务中发现,一个普通的web.py页面每秒只能执行数十次requests,经网友Arbow提醒, web.py默认是单线程方式,所以性能提升困难,并推荐了一些高性能的web framework。同时也看到Python资深网友ZoomQuiet的总结 Pythonic Web 应用平台对比,因此觉得有必要换一种更强的web framework。同时也研究了国内著名的豆瓣所采用的Quixote框架。但由于牵涉到更换之后web.py中的REST接口代码实现要调整,所以就暂时搁置了。

后来看到搜狐qiuyingbo在lighttpd 2.0一文中提到sohu mail也是用web.py, 在向qiuyingbo请教之后,了解到web.py通过fastcgi多进程方式也可以实现高性能的访问,决定不再换框架了。

qiuyingbo推荐使用nginx+flup+webpy, 但是最近nginx的mod_wsgi页面中的 http://wiki.codemongers.com/NginxNgxWSGIModule 下载链接始终不能访问,所以就转向 lighttpd/fastcgi 方式,国外著名的reddit也是采用此架构,性能上应该不会有很大的差异。

在安装了lighttpd和配置之后,目前调用一个helloworld.py在本地一普通服务器上可以每秒达到1000次左右,在一个更专业的4核服务器上,执行速度更可4,000次。基本上可以满足运营的要求。

另外赖勇浩在blog我常用的几个第三方 Python 库中提到,使用psyco可以提升Python 40%或更高的性能。在32bit Linux下,测试上面的场景可提高约10%的性能。但由于Psyco不支持64bit架构,所以正式的生产环境就没有安装这个加速功能。

具体配置过程如下,假定lighttpd安装在/data0/lighttpd下:

  • Install Lighttpd, Download lighttpd http://www.lighttpd.net/download/lighttpd-1.4.21.tar.gz

./configure –prefix=/data0/lighttpd –with-openssl; make; make install cp docs/lighttpd.conf /data0/lighttpd/sbin openssl req -new -x509 -keyout lighttpd.pem -out lighttpd.pem -days 365 -nodes

  • Install Python 2.6, 具有内置Json支持 http://www.python.org/ftp/python/2.6.1/Python-2.6.1.tgz

./configure; make; make install

  • Install web.py http://webpy.org/static/web.py-0.31.tar.gz

python setup.py install

  • Install flup, http://www.saddi.com/software/flup/dist/flup-1.0.1.tar.gz
  • Install lighttpd + fastcgi with web.py

fastcgi.server = ( “/main.py” => ( ( “socket” => “/tmp/fastcgi.socket”, “bin-path” => “/data0/lighttpd/www/python/main.py”, “max-procs” => 50, “bin-environment” => ( “REAL_SCRIPT_NAME” => “” ), “check-local” => “disable” )

) )

url.rewrite-once = ( “^/favicon.ico$” => “/static/favicon.ico”, “^/static/(.*)$” => “/static/$1″, “^/(.*)$” => “/main.py/$1″, )

也可参看webpy官方的lighttpd fastcgi说明:http://webpy.org/cookbook/fastcgi-lighttpd

  • 启动Lighttpd

cd /data0/lighttpd/sbin; ./lighttpd -f lighttpd.conf

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • springboot中的cache(二)

    原理:在 SpringBoot 的 Cache 中,会默认使用 SimpleCacheManager, 生成一个 KeyGenerator(),将数据保存在 C...

    用户6029108
  • 基于STM32F103xxx的J1939程序开发

    本篇笔记主要介绍,如何在STM32F103XXX系列上实现SAE J1939协议,基于STM32F103RCT6芯片 使用IAR8.32作为软件开发环境。

    用户1605515
  • 谁说Postgresql 没有靠谱的高可用

    上期说到了见证服务器,见证服务器的功能到底有什么用,其实如同各种高可用中(这里说的是完备的高可用)大部分都是三台,因为怕什么,怕脑裂,因为高可用要面对的问题是很...

    AustinDatabases
  • GPU并行计算和CUDA编程(1)-CPU体系架构概述

    今天和实验室同学去听了周斌老师讲的《GPU并行计算和CUDA程序开发及优化》(课程主页:http://acsa.ustc.edu.cn/HPC2015/nvid...

    王云峰
  • Docker安装与启动

    Docker官方建议在Ubuntu中安装,因为Docker是基于Ubuntu发布的,而且一般Docker出现的问题Ubuntu是最先更新或者打补丁的。在很多版本...

    cwl_java
  • 不懂底层的程序员不是好程序员,解密代码在计算机中运行原理

    还记得Windows的CMD吗?只需向这个黑框框输入指令,计算机即可做出相对应的响应。其实计算机的运行本身就是依靠向CPU下达一条一条的指令,并使计算机按指令运...

    IT大咖说
  • LLDB实战之导出Mac微信备份聊天记录的SQLite密码(SQLCipher加密)

    于是查看SQLCipher的API,看到用的是sqlite3_key()和sqlite3_key_v2()这2个函数,在源码里搜索,找到调用,一共有两处,在WC...

    xferris
  • Python | asyncio:从原理、源码到实现

    今年,在一次内部技术分享会上,我要分享的内容涉及到一些 python 协程,我又去看 asyncio 的文档。

    咸鱼学Python
  • 计算机基础 | 多核、缓存...现代CPU是如何工作的

    之前的文章《源代码如何被计算机执行》已经提到,对于一段源代码,计算机主要依靠编译器将源代码转化为CPU可以执行的程序。那么,CPU到底是如何工作的呢?本文将介绍...

    PP鲁
  • HoneyTalk——我和我女朋友的专属情侣聊天器

    Arduino聊天室是一个匿名群聊应用 但是今天的应用是一对一 专属情侣聊天 话不多说 还不快来看看

    聪明的瓦肯人

扫码关注云+社区

领取腾讯云代金券