Gunicorn是一个unix上被广泛使用的高性能的Python WSGI UNIX HTTP Server。
和大多数的web框架兼容,并具有实现简单,轻量级,高性能等特点。

gunicorn 安装

pip install gunicorn

gunicorn + flask 简单示例

flask程序需要先安装flask module,pip install flask。

gunicorn_demo.py

from flask import Flask

app = Flask(__name__)

@app.route('/demo', methods=['GET'])
def demo():
return "gunicorn and flask demo."

通过gunicorn运行flask app

# gunicorn gunicorn_demo:app
[2017-12-23 10:36:09 +0000] [24441] [INFO] Starting gunicorn 19.7.1
[2017-12-23 10:36:09 +0000] [24441] [INFO] Listening at: http://127.0.0.1:8000 (24441)
[2017-12-23 10:36:09 +0000] [24441] [INFO] Using worker: sync
[2017-12-23 10:36:09 +0000] [24446] [INFO] Booting worker with pid: 24446

测试结果

# curl http://127.0.0.1:8000/demo
gunicorn and flask demo.

gunicorn 详细配置

gunicorn配置项可以通过gunicorn的启动命令行中设定,也可以通过配置文件指定。强烈建议使用一个配置文件。

配置项如下:

server socket

  • bind

    监听地址和端口。

  • backlog

    服务器中在pending状态的最大连接数,即client处于waiting的数目。超过这个数目, client连接会得到一个error。

    建议值64-2048。

worker 进程

  • workers

    worker进程的数量。建议值2-4 x $(NUM_CORES), 缺省为1。

  • worker_class

    worker进程的工作方式。 有 sync, eventlet, gevent, tornado, gthread, 缺省值sync。

  • threads

    工作进程中线程的数量。建议值2-4 x $(NUM_CORES), 缺省值1。

    此配置只适用于gthread 进程工作方式, 因为gevent这种使用的是协程工作方式。

  • worker_connections

    客户端最大同时连接数。只适用于eventlet, gevent工作方式。

  • max_requests

    worker重启之前处理的最大requests数, 缺省值为0表示自动重启disabled。主要是防止内存泄露。

  • max_requests_jitter

    抖动参数,防止worker全部同时重启。

  • timeout

    通常设为30。

  • graceful_timeout

    接收到restart信号后,worker可以在graceful_timeout时间内,继续处理完当前requests。

  • keepalive

    server端保持连接时间。

security

  • limit_request_line

    http request line最大字节数。值范围0-8190, 0表示无限制。

  • limit_request_field

    http request中 header字段数的最大值。缺省为100,最大32768。

  • limit_request_field_size

    http request header字段最大字节数。0表示无限制。

调试

  • reload

    当代码有修改时,自动重启workers。适用于开发环境。

  • reload_extra_files

    扩展reload配置,增加templates,configurations等文件修改监控。

  • spew

    跟踪程序执行的每一行。

  • check_config

    检查配置。

server 机制

  • sendfile

    系统底层拷贝数据方式,提供performance。

  • chdir

    在app加载之前,进入到此目录。

  • daemon

    应用是否以daemon方式运行。

  • raw_env

    key=value, 传递环境参数。

  • pidfile

    pid存储文件路径。

  • worker_tmp_dir

    临时工作目录。

  • user

    指定worker进程的运行用户名。

  • group

    指定worker进程运行用户所在组。

  • umask

    gunicorn创建文件的缺省权限。

  • pythonpath

    附加到python path的目录列表。

日志

  • accesslog

    访问日志文件路径。

  • access_log_format

    日志格式。 例如 %(h)s %(l)s %(u)s %(t)s "%(r)s" %(s)s %(b)s "%(f)s" "%(a)s" 。

  • errorlog

    错误日志路径。

  • loglever

    日志级别。debug, info, warning, error, critical.

  • capture_output

    重定向stdout/stderr到error log file。

  • logger_class

    日志实现类。缺省gunicorn.glogging.Logger 。

  • logconfig

    日志配置文件。同python标准日志模块logging的配置。

进程名

  • proc_name

    设置进程名(setproctitle),在ps,top等命令中会看到. 缺省值为default_proc_name配置。

server钩子

  • on_starting
  • on_reload
  • when_ready
  • pre_fork
  • post_fork
  • post_worker_init
  • worker_init
  • worker_abort
  • pre_exec
  • pre_request
  • post_request
  • child_exit
  • worker-exit
  • nworkers_changed
  • on_exit

Gunicorn配置

 Gunicorn从三个不同的地方读取配置信息。

 第一个地方:从framework定义的配置信息中读取,目前只对 Paster 框架有效。

 第二个地方:在命令行中定义,命令行中定义的配置信息将会覆盖掉框架中定义的相同的参数名的值。

 最后:将所有的参数信息,放到一个文件中,只要是在命令行中可以定义的参数中,在配置文件中都可以定义。(是一个Python源文件,所以你就像在写Python代码一样)

 第一个地方不不介绍了,不实用。重点介绍第二种和第三种,其实这两种方式都是相同的。

 显示说有配置选项:

gunicorn -h

使用命令行配置:

在上面的 myapp 例子的基础上

gunicorn --workers=4 --bind=127.0.0.1:8000 myapp.test:app

上面的命令 启动 4个 workers ,绑定到 127.0.0.1:8000

配置文件 config.py 源码

import multiprocessing 

bind = "127.0.0.1:8001"
workers = multiprocessing.cpu_count() * 2 + 1

使用配置文件启动Gunicorn

gunicorn --config=config.py myapp.test:app

和上面用命令行配置的效果完全一样,当然两者还可以结合起来用:

gunicorn --config=gunicorn_conf.py --worker-class=eventlet myapp.test:app

worker-class默认是sync(同步),我们配置成了 eventlet(并发的)

本人自己运营一个淘宝店,如果你觉得文章写得好。帮忙给淘宝店点个关注。谢谢

链接: https://shop211977203.taobao.com/

python gunicorn详解的更多相关文章

  1. Python闭包详解

    Python闭包详解 1 快速预览 以下是一段简单的闭包代码示例: def foo(): m=3 n=5 def bar(): a=4 return m+n+a return bar >> ...

  2. [转] Python Traceback详解

    追莫名其妙的bugs利器-mark- 转自:https://www.jianshu.com/p/a8cb5375171a   Python Traceback详解   刚接触Python的时候,简单的 ...

  3. python 数据类型详解

    python数据类型详解 参考网址:http://www.cnblogs.com/linjiqin/p/3608541.html 目录1.字符串2.布尔类型3.整数4.浮点数5.数字6.列表7.元组8 ...

  4. Python 递归函数 详解

    Python 递归函数 详解   在函数内调用当前函数本身的函数就是递归函数   下面是一个递归函数的实例: 第一次接触递归函数的人,都会被它调用本身而搞得晕头转向,而且看上面的函数调用,得到的结果会 ...

  5. python线程详解

    #线程状态 #线程同步(锁)#多线程的优势在于可以同时运行多个任务,至少感觉起来是这样,但是当线程需要共享数据时,可能存在数据不同步的问题. #threading模块#常用方法:'''threadin ...

  6. python数据类型详解(全面)

    python数据类型详解 目录1.字符串2.布尔类型3.整数4.浮点数5.数字6.列表7.元组8.字典9.日期 1.字符串1.1.如何在Python中使用字符串a.使用单引号(')用单引号括起来表示字 ...

  7. Python Collections详解

    Python Collections详解 collections模块在内置数据结构(list.tuple.dict.set)的基础上,提供了几个额外的数据结构:ChainMap.Counter.deq ...

  8. python生成器详解

    1. 生成器 利用迭代器(迭代器详解python迭代器详解),我们可以在每次迭代获取数据(通过next()方法)时按照特定的规律进行生成.但是我们在实现一个迭代器时,关于当前迭代到的状态需要我们自己记 ...

  9. 转 python数据类型详解

    python数据类型详解 目录 1.字符串 2.布尔类型 3.整数 4.浮点数 5.数字 6.列表 7.元组 8.字典 9.日期 1.字符串 1.1.如何在Python中使用字符串 a.使用单引号(' ...

随机推荐

  1. 什么是垃圾搜集(GC)?为什么要有GC呢?

    GC的全称是Gabage Collection,翻译过来就是"垃圾收集"的意思.那么我们为什么用GC呢? 那么我们接下来就来聊一聊GC的创造背景.在C和C++那个年代的程序员界的长 ...

  2. 2020 Java开发者数据分析:中国已成为 Java 第一大国

    最近知名开发工具供应商Jetbrains在Java 25周年之际,对开发群体做了一次有意思的数据分析. 全文内容可见:https://blog.jetbrains.com/idea/2020/09/a ...

  3. Python self用法详解

    在定义类的过程中,无论是显式创建类的构造方法,还是向类中添加实例方法,都要求将 self 参数作为方法的第一个参数.例如,定义一个 Person 类: class Person: def __init ...

  4. Linux学习笔记-vi(一)

    vim编辑命令 vim命令的三种模式: 1.命令模式: vi file.txt  进入vi模式,默认为命令模式,命令模式移动光标. 2.插入模式 i (insert):在光标前插入内容 a(appen ...

  5. 剑指Offer(一):二维数组中的查找

    一.前言 刷题平台:牛客网 二.题目 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整 ...

  6. Mac系统下的zip压缩包解压到Windows下出现乱码的解决方法

    环境变量 环境变量是具有特殊名字的一个特定对象,包含了一个或多个应用程序运行所需的信息.(例如PATH,可执行程序的搜索路径,当要求系统运行一个程序,而没告诉系统它的具体路径时,系统就要在PTAH值的 ...

  7. 三、Requests库的使用

    requests 的底层实现其实就是 urllib3 Requests 唯一的一个非转基因的 Python HTTP 库,人类可以安全享用. 学过关于urllib库的使用,你会发现它是很不方便的.而R ...

  8. 轻松理解JVM的分代模型

    前言 上篇文章我们一起对jvm的内存模型有了比较清晰的认识,小伙伴们可以参考JVM内存模型不再是秘密这篇文章做一个复习. 本篇文章我们将针对jvm堆内存的分代模型做一个详细的解析,和大家一起轻松理解j ...

  9. CDH5部署三部曲之一:准备工作

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  10. Fabric1.4.4 基础环境搭建

    简单记录一下fabric版本1.4.4的环境搭建部署,运行环境为CentOs7.8,如有错误欢迎批评指正. 1.Docker 和 Docker Compose 1. docker的安装部署 docke ...