gunicorn

安装

pip install gunicorn

常用命令

gunicorn -w 4 -b 127.0.0.1:8080 -D --access-logfile=/var/log/gunicorn.log 项目名.wsgi:application
1)-c CONFIG,–config=CONFIG
指定一个配置文件(py文件)
2)-b BIND,–bind=BIND
与指定socket进行板顶
3)-D,–daemon
后台进程方式运行gunicorn进程
4)-w WORKERS,–workers=WORKERS
工作进程的数量
5)-k WORKERCLASS,–worker-class=WORKERCLASS
工作进程类型,包括sync(默认),eventlet,gevent,tornado,gthread,gaiohttp
6)–backlog INT
最大挂起的连接数
7)–log-level LEVEL
日志输出等级
8)–access-logfile FILE
访问日志输出文件
9)–error-logfile FILE
错误日志输出文件

使用配置文件启动项目
# gunicorn.conf.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/python/PycharmProjects/News-Information'  # 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/python/PycharmProjects/News-Information/log/gunicorn_access.log"  # 访问日志文件
 errorlog = "/home/python/PycharmProjects/News-Information/log/gunicorn_error.log"
详解

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 “%®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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值