1简介:
Memcache(内存缓存) 是一个高性能的分布式的内存对象缓存系统。通过在内存里维护一个巨大的hash表。
其实简单说点就是一个软件,可以用来维护内存,将数据在内存中使用,减少I/O
2工作原理:
memcached是以守护程序方式运行于一个或多个服务器中,随时会接收客户端的连接和操作。
3安装:
分为两个过程:memcache服务器端的安装和memcahe客户端的安装
1)客户端安装:
所谓客户端安装就是php(或其他程序)去使用服务器端的Memcache提供的函数,需要php添加扩展
2)服务器端安装
windows下安装:
Memcahced.exe -d install [uninstall]
linux下安装
由于是基于libevent事件,因此需要先安装libevent
安装libevent时
./configure –with-libevent=/usr
Make && make install
安装memcached
./configure –with-libevent=/usr
Make && make install
4使用telnet命令操作memcached
telnet 127.0.0.1 11211
成功连接后,回车两次就可以进行操作了。
5Memcache的安全
Memcache服务器端都是直接通过客户端连接后直接操作,没有任何验证过程,这样如果服务器直接暴露在互联网的话,是比较危险的。为了安全起见,建议两点。
1)最好把两台服务器之间的访问时内网形式的,一般是web服务器跟Memcache服务器之间。普遍的服务器器都是有两块网卡,一块指向互联网,一块指向内网,那么就让web服务器通过内网的网卡来访问Memcache服务器,我们Memcache的服务器上启动时就监听内网的IP地址和端口,内网间的访问能够有效阻止其他非法的访问。
# memcached -d -m 1024 -u root -l 192.168.0.200 -p 11211 -c 1024 -P /tmp/memcached.pid
下面代码是使用php连接memcache中的小实例
<?php $mem=new Memcache; $mem->connect('localhost',11211); $mem->add('mystr','this is a memcache test!',MEMCACHE_COMPRESSED,3600);//增加一个条目到缓存服务器
$mem->set('mystr','this is another test!',MEMCACHE_COMPRESSED,3600); $mem->add('myarr',array('aa','bb','cc')); echo$mem->get('mystr'); //print_r($mem->get('myarr'));
class Person{ public $name='123'; function test(){ echo "this is a test"; } } $p=new Person; $mem->add('myobj',$p); var_dump($mem->get('myobj')); echo "<br/>"; echo $mem->getversion(); echo "<br/>"; echo "<pre>"; print_r($mem->getstats()); echo "</pre>"; $mem->close();
ps:$mem->add()第四个参数是指定过期时间,如果此值设置为0表明此数据永不过期。你可以设置一个UNIX时间戳或 以秒为单位的整数(从当前算起的时间差)来说明此数据的过期时间,但是在后一种设置方式中,不能超过 2592000秒(30天)。
在面试题中见到一个是设置31天,这个参数就不能写成$mem->add(,,,31*24*3600),而应写成$mem->add(,,,time()+31*24*3600)