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