欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用FastCGI部署Python的Django應用的教程

 更新時間:2015年07月22日 11:12:26   投稿:goldensun  
這篇文章主要介紹了使用FastCGI部署Python的Django應用的教程,FastCGI也是被最廣泛的應用于Python框架和服務器連接的模塊,需要的朋友可以參考下

作為一個mod_python模塊的替代,你可以考慮使用mod_wsgi模塊,此模塊開發(fā)的時間比mod_python的開發(fā)時間離現(xiàn)在更近一些,在Django社區(qū)已有一些使用。 一個完整的概述超出了本書的范圍,你可以從官方的Django文檔查看到更多的信息。
使用FastCGI部署Django應用

盡管將使用Apache和mod_python搭建Django環(huán)境是最具魯棒性的,但在很多虛擬主機平臺上,往往只能使用FastCGI

此外,在很多情況下,F(xiàn)astCGI能夠提供比mod_python更為優(yōu)越的安全性和效能。 針對小型站點,相對于Apache來說FastCGI更為輕量級。
FastCGI 簡介

如何能夠由一個外部的應用程序很有效解釋WEB 服務器上的動態(tài)頁面請求呢? 答案就是使用FastCGI! 它的工作步驟簡單的描述起來是這樣的:

和mod_python一樣,F(xiàn)astCGI也是駐留在內(nèi)存里為客戶請求返回動態(tài)信息,而且也免掉了像傳統(tǒng)的CGI一樣啟動進程時候的時間花銷。 但于mod_python不同之處是它并不是作為模塊運行在web服務器同一進程內(nèi)的,而是有自己的獨立進程。

為什么要在一個獨立的進程中運行代碼?

在以傳統(tǒng)的方式的幾種以mod_*方式嵌入到Apache的腳本語言中(常見的例如: PHP,Python/mod_python和Perl/mod_perl),他們都是以apache擴展模塊的方式將自身嵌入到Apache進程中的。

每一個Apache進程都是一個Apache引擎的副本,它完全包括了所有Apache所具有的一切功能特性(哪怕是對Django毫無好處的東西也一并加載進來)。 而FastCGI就不一樣了,它僅僅把Python和Django等必備的東東弄到內(nèi)存中。

依據(jù)FastCGI自身的特點可以看到,F(xiàn)astCGI進程可以與Web服務器的進程分別運行在不同的用戶權(quán)限下。 對于一個多人共用的系統(tǒng)來說,這個特性對于安全性是非常有好處的,因為你可以安全的于別人分享和重用代碼了。

如果你希望你的Django以FastCGI的方式運行,那么你還必須安裝 flup 這個Python庫,這個庫就是用于處理FastCGI的。 很多用戶都抱怨 flup 的發(fā)布版太久了,老是不更新。 其實不是的,他們一直在努力的工作著,這是沒有放出來而已。
運行你的 FastCGI 服務器

FastCGI是以客戶機/服務器方式運行的,并且在很多情況下,你得自己去啟動FastCGI的服務進程。 Web服務器(例如Apache,lighttpd等等)僅僅在有動態(tài)頁面訪問請求的時候才會去與你的Django-FastCGI進程交互。 因為Fast-CGI已經(jīng)一直駐留在內(nèi)存里面了的,所以它響應起來也是很快的。

記錄

在虛擬主機上使用的話,你可能會被強制的使用Web server-managed FastCGI進程。 在這樣的情況下,請參閱下面的“在Apache共享主機里運行Django”這一小節(jié)。

web服務器有兩種方式于FastCGI進程交互: 使用Unix domain socket(在win32里面是 命名管道 )或者使用TCP socket.具體使用哪一個,那就根據(jù)你的偏好而定了,但是TCP socket弄不好的話往往會發(fā)生一些權(quán)限上的問題。 What you choose is a manner of preference; a TCP socket is usually easier due to permissions issues.

開始你的服務器項目,首先進入你的項目目錄下(你的 manage.py 文件所在之處),然后使用 manage.py runfcgi 命令:

./manage.py runfcgi [options]

想了解如何使用 runfcgi ,輸入 manage.py runfcgi help 命令。

你可以指定 socket 或者同時指定 host 和 port 。當你要創(chuàng)建Web服務器時,你只需要將服務器指向當你在啟動FastCGI服務器時確定的socket或者host/port。

范例:

    在TCP端口上運行一個線程服務器:

./manage.py runfcgi method=threaded host=127.0.0.1 port=3033

    在Unix socket上運行prefork服務器:

./manage.py runfcgi method=prefork socket=/home/user/mysite.sock pidfile=django.pid

    啟動,但不作為后臺進程(在調(diào)試時比較方便):

./manage.py runfcgi daemonize=false socket=/tmp/mysite.sock

停止FastCGI的行程

如果你的FastCGI是在前臺運行的,那么只需按Ctrl+C就可以很方便的停止這個進程了。 但如果是在后臺運行的話,你就要使用Unix的 kill 命令來殺掉它。 然而,當你正在處理后臺進程時,你會需要將其付諸于Unix kill的命令

如果你在 manage.py runfcgi 中指定了 pidfile 這個選項,那么你可以這樣來殺死這個FastCGI后臺進程:

kill `cat $PIDFILE`

$PIDFILE 就是你在 pidfile 指定的那個。

你可以使用下面這個腳本方便地重啟Unix里的FastCGI守護進程:

#!/bin/bash

# Replace these three settings.
PROJDIR="/home/user/myproject"
PIDFILE="$PROJDIR/mysite.pid"
SOCKET="$PROJDIR/mysite.sock"

cd $PROJDIR
if [ -f $PIDFILE ]; then
 kill `cat -- $PIDFILE`
 rm -f -- $PIDFILE
fi
exec /usr/bin/env -  PYTHONPATH="../python:.."  ./manage.py runfcgi socket=$SOCKET pidfile=$PIDFIL


相關文章

最新評論