skillup

技術ブログ

PHP サーバー・ネットワーク

FastCGIに関して

投稿日:2016年12月14日 更新日:

nginxについて学習してきましたが、今回はphp-fpmについてです。

そもそもの構成

以前、nginxにも書きましたが、nginx自体はPHPを処理することはできないので、代わりにPHPを処理するソフトウェアが必要になってきます。

ざっくり示すと下記のような流れになるようです。

  1. nginxがリクエストをうけとる
  2. nginx→php-fpmに処理を流す
  3. php-fpmが処理をし、nginxに処理を変える
  4. nginxからユーザーにレスポンスを返す

KoaでWeb開発: Koaの検証を通じてミドルウェアの概念を理解する

PHPをApacheで処理する場合、mod_phpを用いて動作させるのが一般的でしたが、最近はphp-fpmが注目されています。

php-fpmはFastCGI形式で動作するPHPサーバーで、従来のApacheに任せたプロセス管理とはことなり、独自のプロセス管理を実装しています。PHP5.3.3以降はPHP自体に標準搭載されているようです。

CGIのメカニズム

そもそものWebサーバーの目的はクライアントからの要求に対して記憶装置に格納されているファイルを送り返すことです。

最初は静的なファイルが中心でしたが、現在では動的なファイルのやりとりをすることが一般的になりました。こういった動的なファイルの処理を行うために考え出されたプロトコルがCGI(Common Gate Interface)です。

しかし、下記のような問題点もありました。

  • 個々の要求ごとに別々のプロセスが起動されるため、メモリや各種コンテキスト情報は、要求ごとに失われてします。
  • プロセスの起動により、システムのリソースを大きく消費し、サーバーを圧迫する
  • Webサーバーとアプリケーションが別々のコンピューターで実行されるアーキテクチャはちょいムズイ

FastCGI

上記のような問題があるため、FastCGIという仕組みが考え出されました。

主に下記のようなメリットがあります。

  • 要求ごとにプロセスを起動するのではなく、複数の要求を処理することのできる永続プロセスを使う
  • Webサーバーとアプリケーションをソケット通信させることで、ネットワーク上の2つのコンピューター上で実行できる
  • ソケットベースのプロトコルなため、任意のプログラミング言語で任意のプラットフォーム上に実装できる

Nginx入門 P185~205

nginx と PHP-FPM の仕組みをちゃんと理解しながら PHP の実行環境を構築する

ネットワークがらみになるとようわからん・・・

この仕組みを通してnginxはPHPを処理しています。phpを直接処理するのはphp-fpmになることが多いでしょう。
php-fpmについて

nginxでの設定に関して

まずnginxでphp-fpmが記載される場合どのように書かれるかを見てみましょう。

一般的に使われるディレクティブを見ていきましょう。

fastcgi_pass

FastCGIに処理が渡されるポートを記します。

phpの場合は 127.0.0.1:9000(TCP) か unix:/var/run/php-fpm/php-fpm.sock(unixソケット通信) のどちらかが選択されることが多いようです。
違いは下記参照
調べなきゃ寝れない!と調べたら余計に寝れなくなったソケットの話

TCPソケット通信で処理を行う場合は fastcgi host:port(今回はこのケース)のように書かれることが一般的です。

fastcgi_index

FastCGIサーバーは自動インデックス付与をサポートしていない。そこで、要求されたURIの末尾が/ならNginxがfastcgi_indexの値を末尾にサポートする

fastcgi_param

FastCGIに渡される要求をkey=value形式で設定します。全てのFASTCGI要求で必ずSCRIPT_NAMEとQUERY_STRINGの2つの引数が必要になります。

SCRIPT_FILENAMEは直接実行されるプログラムです。もし値を見たい場合は$document_rootやfastcgi_script_nameをデバッグしてみてみるとよいでしょう。
(例 $document_root = 'var/www/html/'   $fast_cgi_script_name ='public/sample.php' )

-PHP, サーバー・ネットワーク
-,

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

関連記事

no image

herokuでのmb_convert_encoding

herokuにあげたアプリを起動しようとしたらmb_convert_encodingでundefinedエラーが帰ってきました。 どうやらマルチバイトのライブラリがないエラーのようですね。 といいつつ …

no image

CakePHP3 日付ライブラリ(Time)について

CakePHPには標準でいろいろなライブラリが入っていますが、日付ではCake\I18n\Timeというライブラリが入っています。 内部では3.2より前のバージョンではCarbonだったようですが、そ …

no image

Azure環境へのデプロイ

今までクラウドのインフラ環境というとほとんどがAWSだったのですが、C#+SQLServerの案件に携わっていることもあり、Azureを使うことに・・ 自学で簡単なアプリを作ってデプロイしたんですが、 …

no image

nginxのSSL通信や認証、ログに関して

今回はnginxでSSL通信をする際の注意点など。といっても、それほど難しくないようでSSL通信をするには主に2つだけです。 SSLを利用することを明示 サーバー証明書と秘密鍵を指示する またngin …

no image

cakeでの多対多を含んだ検索に関して

cakeを使って多対多を実現する方法はこのエントリーで紹介しました。 が、多対多を含む検索をする場合は一筋縄ではいかず結構面倒くさいです。 通常cakeで検索を行う場合、 ‘conditi …

アーカイブ