Memcache认识及php memcache扩展

42 篇文章 0 订阅
9 篇文章 0 订阅

认识memcache

Memcached是一个自由开源的,高性能,分布式内存对象缓存系统。它是一种基于内存的key-value存储,用来存储小块的任意数据(字符串、对象)。这些数据可以是数据库调用、API调用或者是页面渲染的结果。

Memcached简洁而强大。它的简洁设计便于快速开发,减轻开发难度,解决了大数据量缓存的很多问题。它的API兼容大部分流行的开发语言。

本质上,它是一个简洁的key-value存储系统。

一般的使用目的是,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web应用的速度、提高可扩展性。 

Linux Memcached (rhel6.5.x86_64)安装

Memcached 支持许多平台:Linux、FreeBSD、Solaris、Mac OS,也可以安装在Windows上。

Linux系统安装memcached,首先要先安装libevent库。
yum源安装:

yum install libevent libevent-devel
yum install memcached

源码安装:

wget http://memcached.org/latest                    下载最新版本

tar -zxvf memcached-x.x.x.tar.gz                    解压源码

cd memcached-x.x.x                                  进入目录

./configure --prefix=/usr/local/memcached           配置

make                                  编译

make install                                   安装

如果你是 PHP7 版本,则需要下载指定分支:

git clone -b php7 https://github.com/php-memcached-dev/php-memcached.git

安装完成之后启动服务:

/etc/init.d/memcached start
这里写图片描述

Memcached 连接

我们可以通过 telnet 命令并指定主机ip和端口来连接 Memcached 服务。

telnet HOST PORT

如果系统中没有telnet命令可以通过yum install telnet -y来进行安装
命令中的 HOST 和 PORT 为运行 Memcached 服务的 IP 和 端口。

连接示例:

[root@lockey1 ~]# telnet localhost 11211
Trying ::1...
Connected to localhost.
Escape character is '^]'.

Memcached 命令

1. Memcached set 与get gets命令

Memcached set 命令用于将 value(数据值) 存储在指定的 key(键) 中。

如果set的key已经存在,该命令可以更新该key所对应的原来的数据,也就是实现更新的作用。
语法:

set 命令的基本语法格式如下:

set key flags exptime bytes [noreply] 
value 

Memcached get 命令获取存储在 key(键) 中的 value(数据值) ,如果 key 不存在,则返回空。
Memcached gets 命令获取带有 CAS 令牌存 的 value(数据值) ,如果 key 不存在,则返回空。
多个 key 使用空格隔开,如下:

gets key1 key2 key3

参数说明如下:

key:键值 key-value 结构中的 key,用于查找缓存值。
flags:可以包括键值对的整型参数,客户机使用它存储关于键值对的额外信息 。
exptime:在缓存中保存键值对的时间长度(以秒为单位,0 表示永远)
bytes:在缓存中存储的字节数
noreply(可选): 该参数告知服务器不需要返回数据
value:存储的值(始终位于第二行)(可直接理解为key-value结构中的value)

示例:

[root@lockey1 ~]# telnet localhost 11211
Trying ::1...
Connected to localhost.
Escape character is '^]'.
set name 0 100 6      #####
lockey
STORED
get name    #####
VALUE name 0 6
lockey
END

输出信息说明:

STORED:保存成功后输出。
ERROR:在保持失败后输出。
2. Memcached add 命令

Memcached add 命令用于将 value(数据值) 存储在指定的 key(键) 中。

如果 add 的 key 已经存在,则不会更新数据(过期的 key 会更新),之前的值将仍然保持相同,并且您将获得响应 NOT_STORED。
语法:

add 命令的基本语法格式如下:

add key flags exptime bytes [noreply]
value

参数说明如下:

key:键值 key-value 结构中的 key,用于查找缓存值。
flags:可以包括键值对的整型参数,客户机使用它存储关于键值对的额外信息 。
exptime:在缓存中保存键值对的时间长度(以秒为单位,0 表示永远)
bytes:在缓存中存储的字节数
noreply(可选): 该参数告知服务器不需要返回数据
value:存储的值(始终位于第二行)(可直接理解为key-value结构中的value)

示例:

add new_key 0 199 8 
birthday
STORED
get new_key
VALUE new_key 0 8
birthday
END
3. Memcached replace 命令

Memcached replace 命令用于替换已存在的 key(键) 的 value(数据值)。

如果 key 不存在,则替换失败,并且您将获得响应 NOT_STORED。
语法:

replace 命令的基本语法格式如下:

replace key flags exptime bytes [noreply]
value

参数说明如下:

key:键值 key-value 结构中的 key,用于查找缓存值。
flags:可以包括键值对的整型参数,客户机使用它存储关于键值对的额外信息 。
exptime:在缓存中保存键值对的时间长度(以秒为单位,0 表示永远)
bytes:在缓存中存储的字节数
noreply(可选): 该参数告知服务器不需要返回数据
value:存储的值(始终位于第二行)(可直接理解为key-value结构中的value)

示例:

add mykey 0 900 10
data_value
STORED
get mykey
VALUE mykey 0 10
data_value
END
replace mykey 0 900 16
some_other_value
get mykey
VALUE mykey 0 16
some_other_value
END

4. Memcached append 和 prepend 命令

Memcached append 命令用于向已存在 key(键) 的 value(数据值) 后面追加数据 。
Memcached prepend 命令用于向已存在 key(键) 的 value(数据值) 前面追加数据 。
语法:

append 和 prepend 命令的基本语法格式如下:

append/prepend key flags exptime bytes [noreply]
value

参数说明如下:

key:键值 key-value 结构中的 key,用于查找缓存值。
flags:可以包括键值对的整型参数,客户机使用它存储关于键值对的额外信息 。
exptime:在缓存中保存键值对的时间长度(以秒为单位,0 表示永远)
bytes:在缓存中存储的字节数
noreply(可选): 该参数告知服务器不需要返回数据
value:存储的值(始终位于第二行)(可直接理解为key-value结构中的value)

5. emcached CAS 命令

Memcached CAS(Check-And-Set 或 Compare-And-Swap) 命令用于执行一个”检查并设置”的操作

它仅在当前客户端最后一次取值后,该key 对应的值没有被其他客户端修改的情况下, 才能够将值写入。

检查是通过cas_token参数进行的, 这个参数是Memcach指定给已经存在的元素的一个唯一的64位值。
语法:

CAS 命令的基本语法格式如下:

cas key flags exptime bytes unique_cas_token [noreply]
value

参数说明如下:

key:键值 key-value 结构中的 key,用于查找缓存值。
flags:可以包括键值对的整型参数,客户机使用它存储关于键值对的额外信息 。
exptime:在缓存中保存键值对的时间长度(以秒为单位,0 表示永远)
bytes:在缓存中存储的字节数
unique_cas_token通过 gets 命令获取的一个唯一的64位值。
noreply(可选): 该参数告知服务器不需要返回数据
value:存储的值(始终位于第二行)(可直接理解为key-value结构中的value)

实例

要在 Memcached 上使用 CAS 命令,你需要从 Memcached 服务商通过 gets 命令获取令牌(token)。

gets 命令的功能类似于基本的 get 命令。两个命令之间的差异在于,gets 返回的信息稍微多一些:64 位的整型值非常像名称/值对的 “版本” 标识符。

实例步骤如下:

如果没有设置唯一令牌,则 CAS 命令执行错误。
如果键 key 不存在,执行失败。
添加键值对。
通过 gets 命令获取唯一令牌。
使用 cas 命令更新数据
使用 get 命令查看数据是否更新

cas tp 0 900 9
ERROR             <− 缺少 token

cas tp 0 900 9 2
memcached
NOT_FOUND         <− 键 tp 不存在

set tp 0 900 9
memcached
STORED

gets tp
VALUE tp 0 9 1
memcached
END

cas tp 0 900 5 1
redis
STORED

get tp
VALUE tp 0 5
redis
END
6. Memcached delete 命令

Memcached delete 命令用于删除已存在的 key(键)。

delete 命令的基本语法格式如下:

delete key [noreply]

参数说明如下:

key:键值 key-value 结构中的 key,用于查找缓存值。
noreply(可选): 该参数告知服务器不需要返回数据
7. Memcached incr 与 decr 命令

Memcached incr 与 decr 命令用于对已存在的 key(键) 的数字值进行自增或自减操作。

incr 与 decr 命令操作的数据必须是十进制的32位无符号整数。

如果 key 不存在返回 NOT_FOUND,如果键的值不为数字,则返回 CLIENT_ERROR,其他错误返回 ERROR。
incr 命令的基本语法格式如下:

incr key increment_value

decr 命令的基本语法格式如下:

decr key decrement_value

参数说明如下:

key:键值 key-value 结构中的 key,用于查找缓存值。
increment_value: 增加的数值。
decrement_value:减少的值。

实例

在以下实例中,我们使用 visitors 作为 key,初始值为 10,之后进行加 5 操作。

set visitors 0 900 2
10
STORED
get visitors
VALUE visitors 0 2
10
END
incr visitors 5
15
get visitors
VALUE visitors 0 2
15
END
8. Memcached stats 、stats items、stats slabs、stats sizes、flush_all命令

Memcached stats 命令用于返回统计信息例如 PID(进程号)、版本号、连接数等。
stats 命令的基本语法格式如下:

stats

Memcached stats items 命令用于显示各个 slab 中 item 的数目和存储时长(最后一次访问距离现在的秒数)。
stats items 命令的基本语法格式如下:

stats items

Memcached stats slabs 命令用于显示各个slab的信息,包括chunk的大小、数目、使用情况等。
stats slabs 命令的基本语法格式如下:

stats slabs

Memcached stats sizes 命令用于显示所有item的大小和个数。

该信息返回两列,第一列是 item 的大小,第二列是 item 的个数。
stats sizes 命令的基本语法格式如下:

stats sizes

Memcached flush_all 命令用于用于清理缓存中的所有 key=>value(键=>值) 对。

该命令提供了一个可选参数 time,用于在制定的时间后执行清理缓存操作。
flush_all 命令的基本语法格式如下:

flush_all [time] [noreply]

PHP 连接 Memcached 服务

PHP Memcache 扩展安装

wget http://pecl.php.net/get/memcache-2.2.7.tgz               
tar -zxvf memcache-2.2.7.tgz
cd memcache-2.2.7
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config
make && make install

如果你是 PHP7 版本,则需要下载指定分支:

git clone -b php7 https://github.com/php-memcached-dev/php-memcached.git

安装成功后会显示你的memcache.so扩展的位置,比如我的:

[root@lockey1 no-debug-non-zts-20131226]# ls
memcache.so  opcache.a  opcache.so
[root@lockey1 no-debug-non-zts-20131226]# pwd
/usr/local/lnmp/php/lib/php/extensions/no-debug-non-zts-20131226

最后我们需要把这个扩展添加到php中,打开你的php.ini文件在最后添加以下内容:

[Memcache]
extension_dir = "/usr/local/lnmp/php/lib/php/extensions/no-debug-non-zts-20131226/"
extension = memcache.so

添加完后 重新启动php,我使用的是nginx+php-fpm,所以需要执行以下命令:

/etc/init.d/phg-fpm reload

安装成功会输出:memcache。

或者通过浏览器访问 phpinfo() 函数来查看,如下图:
这里写图片描述

PHP 连接 Memcached

<?php
$memcache = new Memcache;             //创建一个memcache对象
$memcache->connect('localhost', 11211) or die ("Could not connect"); //连接Memcached服务器
$memcache->set('key', 'test');        //设置一个变量到内存中,名称是key 值是test
$get_value = $memcache->get('key');   //从内存中取出key的值
echo $get_value;
?>

一般情况下在我们解压memcache-2.2.7.tgz之后产生的目录中会有两个测试文件(example.php/memcache.php):
这里写图片描述

我们可以把这两个文件拷贝到php解析目录下然后在浏览器中测试运行:
这里写图片描述

这里写图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值