ThinkPHP フレームワークで使用される fastcgi_finish_request と trait の機能
#”この記事では、コントローラーの最終実行プロセスと使用される 2 つの高度な属性について簡単に説明します。1 つは fastcgi_finish_request メソッドの賢い使用法で、もう 1 つは特性機能です。スーパークラス 概念はある程度理解できたので、一緒に分析しましょう。”#1. 端末へのデータ出力方法
##コントローラー内のメソッドが実行されると、Appクラスのrunメソッドに応答データが送信され、ここまでで実行が完了します。
ここのデータが最終的にどこに返されるかについて少し混乱していますか?アプリケーションの実行
コードのこの部分Container::get('app')
これは、次のインスタンスを返すことをご存知でしょう。アプリクラス。
次に、App クラスを介して run メソッドを実行すると、前述のすべてが得られます。
下の写真は、Kaka が作成した腰の真ん中からのマインド マップです。前部分は存在せず、後ろの知識ポイントはすべてこのマインド マップに書き込まれます。
runメソッド実行後、実行されますContainer::get('app' )- >run()->send()
send メソッド、send メソッドが App クラスで実行されると考える人はどのくらいいるでしょうか。
実際にはそうではありません。以前にコントローラー メソッドを実行した後に返された応答結果を思い出してください。
あまり大まかに見なければ、これが Response のオブジェクト インスタンスであることがわかります。
したがって、send メソッドは応答クラスで実行されます。
最初に他のものを見るのではなく、最初にこのコード行を見てください$this-> ;app['hook']
、どこで実行されるかわかりましたか?
このフォームは、以前に解析された ArrayAccess クラスである配列フォームにアクセスすることで、オブジェクトのプロパティにアクセスします。アクセスした属性が存在しない場合は、offsetGetを実行し、マジックメソッド__getを実行し、最後にmakeメソッドでインスタンスを返すという一連の操作がコンテナ内で行われます。
このコード行が具体的に何を監視しているのかについては分析しません。
次に、出力データを処理するコード行を確認する必要があります。$data = $this->getContent();
このメソッドの機能は次のとおりです。 Data を渡すには、このクラスの content 属性に割り当てられます。
実際、この出力データの取得方法ですが、最初のKakaの丸で囲ったところを見てください。あまり必要性を感じません。
データの処理がまったく行われておらず、ただ返されていることがわかります。したがって、このフレームワークには良い点と悪い点があります。読んだ場合のみわかります。読まないと間違っています。普段使っているツールについては何も知りません。
次のステップは、トレース デバッグ インジェクションです。これは、構成ファイルを通じて構成され、デバッグを呼び出すことによって実装されます。ここでは詳しく説明しません。
続いてキャッシングの判定ですが、キャッシングについては次の記事で別途説明するのでこれもパスします。
次のステップは、応答ヘッダーを設定し、HTTP ヘッダーが送信されたかどうかを検出することです。これは非常に重要ですが、あまり公開されることのない知識ポイントでもあります。
headers_sent(): HTTP ヘッダーが送信されたかどうかを確認します -
http_response_code(): 応答の HTTP ステータス コードを取得/設定します header: この関数は、生の HTTP ヘッダーをクライアントに送信します。
$this->sendData($data);
最後にデータを端末に出力します。これはエコー処理です。
ここでの戦いは終わりましたが、以下に非常に重要な知識ポイントがまだ残っており、カカがそれについて再度言及して説明します。
2. fastcgi_finish_request メソッドの賢い使い方
前で Container::get('app')-> を渡しました。 Section ;run()->send();
レスポンスクラスでsendメソッドが実行され、データが出力されます。
しかし、データを出力した後、メソッド fastcgi_finish_request();
も実行されます。コメントは、ページの応答を改善するためです。謎を詳しく見てみましょう。
PHP 公式 Web サイトのこの文章を参照してください。
スクリプトは、fastcgi_finish_request() の後も FPM プロセスを占有します。そのため、長時間実行されるタスクに過度に使用すると、午後までのすべての FPM スレッドを占有する可能性があります。 .max_children。これにより、Web サーバーでゲートウェイ エラーが発生します。
fastcgi_finish_request() の後、スクリプトは引き続き FPM プロセスを占有します。そのため、長時間実行されるタスクでこれを過度に使用すると、すべての FPM スレッドが pm.max_children まで拘束される可能性があります。これにより、Web サーバーでゲートウェイ エラーが発生します。
したがって、この方法を十分に理解していない場合は、自分のプロジェクトでこの方法を使用しないでください。
次に、Kaka はケースを使用してこのメソッドの使用法をデモンストレーションします。これは単なるデモンストレーションです。プロジェクトで使用する必要がある場合は、ドキュメントをよく読み、問題点に注意してください。
ケースデモンストレーション
この会社はユーザーに通知を送信する必要があるビジネスを持っていますが、送信時間が長すぎるため、非常に時間がかかり、問題が発生する可能性があります。数十秒かかりますが、さらに深刻な問題としては、ブラウザ接続のタイムアウトが直接発生する可能性があります。
問題の 1 つはユーザー エクスペリエンスであり、ユーザーの待ち時間の処理は当然ながら良くありません。
上記 2 つの問題を解決するには、今日説明した fastcgi_finish_request
が役に立ちます。 #########理解する######
この関数の実際の理解は、ブラウザに応答を送信することです。ユーザーの待ち時間は大幅に短縮されますが、PHP プロセスは引き続き実行されます。
これにより、私たちがよく話題にする非同期実行と似た目的が達成されます。
直感的には、メールの送信には 10 秒かかるかもしれませんが、ユーザーはそれに気づきません。ユーザーがクリックしてメールを送信すると、送信が成功したことを示すブラウザーの応答が直接返されます。終了すると、ユーザーは他のことを行い、バックグラウンド プロセスが続行され、電子メールの送信タスクを実行します。
#ケース
<span style="display: block; background: url(" https: no-repeat rgb height: width: margin-bottom: border-radius:></span><code class="hljs" style="overflow-x: auto; padding: 15px 16px 16px; color: rgb(171, 178, 191); display: -webkit-box; font-family: " operator mono consolas monaco menlo monospace font-size: background: rgb border-radius:><span class="hljs-meta" style="color: rgb(97, 174, 238); line-height: 26px;"><?php </span><br><span class="hljs-comment" style="color: rgb(92, 99, 112); font-style: italic; line-height: 26px;">/**<br> * 设置超时时间,变成不限制<br> *<br> */</span><br>set_time_limit(<span class="hljs-number" style="color: rgb(209, 154, 102); line-height: 26px;">0</span>);<br><br><span class="hljs-comment" style="color: rgb(92, 99, 112); font-style: italic; line-height: 26px;">/**<br> * 本函数模拟非常耗时的任务,执行完毕需要5秒的时间<br> */</span><br><span class="hljs-function" style="line-height: 26px;"><span class="hljs-keyword" style="color: rgb(198, 120, 221); line-height: 26px;">function</span> <span class="hljs-title" style="color: rgb(97, 174, 238); line-height: 26px;">writeFile</span><span class="hljs-params" style="line-height: 26px;">()</span><br></span>{<br> $path = <span class="hljs-string" style="color: rgb(152, 195, 121); line-height: 26px;">'D:/phpstudy_pro/WWW/kaka.txt'</span>;<br> file_put_contents($path,<span class="hljs-string" style="color: rgb(152, 195, 121); line-height: 26px;">'程序运行开始'</span> . PHP_EOL,FILE_APPEND);<br> <span class="hljs-keyword" style="color: rgb(198, 120, 221); line-height: 26px;">for</span>($i =<span class="hljs-number" style="color: rgb(209, 154, 102); line-height: 26px;">0</span>;$i 5</span>;$i++) {<br> file_put_contents($path,time() . PHP_EOL,FILE_APPEND);<br> sleep(<span class="hljs-number" style="color: rgb(209, 154, 102); line-height: 26px;">1</span>);<br> }<br><br> file_put_contents($path,<span class="hljs-string" style="color: rgb(152, 195, 121); line-height: 26px;">'程序运行结束'</span> . PHP_EOL,FILE_APPEND);<br><br>}<br><br><span class="hljs-comment" style="color: rgb(92, 99, 112); font-style: italic; line-height: 26px;">/**<br> * 输出文字标记,任务开始<br> */</span><br><span class="hljs-keyword" style="color: rgb(198, 120, 221); line-height: 26px;">echo</span>(<span class="hljs-string" style="color: rgb(152, 195, 121); line-height: 26px;">'任务开始'</span>);<br><br><span class="hljs-comment" style="color: rgb(92, 99, 112); font-style: italic; line-height: 26px;">/**<br> * 后台执行非常耗时的任务<br> */</span><br>register_shutdown_function(writeFile);<br><br><span class="hljs-comment" style="color: rgb(92, 99, 112); font-style: italic; line-height: 26px;">/**<br> * 立即发送请求<br> */</span><br>fastcgi_finish_request();<br><br><br><br></code>
上記のデモの後、応答は非常に高速になり、ブラウザーが応答した後も、バックグラウンド プログラムが毎秒タイムスタンプを実行します。
上記は、fastcgi_finish_request
メソッドの簡単な紹介です。興味があれば、簡単に試してみると、小さな秘密をよりよく理解できるようになります。
3. 特性の説明
カカは 2 年前にこの特性を分析するべきでした、特性
はよくあるものですスーパークラスと呼ばれる。
この機能は PHP5.4 でのみ追加されたもので、頻繁に使用されるインターフェイスやクラスではありません。
この機能は、単一継承しかできないという PHP の大きな弱点を解決するものです。ただし、多重継承とは言えません。厳密に言うと、単なる多重継承に似た機能です。 。
次に事例を紹介します。
テスト ファイル 1 を作成し、対応するクラス名を返します。
test1 ファイルを作成し、対応するクラス名を返します
#対応するスーパー クラス ファイルをコントローラーに導入します。
上の図から結果にアクセスすると、Test スーパー クラス ファイルを返すメソッドが同じであることがわかります。 , ただし、このコントローラーは同じですコントローラーコントローラーもそれをベースにしていますこれは記事の冒頭で述べたスーパークラスが多重継承の機能を実装しているだけのものです。
しかし、ここで問題が発生します。以下のエラー メッセージを参照してください。
前の問題を解決する前に、まずこの問題の原因を理解する必要があります。 このエラーの理由は、参照されている 2 つの特性に同じ名前の hello 関数があり、競合が発生しているためです。 しかし、メソッド名を手動で変更するのは依然として非常に便利なので、この状況は日常の開発では回避できますが、ここで Kaka がこの問題の解決方法を教えます。 1 つ目は、あるトレイトで hello メソッドを使用して、別のトレイトの同じ名前のメソッドを上書きすることです。2 つのメソッドの内容は一貫しているため、ここでは上書きする代わりに直接選択します。 2 つ目は、競合が起こらないようにエイリアスとして使用することです。 as キーワードには、メソッドのアクセス制御を変更するという別の用途もあります。 上の図を変更した後、再度アクセスして、返される結果を確認してください。 次に、この時点で一部のパートナーから質問があるでしょう。つまり、ケースの印刷結果は常に Test クラスのメソッドであり、Test1 のメソッドです。クラスは印刷されていません。 アクセス方法!見てみましょう。 上図からわかるように、アクセス方法が alias に変更されています。アクセスを制御してから、訪問結果を確認してください。 コントローラーのソース コード分析は以上です。Kaka は、ソース コードを通じてコントローラーをインスタンス化する方法を分析します。 ArrayAccess とマジック メソッドの呼び出し関係についても再度説明しますが、この問題を考えるには自分なりの考え方が必要です。 コントローラーなどにアクセスした後のデータの応答方法です。 ソースコード内での fastcgi_finish_request メソッドの賢い使い方についても学びましたが、この関数を使用する場合は、Kaka について述べた 2 つの点に注意する必要があります。 最後に、スーパークラスの簡単なケースの説明があります。 学習の継続、ブログの継続、共有の継続は、カカがそのキャリア以来常に支持してきた信念です。巨大なインターネット上のカカの記事がそうであることを願っています」少し持ってきてください助けてください。私はカカです。また今度。
概要
「
以上がThinkPHP フレームワークで使用される fastcgi_finish_request と trait の機能の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











ThinkPHP プロジェクトを実行するには、Composer をインストールし、Composer を使用してプロジェクトを作成し、プロジェクト ディレクトリに入り、php bin/consoleserve を実行し、http://localhost:8000 にアクセスしてようこそページを表示する必要があります。

ThinkPHP には、さまざまな PHP バージョン向けに設計された複数のバージョンがあります。メジャー バージョンには 3.2、5.0、5.1、および 6.0 が含まれますが、マイナー バージョンはバグを修正し、新機能を提供するために使用されます。最新の安定バージョンは ThinkPHP 6.0.16 です。バージョンを選択するときは、PHP バージョン、機能要件、コミュニティ サポートを考慮してください。最高のパフォーマンスとサポートを得るには、最新の安定バージョンを使用することをお勧めします。

ThinkPHP フレームワークをローカルで実行する手順: ThinkPHP フレームワークをローカル ディレクトリにダウンロードして解凍します。 ThinkPHP ルート ディレクトリを指す仮想ホスト (オプション) を作成します。データベース接続パラメータを構成します。 Webサーバーを起動します。 ThinkPHP アプリケーションを初期化します。 ThinkPHP アプリケーションの URL にアクセスして実行します。

「開発に関する提案: ThinkPHP フレームワークを使用して非同期タスクを実装する方法」 インターネット技術の急速な発展に伴い、Web アプリケーションには、多数の同時リクエストと複雑なビジネス ロジックを処理するための要件がますます高まっています。システムのパフォーマンスとユーザー エクスペリエンスを向上させるために、開発者は多くの場合、電子メールの送信、ファイルのアップロードの処理、レポートの生成など、時間のかかる操作を実行するために非同期タスクの使用を検討します。 PHP の分野では、人気のある開発フレームワークとして ThinkPHP フレームワークが、非同期タスクを実装するための便利な方法をいくつか提供しています。

Laravel フレームワークと ThinkPHP フレームワークのパフォーマンスの比較: ThinkPHP は、最適化とキャッシュに重点を置いて、一般に Laravel よりもパフォーマンスが優れています。 Laravel は優れたパフォーマンスを発揮しますが、複雑なアプリケーションの場合は、ThinkPHP の方が適している可能性があります。

ThinkPHP のインストール手順: PHP、Composer、および MySQL 環境を準備します。 Composer を使用してプロジェクトを作成します。 ThinkPHP フレームワークと依存関係をインストールします。データベース接続を構成します。アプリケーションコードを生成します。アプリケーションを起動し、http://localhost:8000 にアクセスします。

ThinkPHP は、キャッシュ メカニズム、コードの最適化、並列処理、データベースの最適化などの利点を備えた高性能 PHP フレームワークです。公式パフォーマンステストでは、1秒あたり10,000以上のリクエストを処理できることが示されており、実際のアプリケーションではJD.comやCtripなどの大規模なWebサイトやエンタープライズシステムで広く使用されています。

開発の提案: API 開発に ThinkPHP フレームワークを使用する方法 インターネットの継続的な発展に伴い、API (アプリケーション プログラミング インターフェイス) の重要性がますます高まっています。 API は、異なるアプリケーション間の通信の橋渡しとなるもので、データの共有や関数の呼び出しなどを実現し、開発者に比較的簡単かつ迅速な開発手法を提供します。優れた PHP 開発フレームワークである ThinkPHP フレームワークは、効率的でスケーラブルで使いやすいです。
