Gunicorn ?
Gunicorn“绿色独角兽”是一个被广泛使用的高性能的Python WSGI UNIX HTTP服务器,移植自Ruby的独角兽(Unicorn )项目,使用pre-fork worker模式,具有部署使用非常简单,轻量级的资源消耗,以及高性能等特点。
Web架构图安装
系统安装
sudo apt-get update
sudo apt-get install gunicorn
pip安装
pip install 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
常见[OPTIONS]
参数:
-
-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. '-' 表示输出到标准错误输出.
配置
配置来源:
- 框架设置
- 配置文件(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" #错误日志文件
网友评论