1. memcached の概要
memcached は、高性能の分散メモリ キャッシュ サーバーです。使用の一般的な目的は、データベース クエリ結果をキャッシュし、データベース アクセスの数を減らすことによって、動的 Web アプリケーションの速度とスケーラビリティを向上させることです。任意の数の接続を処理でき、ノンブロッキング ネットワーク IO を使用します。 Memcached の動作メカニズムは、メモリ内のスペースを開いて HashTable を作成することであるため、Memcached はこれらの HashTable を独自に管理します。
2. Memcached のインストール
最初のステップは、memcached の最新バージョン 1.1.12 を公式 Web サイトから直接ダウンロードすることです。また、memcached は libevent を使用しており、libevent-1.1a.tar.gz をダウンロードしました。
インストールが完了すると、memcached は /usr/bin/memcached に存在するはずです。
3. memcached デーモンを実行します
memcached デーモンの実行は非常に簡単で、コマンドラインだけで実行でき、設定ファイルを変更する必要はありません (変更する必要がある設定ファイルはありません):
/usr/bin/memcached -d -m 128 -l 192.168.1.1 -p 11211 -u httpd
パラメータの説明:
-d は memcached をデーモン モードで実行します。 -m は memcached が使用できるメモリ サイズを M で設定します。 -l はローカル マシンの場合、通常、このパラメータを設定する必要はありません。リスニング ポートを設定します。デフォルトは 11211 であるため、このパラメータを設定する必要はありません。-u はユーザーを指定します。現在 root である場合は、このパラメータを使用してユーザーを指定する必要があります。
もちろん、man memcached を実行すると、使用できるパラメータが他にもあります。
4. memcached の仕組み
まず第一に、memcached は 1 つ以上のサーバーでデーモンとして実行され、クライアント接続操作をいつでも受け入れます。現在知られているクライアント API には、Perl/PHP/Python/Ruby/Java /C#/C などがあります。等PHP および他のクライアントが memcached サービスとの接続を確立したら、次にアクセスするオブジェクトには一意の識別子キーがあり、アクセス操作はこのキーを通じて実行され、memcached に保存されます。 、キャッシュ ファイルに保存されないため、memcached は非常に効率的かつ高速になります。これらのオブジェクトは永続的ではないため、サービスが停止されると内部のデータが失われることに注意してください。
5. PHP を memcached クライアントとして使用する方法
PHP を memcached クライアントとして使用して、オブジェクト アクセス操作のために memcached サービスを呼び出す方法は 2 つあります。
まず、PHP には memcache という拡張機能があります。Linux でコンパイルする場合、Windows では、php.ini の php_memcache.dll の前のコメントを削除する必要があります。 。
さらに、展開と再コンパイルによる問題を回避する別の方法として、php-memcached-client を直接使用する方法があります。
この記事では2番目の方法を使用しますが、拡張ライブラリよりも若干効率は悪くなりますが、大きな問題はありません。
6. PHP memcached アプリケーションの例
最初に memcached-client.php をダウンロードします。memcached-client.php をダウンロードした後、このファイル内のクラス「memcached」を通じて memcached サービスを操作できます。実際、コード呼び出しは非常に単純で、使用される主なメソッドは add()、get()、replace()、delete() です。メソッドの説明は次のとおりです。
コードをコピーします
コードは次のとおりです:
($key, $val, $exp = 0) を追加します
オブジェクトを memcached に書き込みます。$key はオブジェクトのデータです。$exp は秒単位で指定します。
($key)を取得
コードをコピーします
($key, $value, $exp=0) を置き換えます
$value を使用して、memcached の識別子 $key に置き換えます。パラメータは、$key オブジェクトが存在する場合にのみ機能します。
コードをコピーします
コードは次のとおりです:
memcached 内の $key という識別子を持つオブジェクトを削除します。 $time は、削除するまでの待機時間を示すオプションのパラメーターです。
以下は、識別子「mykey」を持つオブジェクト データにアクセスする簡単なテスト コードです: 実際のアプリケーションでは、通常、データベース クエリの結果セットは memcached に保存され、次回アクセスするときに、データベース クエリ操作を実行する代わりに memcached から直接取得されます。データベースの負担が大きく問題になります。通常、SQL ステートメント md5() の後の値が一意の識別子のキーとして使用されます。以下は、memcached を使用してデータベース クエリ結果セットをキャッシュする例です (このコード スニペットは上記のコード例に続きます): memcached を使用すると、データベース接続とクエリ操作が削減され、データベースの負荷が軽減され、スクリプトの実行速度も向上することがわかります。 以前「PHPでSESSIONデータのマルチサーバー共有を実現する」という記事を書きましたが、その記事内のSESSIONはデータベースを利用して保存されており、同時アクセス数が多いとサーバーへの負荷が非常に大きくなります。多くの場合、接続数は MySQL の最大値を超えますが、memcached を使用すると、この問題をうまく解決できます。 ユーザーが Web ページにアクセスすると、memcached に現在のユーザーの SESSION データがあるかどうかを確認し、データが存在する場合は session_id() を一意の識別子として使用します。データが存在しない場合は、それが直接返されます。データベースに再度接続し、SESSION データを取得し、これを使用します。データは次回使用するために memcached に保存されます。現在の PHP 操作が終了すると (または session_write_close() が使用されます)、My_Sess::write() メソッドが実行されます。この場合、データベース操作もこのメソッド用に最適化する必要があります。ユーザーがページに入ったときにグローバル変数を使用して SESSION データを記録し、このデータを write() メソッドで比較して、書き込みたい SESSION データと同じかどうかを確認します。異なる場合は、に接続します。データベースを削除してデータベースに書き込み、同時に対応するデータを memcached に追加します。オブジェクトが削除された場合、それらが同じであれば、SESSION データは変更されていないことを意味するため、それを直接返すことができます。何も操作を行わずに、ユーザーの SESSION 有効期限を解決するにはどうすればよいでしょうか。 memcached の add() メソッドには有効期限パラメータ $exp があることを覚えていますか?このパラメータ値を SESSION の最大生存時間未満に設定するだけです。また、常にオンラインのユーザーの場合は、条件が満たされた場合にデータベースのデータが更新されるように、write() メソッドで解決できます。 上記の内容は編集者による PHP での Memcached の使い方の紹介です。お役に立てれば幸いです。
興味があるかもしれない記事: