肖理达 (KrazyNio AT hotmail.com), 2006.04. 06, 转载请注明出处
一、memcached 简介
在很多场合,我们都会听到 memcached 这个名字,但很多同学只是听过,并没有用过或实际了解过,只知道它是一个很不错的东东。这里简单介绍一下,memcached 是高效、快速的分布式内存对象缓存系统,主要用于加速 WEB 动态应用程序。
二、memcached 安装
首先是下载 memcached 了,目前最新版本是 1.1.12,直接从官方网站即可下载到 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
三、PHP 如何作为 memcached 客户端
有两种方法可以使 PHP 作为 memcached 客户端,调用 memcached 的服务进行对象存取操作。
第一种,PHP 有一个叫做 memcache 的扩展,Linux 下编译时需要带上 –enable-memcache[=DIR] 选项,Window 下则在 php.ini 中去掉 php_memcache.dll 前边的注释符,使其可用。
除此之外,还有一种方法,可以避开扩展、重新编译所带来的麻烦,那就是直接使用 php-memcached-client。
本文选用第二种方式,虽然效率会比扩展库稍差一些,但问题不大。
四、PHP memcached 应用示例
首先 下载 memcached-client.php,在下载了 memcached-client.php 之后,就可以通过这个文件中的类“memcached”对 memcached 服务进行操作了。其实代码调用非常简单,主要会用到的方法有 add()、get()、replace() 和 delete(),方法说明如下:
add ($key, $val, $exp = 0)
往 memcached 中写入对象,$key 是对象的唯一标识符,$val 是写入的对象数据,$exp 为过期时间,单位为秒,默认为不限时间;
get ($key)
从 memcached 中获取对象数据,通过对象的唯一标识符 $key 获取;
replace ($key, $value, $exp=0)
使用 $value 替换 memcached 中标识符为 $key 的对象内容,参数与 add() 方法一样,只有 $key 对象存在的情况下才会起作用;
delete ($key, $time = 0)
删除 memcached 中标识符为 $key 的对象,$time 为可选参数,表示删除之前需要等待多长时间。
以下は、識別子「mykey」を持つオブジェクト データにアクセスする簡単なテスト コードです:
コードをコピーします コードは次のとおりです:
// memcached クラス ファイルが含まれます
require_once('memcached-client.php');
// オプション設定
$options = array(
'servers' => array('192.168.1.1:11211'), //memcached サービスのアドレスとポートを使用して、複数の memcached サービスを表すことができます。
'debug' => , //デバッグをオンにするかどうか
'compress_threshold' => 10240, //データがバイト数を超えた場合に圧縮する
'persistant' => false //永続的な接続を使用するかどうか
);
// memcached オブジェクトのインスタンスを作成します
$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 , '_')."n";
var_dump($val);
実際のアプリケーションでは、通常、データベースの結果セットです。クエリは memcached に保存され、次回アクセスするときにデータベース クエリ操作を実行せずに memcached から直接取得されるため、データベースへの負担が大幅に軽減されます。通常、SQL ステートメント md5() の後の値が一意の識別子のキーとして使用されます。以下は、memcached を使用してデータベース クエリ結果セットをキャッシュする例です (このコード スニペットは上記のサンプル コードに従っています):
コードは次のとおりです。以下のように: $sql = 'SELECT * FROM users';
$key = md5($sql); //memcached オブジェクト識別子if ( !($ datas = $mc->get($key)) ) {
// 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);
} else {
echo "n".str_pad('memcached からデータを読み取ります。', 60, '_')."n ";
}
var_dump($datas);
?>
memcached を使用すると、データベース接続とクエリ操作が削減され、データベースの負荷が軽減され、スクリプトの実行速度も向上することがわかります。
ユーザーが Web ページにアクセスすると、memcached に現在のユーザーの SESSION データがあるかどうかを確認し、データが存在する場合は session_id() を一意の識別子として使用します。データが存在しない場合は、それが直接返されます。次に、データベースに接続して SESSION データを取得し、次回使用するためにこのデータを memcached に保存します。 現在の PHP 操作が終了する (または session_write_close()
が使用される) と、My_Sess::write() メソッドが呼び出されてデータベースにデータが書き込まれます。毎回データベースを操作する必要があるため、このメソッドも最適化する必要があります。ユーザーがページに入ったときにグローバル変数を使用して SESSION データを記録し、このデータを write() メソッドで比較して、書き込みたい SESSION データと同じかどうかを確認します。異なる場合は、に接続します。データベースを削除してデータベースに書き込み、同時に対応するデータを memcached に追加します。オブジェクトが削除された場合、それらが同じであれば、SESSION データは変更されていないことを意味するため、何もせずに直接戻ることができます。何らかの操作を行う。memcached 公式ウェブサイト