Gunicorn运行与配置方法
Gunicorn“绿色独角兽”是一个被广泛使用的高性能的PythonWSGIUNIXHTTP服务器,移植自Ruby的独角兽(Unicorn)项目,使用pre-forkworker模式,具有使用非常简单,轻量级的资源消耗,以及高性能等特点。
安装gunicorn:
$sudoapt-getupdate $sudoapt-getinstallgunicorn
运行gunicorn:
$gunicorn[OPTIONS]模块名:变量名
模块名是python文件名,可以是完整的路径+python文件名;变量名是python文件中可调用的WSGI(WebServerGateway).
示例:
#filename:test.py defapp(environ,start_response): """Simplestpossibleapplicationobject""" data='Hello,World!\n' status='200OK' response_headers=[ ('Content-type','text/plain'), ('Content-Length',str(len(data))) ] start_response(status,response_headers) returniter([data])
运行app:
$gunicorn--workers=2test:app
常用配置参数:
-cCONFIG,--config=CONFIG
指定一个配置文件(py文件).
-bBIND,--bind=BIND
与指定socket进行绑定.
-D,--daemon
以守护进程形式来运行Gunicorn进程,其实就是将这个服务放到后台去运行。
-wWORKERS,--workers=WORKERS
工作进程的数量。上边提到gunicorn是一个pre-forkworker模式,就是指gunicorn启动的时候,在主进程中会预先fork出指定数量的worker进程在处理请求时,gunicorn依靠操作系统来提供负载均衡,通常推荐的worker数量是:(2x$num_cores)+1
-kWORKERCLASS,--worker-class=WORKERCLASS
工作进程类型.包括sync(默认),eventlet,gevent,ortornado,gthread,gaiohttp.
--backlogINT
最大挂起的连接数.
--chdir
切换到指定的工作目录.
--log-levelLEVEL
输出errorlog的颗粒度,有效的LEVEL有:
debug
info
warning
error
critical
--access-logfileFILE
确认要写入Accesslog的文件FILE.'-'表示输出到标准输出.
--error-logfileFILE,--log-fileFILE
确认要写入Errorlog的文件FILE.'-'表示输出到标准错误输出.
gunicorn配置
Gunicorn从三个不同地方获取配置:
框架设置(通常只影响到Paster应用)
配置文件(python文件):配置文件中的配置会覆盖框架的设置。
命令行
框架设置只跟Paster(一个Web框架)有关,不讨论;命令行配置如上部分所示;现在我们看下怎么用配置文件配置gunicorn:
配置文件必须是一个python文件,只是将命令行中的参数写进py文件中而已,如果需要设置哪个参数,则在py文件中为该参数赋值即可。例如:
#example.py bind="127.0.0.1:8000" workers=2
运行gunicorn:
$gunicorn-cexample.pytest:app
等同于:
$gunicorn-w2-b127.0.0.1:8000test:app
当然,配置文件还能实现更复杂的配置:
#gunicorn.py importlogging importlogging.handlers fromlogging.handlersimportWatchedFileHandler importos importmultiprocessing 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访问日志格式,错误日志无法设置 """ 其每个选项的含义如下: hremoteaddress l'-' ucurrently'-',maybeusernameinfuturereleases tdateoftherequest rstatusline(e.g.``GET/HTTP/1.1``) sstatus bresponselengthor'-' freferer auseragent Trequesttimeinseconds Drequesttimeinmicroseconds Lrequesttimeindecimalseconds pprocessID """ accesslog="/home/test/server/log/gunicorn_access.log"#访问日志文件 errorlog="/home/test/server/log/gunicorn_error.log"#错误日志文件
参考官网
总结
以上所述是小编给大家介绍的Gunicorn运行与配置方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!