python Gunicorn服務(wù)器使用方法詳解
1. 簡介
Gunicorn(Green Unicorn)是給Unix用的WSGI HTTP 服務(wù)器,它與不同的web框架是非常兼容的、易安裝、輕、速度快。

2. 示例代碼1
def app(environ, start_response):
data = b"Hello World\n"
start_response("200 OK", [
("Content-Type", "test/plain"),
("Content-Length", str(len(data)))
])
return iter([data])
啟動
gunicorn -w 4 myapp:app
起來后顯示
[2016-12-12 00:20:12 +0000] [11755] [INFO] Starting gunicorn 19.6.0 [2016-12-12 00:20:12 +0000] [11755] [INFO] Listening at: http://127.0.0.1:8000 (11755) [2016-12-12 00:20:12 +0000] [11755] [INFO] Using worker: sync [2016-12-12 00:20:12 +0000] [11760] [INFO] Booting worker with pid: 11760 [2016-12-12 00:20:12 +0000] [11761] [INFO] Booting worker with pid: 11761 [2016-12-12 00:20:12 +0000] [11762] [INFO] Booting worker with pid: 11762 [2016-12-12 00:20:12 +0000] [11763] [INFO] Booting worker with pid: 11763
此時,調(diào)用http://127.0.0.1:8000
$curl http://127.0.0.1:8000 Hello World
參數(shù)說明
-w 處理HTTP請求的worker進程數(shù),以下兩種啟動方式等價
gunicorn -w 4 myapp:app gunicorn --workers=4 myapp:app
參考:
-w INT, --workers INT
The number of worker processes for handling requests.
問題:為何調(diào)用 http://ip:8000不行呢, 這個是什么請求呢?
默認有-b參數(shù),參考
-b ADDRESS, --bind ADDRESS
The socket to bind. [['127.0.0.1:8000']]
以下方式啟動就可以用ip的方式啟動了
sudo gunicorn -w 2 -b 0.0.0.0:4000 myapp:app
3. 示例代碼2
之前簡單的flask方法
from flask import Flask
app = Flask(__name__)
@app.route('/hello.world')
def check():
return 'hello world!'
if __name__ == '__main__':
app.run()
啟動
$sudo gunicorn -b 0.0.0.0:300 -w 4 myapp3:app [2016-12-18 19:19:51 +0000] [21005] [INFO] Starting gunicorn 19.6.0 [2016-12-18 19:19:51 +0000] [21005] [INFO] Listening at: http://0.0.0.0:300 (21005) [2016-12-18 19:19:51 +0000] [21005] [INFO] Using worker: sync [2016-12-18 19:19:51 +0000] [21010] [INFO] Booting worker with pid: 21010 [2016-12-18 19:19:51 +0000] [21011] [INFO] Booting worker with pid: 21011 [2016-12-18 19:19:51 +0000] [21014] [INFO] Booting worker with pid: 21014 [2016-12-18 19:19:51 +0000] [21017] [INFO] Booting worker with pid: 21017
測試
$curl localhost:300/hello.world hello world!
4. 啟動異常
[ERROR] Connection in use: ('127.0.0.1', 8000)
原因之一是之前啟動的進程沒有殺死。
注:ctrl+z 是掛起進程,但沒有終止。ctrl+c是終止進程。
如果使用了ctrl+z再回到進程中可使用fg命令,這樣可以用ctrl+c來關(guān)閉進程
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python中使用__new__實現(xiàn)單例模式并解析
單例模式是一個經(jīng)典設(shè)計模式,簡要的說,一個類的單例模式就是它只能被實例化一次,實例變量在第一次實例化時就已經(jīng)固定。 這篇文章主要介紹了Python中使用__new__實現(xiàn)單例模式并解析 ,需要的朋友可以參考下2019-06-06
Django把SQLite數(shù)據(jù)庫轉(zhuǎn)換為Mysql數(shù)據(jù)庫的過程
之前我們默認使用的是SQLite數(shù)據(jù)庫,我們開發(fā)完成之后,里面有許多數(shù)據(jù),如果我們想轉(zhuǎn)換成Mysql數(shù)據(jù)庫,那我們先得把舊數(shù)據(jù)從SQLite導(dǎo)出,然后再導(dǎo)入到新的Mysql數(shù)據(jù)庫里去,這篇文章主要介紹了Django如何把SQLite數(shù)據(jù)庫轉(zhuǎn)換為Mysql數(shù)據(jù)庫,需要的朋友可以參考下2023-05-05
python Selenium等待元素出現(xiàn)的具體方法
在本篇文章里小編給大家分享的是一篇關(guān)于python Selenium等待元素出現(xiàn)的具體方法,以后需要的朋友們可以學習參考下。2021-08-08
Python Scrapy框架:通用爬蟲之CrawlSpider用法簡單示例
這篇文章主要介紹了Python Scrapy框架:通用爬蟲之CrawlSpider用法,結(jié)合實例形式分析了Scrapy框架中CrawlSpider的基本使用方法,需要的朋友可以參考下2020-04-04
python使用循環(huán)打印所有三位數(shù)水仙花數(shù)的實例
今天小編就為大家分享一篇python使用循環(huán)打印所有三位數(shù)水仙花數(shù)的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-11-11
Python2中的raw_input() 與 input()
這篇文章主要介紹了Python2中的raw_input() 與 input(),本文分析了它們的內(nèi)部實現(xiàn)和不同之處,并總結(jié)了什么情況下使用哪個函數(shù),需要的朋友可以參考下2015-06-06

