重要な調査結果:
PHPリーグのCommonmark Markdown Parserは、生の速度にわたって拡張性を優先し、BlackFire.ioを使用したパフォーマンスの最適化を受けました。 2つの重要な改善により、パフォーマンスが大幅に向上しました
Cursor::getCharacter()
インラインで最適化されたコールを48,118に削減する最適化により、全体的なパフォーマンスの改善が11%になりました。
Cursor::getCharacter()
コールの削減:NewlineParser::parse()
これらの最適化の合計効果により、52.5%の驚くべきパフォーマンスが得られました。 これは、パフォーマンスのボトルネックを識別およびアドレス指定するためのBlackFire.ioのようなプロファイリングツールの重要性を強調しています。
NewlineParser::parse()
Commonmark Parserは、Commonmark仕様とJavaScript参照実装の拡張性と順守を、何よりも優先します。この設計の選択は、より複雑でオブジェクト指向の構造をもたらしますが、よりシンプルで高速なパーサーと比較して、より大きなカスタマイズと統合が可能になります。 エンドユーザーではパフォーマンスの違いは無視できるかもしれませんが(特にキャッシュを使用する場合)、最適化の取り組みは依然として価値があると考えられていました。
プロファイリング用のblackfire.io:
パフォーマンスプロファイリングツールであるBlackFire.ioは、パフォーマンスの問題を特定する上で非常に貴重であることが証明されました。 その詳細なパフォーマンストレースにより、および
メソッド内のボトルネックを正確に識別することができました。最適化の詳細:
InlineParserEngine::parse()
NewlineParser::parse()
初期最適化は、の文字ごとの反復を、正規表現でに置き換え、非専門文字のシーケンスを効率的に処理することを含む。
最適化2:2番目の最適化は、メソッドに焦点を合わせました。 ハードラインブレイク検出ロジックを合理化することにより、個々のスペース文字の不必要なチェックが排除されました。
InlineParserEngine::parse()
最適化する前に、Commonmark仕様ドキュメントを解析するには約59分かかりました。両方の最適化を実装した後、解析時間は28msに低下しました。これは52.5%の大幅な改善です。
NewlineParser::parse()
提供されたFAQはすでに十分に構造化されており、CommonMark、Blackfire.io、および最適化プロセスに関する一般的な質問に答えます。 それ以上の変更は必要ありません。
以上がケーススタディ:Blackfire.ioを使用したCommonmark Markdownパーサーの最適化の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。