主頁 > 知識庫 > Gunicorn運行與配置方法

Gunicorn運行與配置方法

熱門標簽:山東企業(yè)外呼系統(tǒng)公司 承德地圖標注公司 地圖標注黃河的位置 濮陽好的聯(lián)通400電話申請 靈圖uu電子寵物店地圖標注 400電話號碼辦理多少錢 地圖標注如何改成微信號 虛假地圖標注 百度地圖標注公司位置要多少錢

Gunicorn“綠色獨角獸”是一個被廣泛使用的高性能的Python WSGI UNIX HTTP服務(wù)器,移植自Ruby的獨角獸(Unicorn )項目,使用pre-fork worker模式,具有使用非常簡單,輕量級的資源消耗,以及高性能等特點。

安裝gunicorn:

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

運行g(shù)unicorn:

$ gunicorn [OPTIONS] 模塊名:變量名

模塊名是python文件名,可以是完整的路徑+python文件名;變量名是python文件中可調(diào)用的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

常用配置參數(shù):

-c CONFIG, --config=CONFIG

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

-b BIND, --bind=BIND

與指定socket進行綁定.

-D, --daemon

以守護進程形式來運行Gunicorn進程,其實就是將這個服務(wù)放到后臺去運行。

-w WORKERS, --workers=WORKERS

工作進程的數(shù)量。上邊提到gunicorn是一個pre-fork worker模式,就是指gunicorn啟動的時候,在主進程中會預先fork出指定數(shù)量的worker進程在處理請求時,gunicorn依靠操作系統(tǒng)來提供負載均衡,通常推薦的worker數(shù)量是:(2 x $num_cores) + 1

-k WORKERCLASS, --worker-class=WORKERCLASS

工作進程類型. 包括 sync(默認), eventlet, gevent, or tornado, gthread, gaiohttp.

--backlog INT

最大掛起的連接數(shù).

--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從三個不同地方獲取配置:

框架設(shè)置(通常只影響到Paster應用)

配置文件(python文件):配置文件中的配置會覆蓋框架的設(shè)置。

命令行

框架設(shè)置只跟Paster(一個Web框架)有關(guān),不討論;命令行配置如上部分所示;現(xiàn)在我們看下怎么用配置文件配置gunicorn:

配置文件必須是一個python文件,只是將命令行中的參數(shù)寫進py文件中而已,如果需要設(shè)置哪個參數(shù),則在py文件中為該參數(shù)賦值即可。例如:

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

運行g(shù)unicorn:

$ gunicorn -c example.py test:app

等同于:

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

當然,配置文件還能實現(xiàn)更復雜的配置:

# 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        #監(jiān)聽隊列
chdir = '/home/test/server/bin' #gunicorn要切換到的目的工作目錄
timeout = 30   #超時
worker_class = 'gevent' #使用gevent模式,還可以使用sync 模式,默認的是sync模式
workers = multiprocessing.cpu_count() * 2 + 1  #進程數(shù)
threads = 2 #指定每個進程開啟的線程數(shù)
loglevel = 'info' #日志級別,這個日志級別指的是錯誤日志的級別,而訪問日志的級別無法設(shè)置
access_log_format = '%(t)s %(p)s %(h)s "%(r)s" %(s)s %(L)s %(b)s %(f)s" "%(a)s"'  #設(shè)置gunicorn訪問日志格式,錯誤日志無法設(shè)置
"""
其每個選項的含義如下:
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"    #錯誤日志文件

參考官網(wǎng)

總結(jié)

以上所述是小編給大家介紹的Gunicorn運行與配置方法,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

標簽:德宏 泰安 福州 安康 淮安 上海 樂山 鷹潭

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Gunicorn運行與配置方法》,本文關(guān)鍵詞  Gunicorn,運行,與,配置,方法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Gunicorn運行與配置方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于Gunicorn運行與配置方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章