ブートストラップ ¶
ブートストラップとは、アプリケーションが、入ってくるリクエストの解決と処理を開始する前に、環境を準備する過程を指すものです。 ブートストラップは二つの場所、すなわち、エントリ・スクリプト と アプリケーションで行われます。
エントリ・スクリプト では、さまざまなライブラリのためのクラス・オートローダが登録されます。
この中には、Composer の autoload.php
によるオートローダと、Yii の Yii
クラス・ファイルによるオートローダが含まれます。
エントリ・スクリプトは、次に、アプリケーションの 構成情報 をロードして、
アプリケーション のインスタンスを作成します。
アプリケーションのコンストラクタでは、次のようなブートストラップの仕事が行われます。
- preInit() が呼ばれます。 このメソッドは、いくつかの優先度の高いアプリケーション・プロパティ、例えば yii\base\Application::basePath などを構成します。
- yii\base\Application::errorHandler を登録します。
- 与えられたアプリケーションの構成情報を使って、アプリケーションのプロパティを初期化します。
- init() が呼ばれます。
そして
init()
が bootstrap() を呼んで、ブートストラップ・コンポーネントを走らせます。- エクステンション・マニフェスト・ファイル
vendor/yiisoft/extensions.php
をインクルードします。 - エクステンションによって宣言された ブートストラップ・コンポーネント を作成して実行します。
- アプリケーションの bootstrap プロパティ に宣言されている アプリケーション・コンポーネント および/または モジュール を作成して実行します。
- エクステンション・マニフェスト・ファイル
ブートストラップの仕事は 全て のリクエストを処理する前に、毎回しなければなりませんので、 この過程を軽いものに保って可能な限り最適化することは非常に重要なことです。
あまりに多くのブートストラップ・コンポーネントを登録しないように努めてください。 ブートストラップ・コンポーネントが必要になるのは、リクエスト処理のライフサイクル全体に関与する必要がある場合だけです。 例えば、モジュールが追加の URL 解析規則を登録する必要がある場合は、モジュールを bootstrap プロパティ のリストに挙げなければなりません。 なぜなら、URL 規則を使ってリクエストが解決される前に、新しい URL 規則を有効にしなければならないからです。
本番運用モードにおいては、PHP OPCache や APC など、バイトコード・キャッシュを有効にして、 PHP ファイルをインクルードして解析するのに要する時間を最小化してください。
大規模なアプリケーションには、多数の小さな構成情報ファイルに分割された、非常に複雑なアプリケーション 構成情報 を持つものがあります。 そのような場合には、構成情報配列全体をキャッシュするという方法を考慮して下さい。 エントリ・スクリプトでアプリケーションのインスタンスを作成する前に構成情報をロードするときには、 配列全体を直接にキャッシュからロードするのです。