gunicorn 實現 gevent 多線程


# -*- coding:utf8 -*-
# gunicorn 參數詳情 https://blog.csdn.net/y472360651/article/details/78538188
from gevent import monkey
import multiprocessing
monkey.patch_all()
# 監聽本機的8888端口
bind = '0.0.0.0:8888'        #指定gunicorn的端口號
#preload_app = True
# 開啟進程
# workers=4
workers = multiprocessing.cpu_count() * 2 + 1
# 每個進程的開啟線程
threads = multiprocessing.cpu_count() * 2
backlog = 2048
timeout = 60*60*10
# 工作模式為gevent
worker_class = "gevent"
debug=True
# 如果不使用supervisord之類的進程管理工具可以是進程成為守護進程,否則會出問題
# daemon = True
# # 進程名稱
proc_name = 'gunicorn.pid'
# # 進程pid記錄文件
# pidfile = 'app_pid.log'
# loglevel = '/logs/debug'
# logfile = '/logs/gun_debug.log'
# accesslog = '/logs/gun_access.log'
# access_log_format = '%(h)s %(t)s %(U)s %(q)s'
# errorlog = '/logs/gun_error.log'


啟動
["./wait.sh", "mysql:3306", "--timeout=120","--","gunicorn",'-c','gunicorn_config.py','start:app']
 
        

gunicorn 安裝

pip install gunicorn

 

gunicorn_demo.py

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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2026 CODEPRJ.COM