1.memcache的基本使用
输出效果:
上代码:
<?php
//连接Memcache
$mem = new Memcache;
$mem->connect("localhost", 11211) or die ("Could not connect");
//保存数据
$mem->set('key1', 'This is first value', 0, 60);
$val = $mem->get('key1');
echo "Get key1 value: " . $val ."<br>";
//替换数据
$mem->replace('key1', 'This is replace value', 0, 60);
$val = $mem->get('key1');
echo "Get key1 value: " . $val . "<br>";
// 后面追加数据
$mem->append('key1', 'This is afterzhuijia value', 0, 60);
$val = $mem->get('key1');
echo "Get key1 value: " . $val . "<br>";
// 前面追加数据
$mem->prepend('key1', 'This is prezhuijia value', 0, 60);
$val = $mem->get('key1');
echo "Get key1 value: " . $val . "<br>";
//保存数组数据
$arr = array('aaa', 'bbb', 'ccc', 'ddd');
$mem->set('key2', $arr, 0, 60);
$val2 = $mem->get('key2');
echo "Get key2 value: ";
print_r($val2);
echo "<br>";
//添加对象
class Dog{
public $name;
public $age;
public function __construct($name,$age){
$this->name=$name;
$this->age=$age;
}
}
$dog3=new Dog('小狗',50);
$mem->set('key3',$dog3,MEMCACHE_COMPRESSED,60);
$val3 = $mem->get('key3');
echo "Get key3 value name: ";
print_r($val3->name);
echo "<br>";
//获取版本信息
$version = $mem->getversion();
echo "Get version value: ";
print_r($version);
echo "<br>";
//删除数据
$mem->delete('key1');
$val = $mem->get('key1');
echo "Get key1 value: " . $val . "<br>";
//清除所有数据
$mem->flush();
$val2 = $mem->get('key2');
echo "Get key2 value: ";
print_r($val2);
echo "<br>";
$val3 = $mem->get('key3');
echo "Get key3 value: ";
print_r($val3);
echo "<br>";
//关闭连接
$mem->close();
2.先从缓存读数据,无数据在调用数据库
效果图:
上代码:
<?php
$mem = new Memcache();
$mem->connect('localhost',11211);
$users = $mem->get('users');//从memcached中读取users数据
if(empty($users)){
$dsn = 'mysql:host=localhost;dbname=pzkc';
$pdo = new PDO($dsn,'root','root');
$sql = 'select * from lyy_member;';
$st = $pdo->prepare($sql);
$st->execute();
$users = $st->fetchAll(PDO::FETCH_ASSOC);
$mem->add('users',$users,false,5);//将users数据添加到memcached中并保存5秒
echo 'from mysql'.'<br/>';
}else{
echo 'from cache'.'<br/>';
}
print_r($users);
?>
3.构造简单消息列队
参考:https://www.cnblogs.com/ximu/articles/2118323.html
性能特点
1. 无差错高并发写入
2.内部指针以int计数, 一个队列当写入次数超过int范围时,出错
<?php
/**
* Memcache 消息队列类
* @author xiaowu <tsxw24@gmail.com>
*/
class QMC {
const PREFIX = 'ASDFASDFFWQKE';
/**
* 初始化mc
* @staticvar string $mc
* @return Memcache
*/
static private function mc_init() {
static $mc = null;
if (is_null($mc)) {
$mc = new Memcache;
$mc->connect('127.0.0.1', 11211);
}
return $mc;
}
/**
* mc 计数器,增加计数并返回新的计数
* @param string $key 计数器
* @param int $offset 计数增量,可为负数.0为不改变计数
* @param int $time 时间
* @return int/false 失败是返回false,成功时返回更新计数器后的计数
*/
static public function set_counter( $key, $offset, $time=0 ){
$mc = self::mc_init();
$val = $mc->get($key);
if( !is_numeric($val) || $val < 0 ){
$ret = $mc->set( $key, 0, $time );
if( !$ret ) return false;
$val = 0;
}
$offset = intval( $offset );
if( $offset > 0 ){
return $mc->increment( $key, $offset );
}elseif( $offset < 0 ){
return $mc->decrement( $key, -$offset );
}
return $val;
}
/**
* 写入队列
* @param string $key
* @param mixed $value
* @return bool
*/
static public function input( $key, $value ){
$mc = self::mc_init();
$w_key = self::PREFIX.$key.'W';
$v_key = self::PREFIX.$key.self::set_counter($w_key, 1);
return $mc->set( $v_key, $value );
}
/**
* 读取队列里的数据
* @param string $key
* @param int $max 最多读取条数
* @return array
*/
static public function output( $key, $max=100 ){
$out = array();
$mc = self::mc_init();
$r_key = self::PREFIX.$key.'R';
$w_key = self::PREFIX.$key.'W';
$r_p = self::set_counter( $r_key, 0 );//读指针
$w_p = self::set_counter( $w_key, 0 );//写指针
if( $r_p == 0 ) $r_p = 1;
while( $w_p >= $r_p ){
if( --$max < 0 ) break;
$v_key = self::PREFIX.$key.$r_p;
$r_p = self::set_counter( $r_key, 1 );
$out[] = $mc->get( $v_key );
$mc->delete($v_key);
}
return $out;
}
}
/**
使用方法:
QMC::input($key, $value );//写入队列
$list = QMC::output($key);//读取队列
*/
QMC::input(1, 1 );//写入队列
QMC::input(1, 2 );//写入队列
QMC::input(1, 3 );//写入队列
QMC::input(1, 4 );//写入队列
$list = QMC::output(1);//读取队列
print_r($list);
?>