1. memcached の概要 memcached という名前をよく聞くことがありますが、多くの学生は聞いたことがあるだけで、実際に使用したり、理解したことがありません。ここで簡単に紹介します: memcached は効率的かつ高速な分散メモリ オブジェクト キャッシング システムであり、主に WEB 動的アプリケーションを高速化するために使用されます。 2. Memcached のインストール 最初のステップは、memcached の最新バージョン 1.1.12 を公式 Web サイトから直接ダウンロードすることです。また、memcached は libevent を使用しており、libevent-1.1a.tar.gz をダウンロードしました。次のステップでは、libevent-1.1a.tar.gz と memcached-1.1.12.tar.gz をそれぞれ解凍、コンパイル、インストールします。 # tar -xzf libevent-1.1a.tar.gz
# cd libevent- 1.1 a
# ./configure --prefix=/usr
# make
# make install
# cd ..
# tar -xzf memcached-1.1.12.tar.gz
# cd memcached-1.1.12
# ./configure --prefix=/usr
# make
# make install のインストール後、memcached は /usr/bin/memcached にあるはずです。 3. memcached デーモンを実行します。 memcached デーモンの実行は非常に簡単です。コマンド ラインを必要とするだけです (変更する必要がある構成ファイルはありません)。 d -m 128 -l 192.168.1.1 -p 11211 -u httpd パラメータの説明: -d は memcached をデーモン モードで実行します。
-m は memcached が使用できるメモリ サイズを M に設定します。リスニング IP アドレス。ローカル マシンの場合、通常、このパラメータを設定する必要はありません。
-p はリスニング ポートを設定します。デフォルトは 11211 であるため、このパラメータを設定する必要はありません。 u はユーザーを指定します。現在 root である場合は、このパラメーターを使用してユーザーを指定する必要があります。もちろん、man memcached を実行すると、他にも使用できるパラメーターが表示されます。 4. memcached の動作原理: まず、memcached は 1 つ以上のサーバーでデーモンとして実行され、クライアント接続操作をいつでも受け入れます。現在知られているクライアント API には、Perl/PHP/Python/Ruby などがあります。 /Java/C#/C などPHP などのクライアントが memcached サービスとの接続を確立したら、次にアクセスするオブジェクトには一意の識別子キーがあり、アクセス操作は memcached に保存されます。 、キャッシュ ファイルに保存されないため、memcached は非常に効率的かつ高速になります。これらのオブジェクトは永続的ではないため、サービスが停止されると内部のデータが失われることに注意してください。 3. PHP を memcached クライアントとして使用する方法 PHP を memcached クライアントとして使用して、オブジェクト アクセス操作のために memcached サービスを呼び出す方法は 2 つあります。まず、PHP には memcache という拡張機能があります。Linux でコンパイルする場合は、-enable-memcache[=DIR] オプションを使用できるようにするために、php.ini の php_memcache.dll の前のコメントを削除する必要があります。また、展開や再コンパイルによるトラブルを回避するには、php-memcached-client を直接使用する方法もあります。この記事では 2 番目の方法を選択しますが、拡張ライブラリよりも若干効率が悪くなりますが、大きな問題はありません。 4. PHP memcached アプリケーションの例 まず、memcached-client.php をダウンロードします。ダウンロード後、このファイル内のクラス「memcached」を通じて memcached サービスを操作できます。実際、コード呼び出しは非常に単純です。使用される主なメソッドは、add()、get()、replace()、および delete() です。メソッドの説明は次のとおりです。 )
memcached にオブジェクトを書き込みます。$key はオブジェクトの一意の識別子、$val は書き込まれるオブジェクト データ、$exp は秒単位の有効期限、デフォルトは無制限です。 🎜> from memcached オブジェクトの一意の識別子 $key からオブジェクト データを取得します。 replace ($key, $value, $exp=0)
$value を使用して、memcached の識別子 $key を使用します。 add( ) メソッドと同じです。$key オブジェクトが存在する場合にのみ機能します。 delete ($key, $time = 0)
memcached 内の $key という識別子を持つオブジェクトを削除します。$time は削除までの待機時間を示すオプションのパラメータ。以下は、識別子「mykey」を持つオブジェクト データにアクセスする簡単なテスト コードです:
コードをコピー
コードは次のとおりです: コードをコピーします コードは次のとおりです。次のように: $sql = 'SELECT * FROM users';
// memcached クラス ファイルが含まれます
require_once('memcached-client.php');
// オプション設定
$options = array(
'servers' => array('192.168.1.1:11211'), //memcached サービスのアドレスとポート。複数の配列要素を使用して複数の memcached サービスを表すことができます。
'debug' => true, //デバッグがオンかどうか。
' compress_threshold' => 10240, //データがバイト数を超えた場合に圧縮します
'persistant' => false //永続的な接続を使用するかどうか
)//memcached オブジェクトを作成しますinstance
$mc = new memcached($options);
//このスクリプトで使用される一意の識別子を設定します
$key = 'mykey'
//memcached にオブジェクトを書き込みます
$ mc ->add($key, 'いくつかのランダムな文字列');
$val = $mc->get($key);
echo "n".str_pad('$mc->add ( ) ', 60, '_')."n";
var_dump($val)
// 書き込まれたオブジェクトのデータ値を置き換えます
$mc->replace($key, array ( 'some'=>'haha', 'array'=>'xxx'));
$val = $mc->get($key);
echo "n".str_pad( ' $mc->replace() ', 60, '_')."n";
var_dump($val)
// memcached 内のオブジェクトを削除します
$mc->delete ($ key);
$val = $mc->get($key);
echo "n".str_pad('$mc->delete() ', 60, '_') ";
var_dump($val);
?>
$key = md5($sql); //memcached オブジェクト識別子
{
// ではありませんでしたmemcached で取得 データをキャッシュするには、データベース クエリを使用してレコードセットを取得します。
echo "n".str_pad('MySQL からデータを読み取ります。', 60, '_')."n";
$conn = mysql_connect('localhost', 'test', 'test');
mysql_select_db('test');
$result = mysql_query($sql);
while ($row = mysql_fetch_object($result))
$datas[] = $row; //データベースから取得した結果セットのデータを、次回のアクセス時に使用するために memcached に保存します。
$mc->add($key, $datas);
{
echo "n".str_pad('memcached からデータを読み取ります。', 60, '_')."n";
}
var_dump($datas);
?>
memcached を使用すると、データベース接続とクエリ操作が軽減され、データベースの負荷が軽減されることがわかります。スクリプトの実行速度も向上しました。以前「PHPでSESSIONデータのマルチサーバー共有を実現する」という記事を書きましたが、その中のSESSIONはデータベースに保存されるため、同時アクセス数が多いとサーバーへの負荷が非常に大きくなります。 MySQL の最大接続数を超えることがよくありますが、memcached を使用すると、この問題をうまく解決できます。
現在の PHP 操作が終了するとき (または session_write_close() が使用されるとき)、My_Sess::write() メソッドを呼び出してデータベースにデータを書き込みます。この場合も、毎回データベース操作が行われます。方法も最適化する必要があります。ユーザーがページに入ったときにグローバル変数を使用して SESSION データを記録し、このデータを write() メソッドで比較して、書き込みたい SESSION データと同じかどうかを確認します。異なる場合は、に接続します。データベースを削除してデータベースに書き込み、同時にオブジェクトの削除に対応するデータを追加します。それらが同じであれば、SESSION データが変更されていないことを意味し、何も操作せずに直接返すことができます。 ;
では、ユーザーの SESSION 有効期限を解決するにはどうすればよいでしょうか? memcached の add() メソッドには有効期限パラメータ $exp があることを覚えていますか?このパラメータ値を SESSION の最大生存時間未満に設定するだけです。また、常にオンラインのユーザーの場合は、条件が満たされた場合にデータベースのデータが更新されるように、write() メソッドで解決できます。