ほとんどの場合、当社の Web サイトはサイト データ ストレージのコンテナとしてデータベースを使用します。 SQL クエリを実行するときの一般的なプロセスは次のとおりです。データベースに接続します - > SQL クエリを準備します - > データベースにクエリを送信します - > データベースから返された結果を取得します - > データベース接続を閉じますただし、データベース内の一部のデータは完全に静的であるか、頻繁に変更されません。キャッシュ システムは SQL クエリの結果をより高速なストレージ システムにキャッシュするため、頻繁なデータベース操作を回避し、プログラムの実行時間を大幅に短縮できます。後で処理してください。
一般的に使用される PHP キャッシュ技術
PHP キャッシュ技術のデータ キャッシュ:
ここで言うデータ キャッシュとは、ページがアクセスされるたびに、まず対応するキャッシュ データが存在するかどうかを検出します。存在しない場合は、データベースに接続してデータを取得し、クエリ結果をシリアル化してファイルに保存すると、今後は同じクエリ結果がキャッシュ ファイルから直接取得されます。
PHPキャッシュ技術のページキャッシュ:
ページにアクセスするたびに、まず対応するキャッシュされたページファイルが存在するかどうかを検出し、存在しない場合はデータベースに接続し、データを取得し、ページを表示します。同時にキャッシュされたページ ファイルを生成します。これにより、次回アクセスしたときにそのページ ファイルが有効になります。 (インターネット上のテンプレート エンジンや一部の一般的なキャッシュ クラスには通常この機能があります)
PHP キャッシュ技術のメモリ キャッシュ:
ここでは紹介しませんが、この記事では簡単に説明します。それ:
Memcached は、データベースの負荷を軽減し、動的アプリケーションのアクセス速度を向上させるために使用される高性能の分散メモリ オブジェクト キャッシュ システムです。
Dbcached は、Memcached と NMDB に基づいた分散キー値データベース メモリ キャッシュ システムです。
上記のキャッシュ テクノロジは頻繁なデータベース クエリの問題を十分に解決できますが、データがタイムリーではないという欠点があります。ここでは、私がプロジェクトでよく使用する方法を示します。
PHP キャッシュ テクノロジの時間トリガー キャッシュ :
ファイルが存在し、タイムスタンプが設定された有効期限よりも小さいかどうかを確認し、ファイル変更タイムスタンプが現在のタイムスタンプから有効期限タイムスタンプを引いた値より大きい場合はキャッシュを使用し、それ以外の場合はキャッシュを更新します。
設定時間内にデータを更新する必要があるかどうかを判断せず、設定時間後にキャッシュを更新します。上記は、適時性の要件が高くない場合の使用にのみ適しています。それ以外の場合は、以下を参照してください。
PHPキャッシュ技術のコンテンツトリガーキャッシュ:
データが挿入または更新されると、キャッシュが強制的に更新されます。
ここで、大量のデータを頻繁に更新する必要がある場合、最終的にはディスクの読み取りおよび書き込み操作が関与することがわかります。これを解決するにはどうすればよいですか? 私は通常、すべてのコンテンツをキャッシュするのではなく、頻繁に変更されない一部のコンテンツをキャッシュして問題を解決します。ただし、負荷が高い場合は、共有メモリをキャッシュ システムとして使用するのが最善です。
ここでは PHP キャッシュが解決策になる可能性がありますが、その欠点は、依然として各リクエストを PHP によって解析する必要があるため、負荷が高い場合には効率の問題がさらに深刻になることです。この場合、静的キャッシュが使用される可能性があります。
PHP キャッシュ技術の静的キャッシュ
ここで言及する静的キャッシュは HTML キャッシュを指します。通常、HTML が使用される場合、それは通常ページであるため、HTML キャッシュはデータを更新する必要があるかどうかを判断する必要はありません。内容は頻繁に変更されません。データが更新された場合は、HTML を強制的に更新するだけです。