このチュートリアルでは、OpenResty XRay を使用して PHP アプリケーションのプログラム例外をオンラインで分析する方法を紹介します。OpenResty XRay は、PHP のオンラインプロセスにおけるコード例外を検出および分析することができます。これには、プロセスのクラッシュを引き起こさないキャッチされた例外も含まれます。注目すべきは、アプリケーション自体がすでにキャッチして処理した例外でさえ、OpenResty XRay が検出できることです。これにより、問題診断の能力が大幅に向上します。これらのコードパスは、OpenResty XRay が PHP 言語レベルの例外フレームグラフを自動的に分析および解釈することで得られます。これにより、パフォーマンスへの影響を最小限に抑えます。したがって、OpenResty XRay は、パフォーマンスのオーバーヘッドと遅延に敏感な本番環境に非常に適しています。

Guided Analysis 機能を使用して PHP アプリケーションのプログラム例外を分析する

まず、ps コマンドを実行して、PHP アプリケーションプロセスの完全なコマンドラインを確認します。

Screenshot

この php バイナリ実行ファイルが Linux ディストリビューションに付属していることがわかります。

Screenshot

OpenResty XRay を使用して、この未変更のプロセスを検査しましょう。内部で投げられる PHP 例外をリアルタイムで分析することができます。

OpenResty XRay の Web コンソールに移動します。

Screenshot

現在分析中のマシンが正しいことを確認します。

Screenshot

「Guided Analysis」ページに入ります。

Screenshot

ここでは、システムが分析できる異なるタイプの問題を見ることができます。

Screenshot

「Errors & exceptions」を選択します。

Screenshot

「Next」をクリックします。

Screenshot

先ほどの PHP アプリケーションを選択します。

Screenshot

「Whole application」を選択します。

Screenshot

アプリケーションのタイプが正しいことを確認します。通常、デフォルト値で正しいです。

Screenshot

OpenResty XRay は、同時に複数の異なる言語レベルを分析できます。ここでは PHP と C/C++ の両方を選択したままにします。

Screenshot

最長の分析時間を設定することもできます。ここではデフォルトの 300 秒のままにします。

Screenshot

分析を開始します。

Screenshot

システムは複数のラウンドの分析を継続的に実行します。現在、最初のラウンドの分析を実行中です。

Screenshot

最初のラウンドの分析が完了し、2 回目のラウンドに入りました。この例では、1 回の分析で十分です。

Screenshot

分析を停止します。

Screenshot

自動生成された分析レポートを見ることができます。

Screenshot

これは分析する問題のタイプです。「Errors & exceptions」です。

Screenshot

これは PHP コードパスを指しています。最も多くの例外を投げるコードパスが表示されています。

Screenshot

まず、配列の境界外アクセスエラーが見られます。

Screenshot

このエラーは業務コードの getOrder 関数内で発生しています。

Screenshot

Laravel のルーティングコンポーネントは、対応するビジネスロジックコードを実行するために、コントローラーメソッド callAction を自動的に呼び出します。

Screenshot

「More」をクリックして詳細を表示します。

Screenshot

このホットコードパスは、この PHP レベルの例外フレームグラフから自動的に導き出されたものです。

Screenshot

以下は問題のより詳細な説明と提案です。

Screenshot

ここで上記の例外について言及されています。

Screenshot

ここでは PHP エラーコードが発生した場所が指摘されています。

Screenshot

ここで提案された方法でこのエラーを回避できます。OpenResty XRay はこのエラーを修正するためのコード例も提供しています。

Screenshot

元のホットコードパスに戻りましょう。

Screenshot

getOrder 関数の緑色のボックスにマウスを合わせます。

Screenshot

ツールチップで PHP 関数のソースファイル名とフルパスを確認できます。

Screenshot

この PHP ソースコードの行番号は 54 です。

Screenshot

このアイコンをクリックして、この関数のソースファイルパスをコピーします。

Screenshot

ターミナルで vim エディタを使用してソースファイルを開きます。先ほどコピーしたファイルパスを貼り付けます。お好みのエディタを使用できます。

Screenshot

OpenResty XRay が提案したように 54 行目にジャンプします。

Screenshot

PHP 配列要素へのアクセスが見られます。orderId 変数の値が明らかに配列の境界を超えることがあります。ユーザーはこのソースコード行の前で、この配列インデックスの値をチェックする必要がありますが、まだチェックしていません。

Screenshot

この例外はアプリケーション自体によってキャッチされていますが、OpenResty XRay はそれでも検出することができます。

Screenshot

次に、2 番目にプログラム例外を投げる PHP コードパスを見てみましょう。

Screenshot

これは PHP 業務コードが throw ステートメントを使って投げた例外です。

Screenshot

この例外も getOrder 関数によってトリガーされていることがわかります。

Screenshot

自動生成レポート

OpenResty XRay はオンラインプロセスを自動的に監視し、分析レポートを生成することもできます。

Screenshot

「Insights」ページに切り替えます。

Screenshot

「Insights」ページで、日次および週次の自動レポートを見つけることができます。そのため、「Guided Analysis」機能を使用する必要はありません。

Screenshot

もちろん、「Guided Analysis」はアプリケーションの開発とデモンストレーションに非常に有用です。

Screenshot

OpenResty XRay について

OpenResty XRay動的トレーシング製品であり、実行中のアプリケーションを自動的に分析して、パフォーマンスの問題、動作の問題、セキュリティの脆弱性を解決し、実行可能な提案を提供いたします。基盤となる実装において、OpenResty XRay は弊社の Y 言語によって駆動され、Stap+、eBPF+、GDB、ODB など、様々な環境下で複数の異なるランタイムをサポートしております。

著者について

章亦春(Zhang Yichun)は、オープンソースの OpenResty® プロジェクトの創始者であり、OpenResty Inc. の CEO および創業者です。

章亦春(GitHub ID: agentzh)は中国江蘇省生まれで、現在は米国ベイエリアに在住しております。彼は中国における初期のオープンソース技術と文化の提唱者およびリーダーの一人であり、Cloudflare、Yahoo!、Alibaba など、国際的に有名なハイテク企業に勤務した経験があります。「エッジコンピューティング」、「動的トレーシング」、「機械プログラミング」 の先駆者であり、22 年以上のプログラミング経験と 16 年以上のオープンソース経験を持っております。世界中で 4000 万以上のドメイン名を持つユーザーを抱えるオープンソースプロジェクトのリーダーとして、彼は OpenResty® オープンソースプロジェクトをベースに、米国シリコンバレーの中心部にハイテク企業 OpenResty Inc. を設立いたしました。同社の主力製品である OpenResty XRay動的トレーシング技術を利用した非侵襲的な障害分析および排除ツール)と OpenResty XRay(マイクロサービスおよび分散トラフィックに最適化された多機能ゲートウェイソフトウェア)は、世界中の多くの上場企業および大企業から高い評価を得ております。OpenResty 以外にも、章亦春は Linux カーネル、Nginx、LuaJITGDBSystemTapLLVM、Perl など、複数のオープンソースプロジェクトに累計 100 万行以上のコードを寄与し、60 以上のオープンソースソフトウェアライブラリを執筆しております。

翻訳

英語版の原文と日本語訳版(本文)をご用意しております。読者の皆様による他の言語への翻訳版も歓迎いたします。全文翻訳で省略がなければ、採用を検討させていただきます。心より感謝申し上げます!