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. 简单聊聊 Ironic

    上一篇文章里我简单介绍了一下「裸金属」的概念,提到了 OpenStack 中的核心项目 Ironic,今天简单来聊聊它. Ironic 项目的吉祥物 Bare Metal 所以用 Bear 来做吉祥物 ...

  2. 初探JVM

    JVM探究 请你谈谈你对JVM的理解?java8虚拟机和之前的变化更新? 什么是OOM,什么是栈溢出StackOverFlowError?怎么分析? JVM的常用调优参数? 内存快照如何抓取,怎么分析 ...

  3. 项目里出现两个配置类继承WebMvcConfigurationSupport时,为什么只有一个会生效(源码分析)

    为什么我们的项目里出现两个配置类继承WebMvcConfigurationSupport时,只有一个会生效.我在网上找了半天都是说结果的,没有人分析源码到底是为啥,博主准备讲解一下,希望可以帮到大家! ...

  4. pip安装更换镜像源

    说明 有时候网不好,pip安装非常慢,所以需要更换源,特记录如下   国内镜像地址: # 清华大学 https://pypi.tuna.tsinghua.edu.cn/simple # 豆瓣 http ...

  5. linux内核 idr机制

    idr机制解决了什么问题?为什么需要idr机制(或者说,idr机制这种解决方案,相对已有的其他方案,有什么优势所在) ? idr在linux内核中指的就是整数ID管理机制,从本质上来说,这就是一种将整 ...

  6. Hudi on Flink在顺丰的实践应用

    ​ 获取PDF版本 请关注"实时流式计算" 后台回复 "flink1015"

  7. Markdown语法及使用方法完整手册

    欢迎使用 Markdown在线编辑器 MdEditor Markdown是一种轻量级的「标记语言」 Markdown是一种可以使用普通文本编辑器编写的标记语言,通过简单的标记语法,它可以使普通文本内容 ...

  8. IDEA项目路径初探

    IDEA项目路径 普通Java项目 普通Java项目,标准目录结构src下的路径就是classpath类路径,每次编译都会将src目录下新增的类和资源文件打包进类路径. 如下图,类文件和配置文件都会被 ...

  9. es 迁移数据, 重建索引

    原索引 PUT my_index { "mappings": { "_doc": { "properties": { "creat ...

  10. "计算机科学"与"软件工程"有什么区别?哪个专业更适合你?

    "计算机科学和软件工程专业有什么不同?" 以及- "如果我想成为软件工程师,我应该选择计算机科学还是软件工程专业?" 在这篇文章中,我会回答这个问题,并分享一些 ...