zoukankan      html  css  js  c++  java
  • 服务器程序源代码分析之三:gunicorn

    gunicorn是一个python web 服务部署工具,类似flup,完全用python开发,参考了ruby的部署工具: Unicorn project

    gunicorn主要功能:

    • wsgi-http 协议的转换

      python有一个官方的module叫做WSGI(The Web Server Gateway Interface),版本号PEP333,定义了一些接口规范

      所以凡是python web框架都会遵守这个规范,django或者web.py都是这样

    • gunicorn对协议的支持很单一:输入wsgi,输出http

      flup也是输入wsgi,但支持多种输出:ajp,cgi,fcgi,scgi,就偏偏不支持http

      所以flup和gunicorn是前浪后浪的关系

    • IO模型采用pre-fork模式
    • 子进程里面,可以支持sync,eventlet,gevent,tornado 4种网络处理方法,默认用sync
    • gunicorn的代码质量比较差,起码比flup要差,缺乏python-style

      python-style:只要看看python自带的lib就了然,就是那种感觉

    sync的实现

    1. 采用阻塞的accept等待新连接
    2. 一旦连接成功,就用select来驱动所有的client

    select是遍历fd_set的方式,并且在linux有句柄数量必须小于1024的限制,这两点导致了sync模式的并发能力有限,flup也是这样,如果选择sync模式,那么和用 flup 没有什么区别

    gunicorn还可以采用异步IO

    • 可以通过import代码包的方式,使用eventlet,gevent,tornado 之一
    • 这3种都是高性能异步IO(Fast event loop based on libev (epoll on Linux, kqueue on FreeBSD))
    • python 2.6就在select module里面加上了epoll/poll/kqueue/kevent 支持,把sync模块 改造为高性能异步IO其实非常容易

    本文地址: http://lutaf.com/219.htm 鲁塔弗原创文章,欢迎转载,请附带原文链接

  • 相关阅读:
    数据库设计
    构建评价
    Schema xds文献
    架构设计评价
    需求分析评价
    获取script的链接参数并执行
    js获取封装对象/通过id tag className
    通过css/js来固定div的位置
    nginx日志分析工具goaccesss
    如何快速安装 allure
  • 原文地址:https://www.cnblogs.com/DjangoBlog/p/4442098.html
Copyright © 2011-2022 走看看