Gunicorn运行与配置方法

 更新时间:2019年08月04日 09:59:42   作者:涵仔睡觉  
这篇文章主要介绍了Gunicorn运行与配置方法,使用pre-fork worker模式,具有使用非常简单,轻量级的资源消耗,以及高性能等特点。对此感兴趣的朋友跟随小编一起看看吧

Gunicorn“绿色独角兽”是一个被广泛使用的高性能的Python WSGI UNIX HTTP服务器,移植自Ruby的独角兽(Unicorn )项目,使用pre-fork worker模式,具有使用非常简单,轻量级的资源消耗,以及高性能等特点。

安装gunicorn:

$ sudo apt-get update
$ sudo apt-get install gunicorn

运行gunicorn:

$ gunicorn [OPTIONS] 模块名:变量名

模块名是python文件名,可以是完整的路径+python文件名;变量名是python文件中可调用的WSGI(Web Server Gateway ).

示例:

# filename:test.py
def app(environ, start_response):
"""Simplest possible application object"""
data = 'Hello, World!\\n'
status = '200 OK'
response_headers = [
('Content-type','text/plain'),
('Content-Length', str(len(data)))
]
start_response(status, response_headers)
return iter([data])

运行app:

$ gunicorn --workers=2 test:app

常用配置参数:

-c CONFIG, --config=CONFIG

指定一个配置文件(py文件).

-b BIND, –bind=BIND

与指定socket进行绑定.

-D, –daemon

以守护进程形式来运行Gunicorn进程,其实就是将这个服务放到后台去运行。

-w WORKERS, –workers=WORKERS

工作进程的数量。上边提到gunicorn是一个pre-fork worker模式,就是指gunicorn启动的时候,在主进程中会预先fork出指定数量的worker进程在处理请求时,gunicorn依靠操作系统来提供负载均衡,通常推荐的worker数量是:(2 x $num_cores) + 1

-k WORKERCLASS, –worker-class=WORKERCLASS

工作进程类型. 包括 sync(默认), eventlet, gevent, or tornado, gthread, gaiohttp.

–backlog INT

最大挂起的连接数.

–chdir

切换到指定的工作目录.

–log-level LEVEL

输出error log的颗粒度,有效的LEVEL有:

debug
info
warning
error
critical
–access-logfile FILE

确认要写入Access log的文件FILE. ‘-‘ 表示输出到标准输出.

–error-logfile FILE, –log-file FILE

确认要写入Error log的文件FILE. ‘-‘ 表示输出到标准错误输出.

gunicorn配置

Gunicorn从三个不同地方获取配置:

框架设置(通常只影响到Paster应用)

配置文件(python文件):配置文件中的配置会覆盖框架的设置。

命令行

框架设置只跟Paster(一个Web框架)有关,不讨论;命令行配置如上部分所示;现在我们看下怎么用配置文件配置gunicorn:

配置文件必须是一个python文件,只是将命令行中的参数写进py文件中而已,如果需要设置哪个参数,则在py文件中为该参数赋值即可。例如:

# example.py
bind = "127.0.0.1:8000"
workers = 2

运行gunicorn:

$ gunicorn -c example.py test:app

等同于:

$ gunicorn -w 2 -b 127.0.0.1:8000 test:app

当然,配置文件还能实现更复杂的配置:

# gunicorn.py
import logging
import logging.handlers
from logging.handlers import WatchedFileHandler
import os
import multiprocessing
bind = '127.0.0.1:8000'   #绑定ip和端口号
backlog = 512        #监听队列
chdir = '/home/test/server/bin' #gunicorn要切换到的目的工作目录
timeout = 30   #超时
worker_class = 'gevent' #使用gevent模式,还可以使用sync 模式,默认的是sync模式
workers = multiprocessing.cpu_count() * 2 + 1  #进程数
threads = 2 #指定每个进程开启的线程数
loglevel = 'info' #日志级别,这个日志级别指的是错误日志的级别,而访问日志的级别无法设置
access_log_format = '%(t)s %(p)s %(h)s "%(r)s" %(s)s %(L)s %(b)s %(f)s" "%(a)s"'  #设置gunicorn访问日志格式,错误日志无法设置
"""
其每个选项的含义如下:
h     remote address
l     '-'
u     currently '-', may be user name in future releases
t     date of the request
r     status line (e.g. ``GET / HTTP/1.1``)
s     status
b     response length or '-'
f     referer
a     user agent
T     request time in seconds
D     request time in microseconds
L     request time in decimal seconds
p     process ID
"""
accesslog = "/home/test/server/log/gunicorn_access.log"   #访问日志文件
errorlog = "/home/test/server/log/gunicorn_error.log"    #错误日志文件

参考官网

总结

以上所述是小编给大家介绍的Gunicorn运行与配置方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

相关文章

  • 详解linux中nano命令

    详解linux中nano命令

    这篇文章主要介绍了详解linux中nano命令,详细的介绍了nano命令的用法,非常具有实用价值,需要的朋友可以参考下

    2017-09-09

  • 详解Linux系统中的tempfs与/dev/shm

    详解Linux系统中的tempfs与/dev/shm

    /dev/shm是Linux非常有用的一个目录,它就是所谓的tmpfs,也可以称之为临时文件系统(不是块设备),类似oracle中的临时表空间一样,用于加速和优化系统。下面这篇文章主要给大家介绍了Linux系统中tempfs与/dev/shm的相关资料,需要的朋友可以参考下。

    2017-02-02

  • 解析Linux内核与设备树的编译和烧写

    解析Linux内核与设备树的编译和烧写

    在内核源码中,存在大量对板级细节信息描述的代码。开源文档中对设备树的描述是,一种描述硬件资源的数据结构,它通过bootloader将硬件资源传给内核,使得内核和硬件资源描述相对独立

    2021-06-06

  • 区分Linux硬链接与软链接

    区分Linux硬链接与软链接

    这篇文章主要介绍了区分Linux硬链接与软链接,帮助大家更好的理解和学习Linux,感兴趣的朋友可以了解下

    2020-08-08

  • Yum中报错:“pycurl.so: undefined symbol: CRYPTO_num_locks”的问题排查

    Yum中报错:“pycurl.so: undefined symbol: CRYPTO_num_locks”

    这篇文章主要给大家介绍了在Yum中报错: "pycurl.so: undefined symbol: CRYPTO_num_locks"的问题排查的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。

    2017-06-06

  • linux systemctl命令详解

    linux systemctl命令详解

    这篇文章主要介绍了linux systemctl命令详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

    2018-03-03

  • Linux下安装IPython配置python开发环境教程

    Linux下安装IPython配置python开发环境教程

    这篇文章主要为大家详细介绍了Linux下安装IPython配置python开发环境教程,需要的朋友可以参考下

    2016-05-05

  • 详解Centos/Linux下调整分区大小(以home和根分区为例)

    详解Centos/Linux下调整分区大小(以home和根分区为例)

    本篇文章主要介绍了Centos/Linux下调整分区大小(以home和根分区为例),具有一定的参加价值,有需要的同学可以了解一下

    2017-06-06

  • 详解linux 下安装软件tar.gz, rpm,deb的方法

    详解linux 下安装软件tar.gz, rpm,deb的方法

    本篇文章主要介绍了linux 下安装软件tar.gz, rpm,deb的方法 ,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。

    2016-12-12

  • ubuntu 13.10编译安装mono环境(二)

    ubuntu 13.10编译安装mono环境(二)

    接上篇,上篇仅安装了Mono本身,并没有安装libgdiplus、gtk-sharp、mod_mono、MonoDevelop 等其他相关的软件。 这篇主要是配置安装libgdiplus。

    2014-07-07

最新评论

声明:本站(华域联盟www.cnhackhy.com)所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。