gunicorn+gevent+nginx部署flask應(yīng)用

gunicorn+gevent+nginx部署flask應(yīng)用

這次部署是在ubuntu上進(jìn)行的,在部署開始之前要做以下事情:

1.在你的linux系統(tǒng)上安裝python-pip
sudo apt-get install python-setuptools
sudo apt-get install python-dev 
sudo apt-get install python-pip
2.安裝virtualenv
sudo apt-get install python-virtualenv
3.切換到你的flask應(yīng)用項(xiàng)目的根目錄
virtualenv venv
source venv/bin/activate
4.進(jìn)入虛擬環(huán)境后,安裝你的flask應(yīng)用的所有擴(kuò)展包,最好把所有的擴(kuò)展包寫入requirements.txt
pip install -r requirements.txt 
5.安裝gunicorn和gevent
pip install gunicorn
pip install gevent
6.啟動(dòng)gunicorn(注:這時(shí)必須進(jìn)入你項(xiàng)目的根目錄且處于虛擬環(huán)境中司志,因?yàn)間unicorn安裝在虛擬環(huán)境中)

1.配置gunicorn啟動(dòng)配置文件,在項(xiàng)目的根目錄創(chuàng)建一個(gè)gun.conf,寫入以下內(nèi)容:

import os
bind = '0.0.0.0:8000'   #綁定的ip及端口號(hào)
workers = 4     #進(jìn)程數(shù)
backlog = 2048      #監(jiān)聽隊(duì)列
worker_class = "gevent"     #使用gevent模式窒篱,還可以使用sync 模式,默認(rèn)的是sync模式
debug = True
chdir = #你項(xiàng)目的根目錄,比如我的app.py文件在/home/ubuntu/app目錄下,就填寫'/home/ubuntu/app'
proc_name = 'gunicorn.proc'

2.然后執(zhí)行以下代碼啟動(dòng)

gunicorn -k gevent -c gun.conf app:app

如果看到類似下面的反應(yīng)就表示啟動(dòng)成功煮盼,如果失敗請(qǐng)檢查你所在的目錄是否為Flask項(xiàng)目的根目錄

(venv) ubuntu@VM-250-138-ubuntu:~/app$ gunicorn -k gevent -c gun.conf app:app
[2016-09-10 23:07:55 +0800] [2641] [DEBUG] Current configuration:
  paste: None
  post_fork: <function Postfork.post_fork at 0x7fda10539bf8>
  threads: 1
  chdir: /home/ubuntu/app
  group: 500
  post_request: <function PostRequest.post_request at 0x7fda10544598>
  forwarded_allow_ips: ['127.0.0.1']
  worker_exit: <function WorkerExit.worker_exit at 0x7fda10544730>
  worker_tmp_dir: None
  tmp_upload_dir: None
  secure_scheme_headers: {'X-FORWARDED-SSL': 'on', 'X-FORWARDED-PROTO': 'https', 'X-FORWARDED-PROTOCOL': 'ssl'}
  syslog_addr: udp://localhost:514
  post_worker_init: <function PostWorkerInit.post_worker_init at 0x7fda10539d90>
  pre_exec: <function PreExec.pre_exec at 0x7fda105442f0>
  max_requests_jitter: 0
  timeout: 30
  keepalive: 2
  umask: 0
  logger_class: gunicorn.glogging.Logger
  syslog_prefix: None
  spew: False
  pre_fork: <function Prefork.pre_fork at 0x7fda10539a60>
  keyfile: None
  ca_certs: None
  do_handshake_on_connect: False
  worker_connections: 1000
  pre_request: <function PreRequest.pre_request at 0x7fda10544488>
  workers: 4
  ssl_version: 3
  sendfile: None
  reload: False
  syslog: False
  statsd_prefix: 
  limit_request_field_size: 8190
  cert_reqs: 0
  ciphers: TLSv1
  syslog_facility: user
  on_reload: <function OnReload.on_reload at 0x7fda10539730>
  on_exit: <function OnExit.on_exit at 0x7fda10544a60>
  proxy_protocol: False
  suppress_ragged_eofs: True
  check_config: False
  proc_name: gunicorn.proc
  capture_output: False
  enable_stdio_inheritance: False
  pidfile: /home/ubuntu/app/gunicorn.pid
  worker_int: <function WorkerInt.worker_int at 0x7fda10539f28>
  accesslog: None
  loglevel: debug
  logconfig: None
  statsd_host: None
  nworkers_changed: <function NumWorkersChanged.nworkers_changed at 0x7fda105448c8>
  preload_app: False
  default_proc_name: app:app
  limit_request_line: 4094
  errorlog: -
  daemon: False
  pythonpath: None
  certfile: None
  bind: ['127.0.0.1:8000']
  when_ready: <function WhenReady.when_ready at 0x7fda105398c8>
  worker_class: gevent
  raw_env: []
  graceful_timeout: 30
  on_starting: <function OnStarting.on_starting at 0x7fda10539598>
  max_requests: 0
  backlog: 2048
  proxy_allow_ips: ['127.0.0.1']
  django_settings: None
  config: gun.conf
  user: 500
  access_log_format: %(h)s %(l)s %(u)s %(t)s "%(r)s" %(s)s %(b)s "%(f)s" "%(a)s"
  limit_request_fields: 100
  worker_abort: <function WorkerAbort.worker_abort at 0x7fda10544158>
[2016-09-10 23:07:55 +0800] [2641] [INFO] Starting gunicorn 19.6.0
[2016-09-10 23:07:55 +0800] [2641] [DEBUG] Arbiter booted
[2016-09-10 23:07:55 +0800] [2641] [INFO] Listening at: http://127.0.0.1:8000 (2641)
[2016-09-10 23:07:55 +0800] [2641] [INFO] Using worker: gevent
[2016-09-10 23:07:55 +0800] [2644] [INFO] Booting worker with pid: 2644
[2016-09-10 23:07:55 +0800] [2646] [INFO] Booting worker with pid: 2646
[2016-09-10 23:07:55 +0800] [2647] [INFO] Booting worker with pid: 2647
[2016-09-10 23:07:55 +0800] [2648] [INFO] Booting worker with pid: 2648
[2016-09-10 23:07:55 +0800] [2641] [DEBUG] 4 workers

命令的app:app中第一個(gè)為你定義Flask應(yīng)用實(shí)例的py文件修赞,這里不要加入后綴,例如:

#app.py
from flask import Flask
app = Flask(__name__)

@app.route("/")
def index():
    return "你已經(jīng)成功了仅偎。"

if __name__ == "__main__":
    app.run()

第二個(gè)app是你在該文件中實(shí)例化的Flask應(yīng)用的變量名,然后打開你本地電腦的瀏覽器雳殊,訪問http:\你的服務(wù)器ip:8000,
你就可以看到你的Flask應(yīng)用橘沥。

7.另外啟動(dòng)一個(gè)終端,安裝nginx并配置(之后的操作不需要再虛擬環(huán)境中進(jìn)行)
sudo apt-get install nginx

打開/etc/nginx/sites-enabled/夯秃,備份default文件后,在default加入以下內(nèi)容:

    server {
        listen   80;
        server_name  公網(wǎng)IP或者你已經(jīng)解析的域名;
        location / {
            proxy_pass http://127.0.0.1:8000;
            proxy_redirect off;
            proxy_set_header Host $host:80;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

然后輸入以下命令檢查nginx配置文件是否有錯(cuò):

sudo nginx -t

#成功會(huì)出現(xiàn)類似的提示:
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

#出錯(cuò)請(qǐng)檢查你的配置

啟動(dòng)nginx

sudo service nginx start
sudo nginx -s reload

可以通過以下命令查看nginx狀態(tài)

service nginx status

打開瀏覽器座咆,訪問http://你的服務(wù)器ip,就可以看到你的Flask應(yīng)用界面仓洼。


項(xiàng)目目錄結(jié)構(gòu)

app/
 |----app.py
 |----manage.py
 |----requirements.txt
 |----data.sqlite
 |----gun.conf
 |----static
 |----templates
 |----venv

這個(gè)教程只是初步用來快速部署介陶,之后會(huì)深入研究下uwsgi和nginx部署.
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市色建,隨后出現(xiàn)的幾起案子哺呜,更是在濱河造成了極大的恐慌,老刑警劉巖箕戳,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件某残,死亡現(xiàn)場(chǎng)離奇詭異国撵,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)玻墅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門介牙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人澳厢,你說我怎么就攤上這事环础。” “怎么了剩拢?”我有些...
    開封第一講書人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵线得,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我徐伐,道長(zhǎng)框都,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任呵晨,我火速辦了婚禮,結(jié)果婚禮上熬尺,老公的妹妹穿的比我還像新娘摸屠。我一直安慰自己,他們只是感情好粱哼,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開白布季二。 她就那樣靜靜地躺著,像睡著了一般揭措。 火紅的嫁衣襯著肌膚如雪胯舷。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,301評(píng)論 1 301
  • 那天绊含,我揣著相機(jī)與錄音桑嘶,去河邊找鬼。 笑死躬充,一個(gè)胖子當(dāng)著我的面吹牛逃顶,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播充甚,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼以政,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了伴找?” 一聲冷哼從身側(cè)響起盈蛮,我...
    開封第一講書人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎技矮,沒想到半個(gè)月后抖誉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體殊轴,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年寸五,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了梳凛。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡梳杏,死狀恐怖韧拒,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情十性,我是刑警寧澤叛溢,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站劲适,受9級(jí)特大地震影響楷掉,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜霞势,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一烹植、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧愕贡,春花似錦草雕、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至憨琳,卻和暖如春诫钓,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背篙螟。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工菌湃, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人遍略。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓慢味,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親墅冷。 傳聞我的和親對(duì)象是個(gè)殘疾皇子纯路,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354

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