1. ホーム
  2. python

[解決済み] PythonのWebフレームワーク、WSGIとCGIはどのように組み合わされるか

2022-04-28 13:13:30

質問

私は ブルーホスト アカウントで、PythonスクリプトをCGIとして実行することができます。最もシンプルなCGIだと思います。 .htaccess :

Options +ExecCGI
AddType text/html py
AddHandler cgi-script .py

Pythonを使ったWebプログラミングについて調べるたびに、WSGIやほとんどのフレームワークがそれを使っていることをよく耳にします。しかし、私はそれがどのように組み合わされるのか理解できません。特に、私のWebサーバーが与えられたもの(ホストのマシンで動作するApache)であり、私が本当に弄れるものではない場合(ただし .htaccess コマンドを使用します)。

どのように WSGI とか、CGIとか、フレームワークとか、全部つながっているんですか?ウェブフレームワーク(たとえば web.py または CherryPy ) を私の基本的なCGI設定に加えることができますか?WSGIサポートをインストールするには?

どのように解決するのですか?

WSGI、CGI、フレームワークはどのようにつながっているのですか?

Apacheは80番ポートでリッスンします。 HTTP リクエストを受け取ります。 そして、応答する方法を見つけるためにリクエストを解析します。 Apache は応答するための多くの選択肢を持っています。 応答する一つの方法は、CGI を使ってスクリプトを実行することです。 もう一つの応答方法は、単にファイルを提供することです。

CGI の場合、Apache は環境を整え、CGI プロトコルを介してスクリプトを呼び出します。 これは標準的な Unix の Fork/Exec の状況です -- CGI サブプロセスはソケットと標準出力を含む OS 環境を受け継ぎます。 CGI サブプロセスは応答を書き、それは Apache に返され、Apache はこの応答をブラウザに送ります。

CGIは原始的で煩わしい。 ほとんどの場合、リクエストごとにサブプロセスをフォークし、サブプロセスはレスポンスの終了を示すために stdout と stderr を終了するか閉じなければならないからです。

WSGIは、CGIのデザインパターンをベースにしたインターフェースです。 それは必ずしも CGI ではない -- リクエストごとにサブプロセスを fork する必要はない。 それは CGI であることができますが、そうである必要はありません。

WSGI は、いくつかの重要な方法で CGI デザインパターンを追加しています。 それは、あなたのために HTTP リクエストヘッダを解析し、それを環境に追加します。 POST 指向の入力は、環境の中でファイルのようなオブジェクトとして提供されます。 また、レスポンスを作成する関数も提供し、多くの書式の詳細からあなたを解放します。

基本的なCGIの構成でWebフレームワーク(web.pyやcherrypyなど)を実行したい場合、何を知り、インストールし、何をする必要がありますか?

サブプロセスをフォークすると高くつくことを思い出してください。 これを回避する方法は2つあります。

  1. エンベデッド mod_wsgi または mod_python はPythonをApacheの中に埋め込みます。 Apache は Django アプリケーションを直接実行します。

  2. デーモン mod_wsgi または mod_fastcgi を使うと、WSGI プロトコルを使って Apache が別のデーモン (または "long-running process") と対話することができるようになります。 長時間稼働する Django プロセスを起動し、このプロセスと通信するために Apache の mod_fastcgi を設定します。

なお mod_wsgi は、組み込みとデーモン、どちらのモードでも動作します。

mod_fastcgi について読むと、Django では フラップ を使用して、mod_fastcgi が提供する情報から WSGI 互換のインターフェイスを作成します。 パイプラインはこのように動作します。

Apache -> mod_fastcgi -> FLUP (via FastCGI protocol) -> Django (via WSGI protocol)

Django には、様々なインターフェースのためにいくつかの "django.core.handlers" があります。

mod_fastcgi に対して、Django は manage.py runfcgi で、FLUPとハンドラを統合しています。

mod_wsgi の場合は、コアハンドラがあります。

WSGI サポートをインストールするには?

以下の手順に従ってください。

https://code.google.com/archive/p/modwsgi/wikis/IntegrationWithDjango.wiki

背景はこちらをご覧ください。

http://docs.djangoproject.com/en/dev/howto/deployment/#howto-deployment-index