Gunicorn筆記教程

Gunicorn 哈街?

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

Web架構(gòu)圖

安裝

系統(tǒng)安裝

sudo apt-get update
sudo apt-get install gunicorn

pip安裝

pip install gunicorn

運行

gunicorn [OPTIONS] 模塊名:變量名

參數(shù):

  • 模塊名: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

常見[OPTIONS]參數(shù):

  • -c CONFIG, --config=CONFIG: 指定配置文件(py文件)
  • -b BIND, --bind=BIND: 與指定socket進(jìn)行綁定.
  • -D, --daemon: 以守護進(jìn)程形式來運行Gunicorn進(jìn)程坑质,其實就是將這個服務(wù)放到后臺去運行合武。
  • -w WORKERS, --workers=WORKERS: 工作進(jìn)程的數(shù)量。上邊提到gunicorn是一個pre-fork worker模式涡扼,就是指gunicorn啟動的時候稼跳,在主進(jìn)程中會預(yù)先fork出指定數(shù)量的worker進(jìn)程在處理請求時,gunicorn依靠操作系統(tǒng)來提供負(fù)載均衡吃沪,通常推薦的worker數(shù)量是:(2 x $num_cores) + 1
  • -k WORKERCLASS, --worker-class=WORKERCLASS: 工作進(jìn)程類型. 包括 sync(默認(rèn)), eventlet, gevent, or tornado, gthread, gaiohttp.
  • --backlog INT: 最大掛起的連接數(shù).
  • --chdir: 切換到指定的工作目錄.
  • --log-level LEVEL: 輸出error log的顆粒度汤善,有效的LEVEL有:debuginfowarning红淡、error不狮、critical
  • --access-logfile FILE: 確認(rèn)要寫入Access log的文件FILE. '-' 表示輸出到標(biāo)準(zhǔn)輸出.
  • --error-logfile FILE, --log-file FILE: 確認(rèn)要寫入Error log的文件FILE. '-' 表示輸出到標(biāo)準(zhǔn)錯誤輸出.

配置

配置來源:

  • 框架設(shè)置
  • 配置文件(python文件)
  • 命令行

配置文件必須是py文件,本質(zhì)是將命令行參數(shù)寫進(jìn)py文件在旱。

如:

# 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

也可以詳細(xì)配置:

# 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 模式,默認(rèn)的是sync模式

workers = multiprocessing.cpu_count() * 2 + 1    #進(jìn)程數(shù)
threads = 2 #指定每個進(jìn)程開啟的線程數(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"        #錯誤日志文件
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末俊嗽,一起剝皮案震驚了整個濱河市雾家,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌绍豁,老刑警劉巖芯咧,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異竹揍,居然都是意外死亡敬飒,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進(jìn)店門芬位,熙熙樓的掌柜王于貴愁眉苦臉地迎上來无拗,“玉大人,你說我怎么就攤上這事昧碉∮⑷荆” “怎么了?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵被饿,是天一觀的道長四康。 經(jīng)常有香客問我,道長狭握,這世上最難降的妖魔是什么闪金? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮论颅,結(jié)果婚禮上哎垦,老公的妹妹穿的比我還像新娘。我一直安慰自己恃疯,他們只是感情好漏设,可當(dāng)我...
    茶點故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著澡谭,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蛙奖,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天潘酗,我揣著相機與錄音,去河邊找鬼雁仲。 笑死仔夺,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的攒砖。 我是一名探鬼主播缸兔,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼吹艇!你這毒婦竟也來了惰蜜?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤受神,失蹤者是張志新(化名)和其女友劉穎抛猖,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鼻听,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡财著,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了撑碴。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片撑教。...
    茶點故事閱讀 38,605評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖醉拓,靈堂內(nèi)的尸體忽然破棺而出伟姐,到底是詐尸還是另有隱情,我是刑警寧澤廉嚼,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布玫镐,位于F島的核電站,受9級特大地震影響怠噪,放射性物質(zhì)發(fā)生泄漏恐似。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一傍念、第九天 我趴在偏房一處隱蔽的房頂上張望矫夷。 院中可真熱鬧,春花似錦憋槐、人聲如沸双藕。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽忧陪。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間嘶摊,已是汗流浹背延蟹。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留叶堆,地道東北人阱飘。 一個月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像虱颗,于是被迫代替她去往敵國和親沥匈。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,472評論 2 348

推薦閱讀更多精彩內(nèi)容