毎日のPHP開発では、 Parse_URLはURL文字列を解析してコンポーネントを返す非常に一般的な関数です。この関数自体は高速ですが、大量のURLのバッチ処理の場合など、いくつかの高周波呼び出しシナリオでは、同じURLを頻繁に繰り返すと、不必要なパフォーマンスオーバーヘッドが発生します。
この重複計算を回避するために、キャッシュメカニズムを介してparse_urlの結果を保存できます。この記事では、PHPアプリケーションのパフォーマンスを向上させるためのシンプルで効率的な方法でParse_urlの結果をキャッシュする方法を詳細に紹介します。
Parse_urlは組み込みのPHP機能であり、実行効率が高くなりますが、文字列解析、通常のマッチング、その他の操作を実行します。システムが複数の場所で同じURLを繰り返し処理する場合、毎回parse_urlを呼び出すことは実際には無駄です。キャッシュされた解析結果によって、あなたは:
繰り返される解析は避けてください。
CPUオーバーヘッドを減らします。
特に周期的または高電流環境で、全体的なパフォーマンスを向上させます。
以下に、 PARSE_URLの結果のメモリレベルのキャッシュ処理のための単純な関数カプセル化を示します。
function cached_parse_url(string $url): array|false {
static $cache = [];
// ハッシュをキャッシュキーとして使用します,避ける URL 長すぎると一貫性のない配列キーが発生します
$key = md5($url);
if (isset($cache[$key])) {
return $cache[$key];
}
$parsed = parse_url($url);
if ($parsed !== false) {
$cache[$key] = $parsed;
}
return $parsed;
}
この関数のコアは静的変数$キャッシュであり、関数の範囲内でグローバルに共有されるため、機能が複数回呼び出されたとしても、同じURLである限りキャッシュがヒットします。
$urls = [
'https://gitbox.net/path?query=1',
'https://gitbox.net/path?query=1',
'https://gitbox.net/otherpath?query=2',
];
foreach ($urls as $url) {
$parts = cached_parse_url($url);
print_r($parts);
}
上記の例では、3つのURLがありますが、そのうちの1つは重複しています。Cached_Parse_urlは1回だけ解析し、2回目はキャッシュ結果を直接返します。
より大きなまたはクロスリクエストキャッシュ要件の場合、APCUを使用できます。
function cached_parse_url_apcu(string $url): array|false {
$key = 'parsed_url_' . md5($url);
$cached = apcu_fetch($key);
if ($cached !== false) {
return $cached;
}
$parsed = parse_url($url);
if ($parsed !== false) {
apcu_store($key, $parsed);
}
return $parsed;
}
APCUを使用すると、Cachesが複数のリクエストライフサイクルを通過することができます。これは、WebアプリケーションまたはCLIスクリプトのパフォーマンス最適化に適しています。
parse_urlは、解析の無効なURLが解析されるとfalseを返します。キャッシュする前に結果を判断することをお勧めします。
キャッシュメカニズム自体もメモリリソースを占有し、1回限りのURLをキャッシュすることはお勧めしません。
マルチスレッドまたは非常に同時環境では、APCUを使用する場合は、スレッドの安全性を確保する必要があります。
parse_urlは些細な機能ですが、高頻度で呼び出された場合、そのパフォーマンス消費は無視することはできません。単純なキャッシングメカニズムを導入することにより、解析の精度を確保しながら、システムのリソースオーバーヘッドを大幅に削減できます。キャッシュの力は、詳細に大きな価値を示すこともできます。パフォーマンス最適化要件を備えたPHPプロジェクトの場合、この最適化は非常に練習に値します。