Redisキャッシュで既存のアプリをスピードアップします
Redisは既存のアプリケーションを加速します:クエリをキャッシュしてサーバーの負荷を減らします
コアポイント:
- Redisは、クエリの結果をキャッシュすることにより、既存のアプリケーションを効果的に加速し、サーバーの圧力を低下させます。指定された時間(たとえば、24時間)のクエリ結果を保存し、これらの結果を再利用して、アプリケーション速度を大幅に改善します。
- Redisのインストールは、オペレーティングシステムパッケージマネージャーを介して、または手動で完了することができます。インストールプロセスには、一般的な警告を避け、サーバーが再起動した後にRedisが自動的に開始されるようにすることが含まれます。
- PredisライブラリはRedisと連携して、アプリケーションにメモリキャッシュレイヤーを提供します。このプロセスでは、現在のクエリの結果がキャッシュに存在するかどうかを確認し、存在しない場合は結果を取得し、将来の使用のために保存します。 パフォーマンスをさらに向上させるために、Predisは、Redisプロトコルのシリアル化と解析のオーバーヘッドを削減するPHP拡張機能であるPhpiredisのインストールを推奨し、Redisのインストールをより速くすることをお勧めします。
問題の説明:
ソリューションを適用する前に、問題の定義を明確にする必要があります。問題のアプリケーションには、クエリを実行するときにDiffbotのAPIにアクセスし、データセットに照会します。次に、サブセットを返して表示します。 Diffbotサーバーがどれだけ忙しいかに応じて、これには約5秒かかります。これは間違いなくコンピューティングパワーを拡大するにつれて改善されますが、セット自体が頻繁にのみ更新されるため、24時間実行されて再利用されたクエリの結果が一度実行された場合、それは素晴らしいことです。
あなたは「単一のクエリをキャッシュすることの利点は何ですか?」
実際には、研究では、人々が同じコンテンツを頻繁に検索し(反応する「React」クエリが突然増加します)、有名な著者(または自分自身)も検索します。このキャッシュの実装にはほとんどコストがかかることを考えると(実際にはサーバーの圧力を削減することでコストを削減することで)、頻繁に使用されていなくても、簡単な勝利です。
それを追加しない理由 - は私たちにしか有利です。 問題を明確に定義したら、前提条件に対処しましょう。
インストール:まず、Redisを開発および生産環境にインストールする必要があります(ローカル開発でHomesteadを使用している場合、Redisはすでにインストールされていますが、執筆時点ではバージョン3.0.1)。
オペレーティングシステムのパッケージマネージャーを通じてこれを行うことができます:
sudo apt-get install redis-server
これは最も簡単で推奨される方法ですが、ゼロからインストールして手動で構成することもできます。彼らのウェブサイトの指示によると、それは次のように行うことができます:
sudo apt-get install gcc make build-essential tcl wget http://download.redis.io/releases/redis-3.0.2.tar.gz tar xzf redis-3.0.2.tar.gz cd redis-3.0.2 make make test sudo make install
実行後にJemalloc.hに言及している致命的なエラーに遭遇した場合は、Make DistCleanを実行して再び実行してください。テストコマンドはオプションですが、役立ちます。
注:この記事とバージョン3.0.2が最新ではなくなった場合は、コマンドを最新バージョン番号に調整するだけです。
いくつかの一般的な警告を防ぐため(少なくともubuntuで)、次のコマンドも予防的に実行します。
また、sudo sh -c 'echo "vm.overcommit_memory=1" >> /etc/sysctl.conf' sudo sh -c 'echo "net.core.somaxconn=65535" >> /etc/sysctl.conf' sudo sh -c 'echo "never" > /sys/kernel/mm/transparent_hugepage/enabled'
最後に、サーバーが再起動した後、Redisが自動的に起動することを確認する必要があるため、公式の指示に従ってこれを行います。
predis:
以前にプレディスの基本をカバーしてきましたが、この場合も使用します。次のコマンドを使用してインストールしましょう:
composer require predis/predis
その投稿が公開されたため、いくつかのわずかな違いが導入されました(名前空間への移行など)が、使用する必要があるAPIはほぼ同じです。
実装:
アプリケーションでRedisを使用するには、次の手順に従う必要があります。現在のクエリ結果がキャッシュに存在するかどうかを表示
- それが存在する場合は、結果を取得します
- それが存在しない場合は、結果を取得し、結果を保存し、結果をアプリケーションの残りの部分に転送します
- したがって、実装は非常に単純です。「フォーム送信」チェック(「検索」パラメーターを探すもの)の下で、Predisクライアントをインスタンス化し、実行された検索クエリのMD5ハッシュを計算してからチェックしますその結果が確認されている場合。 falseの場合、前のプロセスは継続しますが、次のとおりです。
テスト後、それがうまく機能することがわかります - ページを更新するか、別のクエリを実行してから前のクエリに戻ると、1回実行されたクエリは瞬時になります。最後に、展開を追加、送信、プッシュすることができます。
$result = ... $info = ...
// 检查是否提交了搜索表单 if (isset($queryParams['search'])) { $redis = new Client(); $hash = md5($_SERVER['QUERY_STRING']); if (!$redis->get($hash . '-results')) { $diffbot = new Diffbot(DIFFBOT_TOKEN); // 构建搜索字符串 $searchHelper = new SearchHelper(); $string = (isset($queryParams['q']) && !empty($queryParams['q'])) ? $queryParams['q'] : $searchHelper->stringFromParams($queryParams); // 基础设置 $search = $diffbot ->search($string) ->setCol('sp_search') ->setStart(($queryParams['page'] - 1) * $resultsPerPage) ->setNum($resultsPerPage); $redis->set($hash . '-results', serialize($search->call())); $redis->expire($hash . '-results', 86400); $redis->set($hash . '-info', serialize($search->call(true))); $redis->expire($hash . '-info', 86400); } $results = unserialize($redis->get($hash . '-results')); $info = unserialize($redis->get($hash . '-info')); }
git add -A git commit -m "Added Redis cache [deploy:production]" git push origin master
微調整:
パフォーマンスをさらに向上させるために、Predisは、Redisプロトコルのシリアル化と解析
」のオーバーヘッドを削減するためのPHP拡張機能であるPhpiredisをインストールすることをお勧めします。サーバーを完全に制御できるので、これを行いませんか?
これにより、前提条件がインストールされ、拡張機能が有効になります。これで、Phpiredis接続を使用するようにPredisクライアントを構成するだけです。交換する必要があります:sudo apt-get install redis-server
is:
sudo apt-get install gcc make build-essential tcl wget http://download.redis.io/releases/redis-3.0.2.tar.gz tar xzf redis-3.0.2.tar.gz cd redis-3.0.2 make make test sudo make install
それだけです! Redisのインストールは今より速いです!
sudo sh -c 'echo "vm.overcommit_memory=1" >> /etc/sysctl.conf' sudo sh -c 'echo "net.core.somaxconn=65535" >> /etc/sysctl.conf' sudo sh -c 'echo "never" > /sys/kernel/mm/transparent_hugepage/enabled'
このチュートリアルでは、RedisライブラリとPredisライブラリを組み合わせて使用して、展開されたアプリケーションをより速く見えるようにします。ソースを送信する代わりに、Digitalocean液滴の利用可能なRAMを使用して、1日1回クエリの結果を保存し、これらの結果をキャッシュから返します。これは、結果が常に最新であるとは限らないことを意味しますが、この投稿によると、結果自体はこれよりも頻繁に更新されません。
このチュートリアルが、アプリケーションにメモリキャッシュレイヤーを追加するのがどれほど簡単かを示していることを願っています。また、読み込み時間を短縮してサーバーコストを削減する必要がある場合に非常に便利です。他の提案はありますか?スキル?コメント?以下にメッセージを残してください!
(FAQパーツはここで省略されています。FAQパーツの内容が記事の主要な内容と複製されているため、これは冗長な情報です。擬似原産性は、内容の重複を避ける必要があります。
以上がRedisキャッシュで既存のアプリをスピードアップしますの詳細内容です。詳細については、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)

ホットトピック











JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

php8.1の列挙関数は、指定された定数を定義することにより、コードの明確さとタイプの安全性を高めます。 1)列挙は、整数、文字列、またはオブジェクトであり、コードの読みやすさとタイプの安全性を向上させることができます。 2)列挙はクラスに基づいており、トラバーサルや反射などのオブジェクト指向の機能をサポートします。 3)列挙を比較と割り当てに使用して、タイプの安全性を確保できます。 4)列挙は、複雑なロジックを実装するためのメソッドの追加をサポートします。 5)厳密なタイプのチェックとエラー処理は、一般的なエラーを回避できます。 6)列挙は魔法の価値を低下させ、保守性を向上させますが、パフォーマンスの最適化に注意してください。

セッションハイジャックは、次の手順で達成できます。1。セッションIDを取得します。2。セッションIDを使用します。3。セッションをアクティブに保ちます。 PHPでのセッションハイジャックを防ぐための方法には次のものが含まれます。1。セッション_regenerate_id()関数を使用して、セッションIDを再生します。2。データベースを介してストアセッションデータを3。

PHP開発における固体原理の適用には、次のものが含まれます。1。単一責任原則(SRP):各クラスは1つの機能のみを担当します。 2。オープンおよびクローズ原理(OCP):変更は、変更ではなく拡張によって達成されます。 3。Lischの代替原則(LSP):サブクラスは、プログラムの精度に影響を与えることなく、基本クラスを置き換えることができます。 4。インターフェイス分離原理(ISP):依存関係や未使用の方法を避けるために、細粒インターフェイスを使用します。 5。依存関係の反転原理(DIP):高レベルのモジュールと低レベルのモジュールは抽象化に依存し、依存関係噴射を通じて実装されます。

静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

Restapiの設計原則には、リソース定義、URI設計、HTTPメソッドの使用、ステータスコードの使用、バージョンコントロール、およびHATEOASが含まれます。 1。リソースは名詞で表され、階層で維持される必要があります。 2。HTTPメソッドは、GETを使用してリソースを取得するなど、セマンティクスに準拠する必要があります。 3.ステータスコードは、404など、リソースが存在しないことを意味します。 4。バージョン制御は、URIまたはヘッダーを介して実装できます。 5。それに応じてリンクを介してhateoasブーツクライアント操作をブーツします。

PHPでは、Try、Catch、最後にキーワードをスローすることにより、例外処理が達成されます。 1)TRYブロックは、例外をスローする可能性のあるコードを囲みます。 2)キャッチブロックは例外を処理します。 3)最後にブロックは、コードが常に実行されることを保証します。 4)スローは、例外を手動でスローするために使用されます。これらのメカニズムは、コードの堅牢性と保守性を向上させるのに役立ちます。

PHPの匿名クラスの主な機能は、1回限りのオブジェクトを作成することです。 1.匿名クラスでは、名前のないクラスをコードで直接定義することができます。これは、一時的な要件に適しています。 2。クラスを継承したり、インターフェイスを実装して柔軟性を高めることができます。 3.使用時にパフォーマンスとコードの読みやすさに注意し、同じ匿名のクラスを繰り返し定義しないようにします。
