php中的Session默认是用文件的方式存储的,若是用多台WEB服务器,Session共享可能就会成为一个大的问题,能够用NFS共享的方式来存储,可是对于并发请求更多的站点来讲,用NFS也会出现问题,下面就说说用Memcached来保存Session的问题。php
vi memcached_session.php,输入以下的代码
<?php
$ip = '192.168.1.111';
$port = 11211;
ini_set("session.save_handler", "memcache");
ini_set("session.save_path", "tcp://$ip:$port");算法
session_start();
$_SESSION['time'] = time();
print 'time:' . $_SESSION['time'];
print "<br>";
$key = session_id();
print 'session_id:' . $key;
print "<br>";浏览器
$memcache = new Memcache;
$memcache->addServer($ip, $port);
echo "ke: $key value:" . $memcache -> get($key);
?>
程序的输出结果以下:
time:1251362605
session_id:7c694d1c2fea5dd3c56f7a19d2f925c9
ke: 7c694d1c2fea5dd3c56f7a19d2f925c9 value:time|i:1251362604;缓存
从上图能够看出,保存在Memcached中的Session数据,key为客户端生成的SessionID,也就是名为PHPSESSID的cookie保存的值,值为Session的值($_SESSION['time'] = time();)服务器
上述结果能够说明Session数据已经成功保存到Memcached中了cookie
固然也能够直接在php.ini中修改全局配置,这样,不须要在每一个与session有关的程序都须要调用ini_set了
session.save_handler = memcache
session.save_path = "tcp://192.168.1.111:11211"session
使用多个memcached server 时用逗号","隔开,而且和 Memcache::addServer() 文档中说明的同样,能够带额外的参数"persistent"、"weight"、"timeout"、"retry_interval" 等等,相似这样的:"tcp://host1:port1?persistent=1&weight=2,tcp://host2:port2" 。并发
也能够直接telnet到Memcached中用get session_id来查找Session数据
[root@CentOS_Test_Server ~]# telnet 192.168.1.111 11211
Trying 192.168.1.111...
Connected to 192.168.1.111 (192.168.1.111).
Escape character is '^]'.
get 7c694d1c2fea5dd3c56f7a19d2f925c9
VALUE 7c694d1c2fea5dd3c56f7a19d2f925c9 0 18
time|i:1251362209;
END
set name 0 0 10
caihuafeng
STORED
get name
VALUE name 0 10
caihuafeng
ENDtcp
用 memcache 来存储 session 在读写速度上应该会比文件快不少,并且在多个服务器须要共用 session 时会比较方便,将这些服务器都配置成使用同一组 memcached 服务器就能够,减小了额外的工做量。缺点是 session 数据都保存在内存中,不能持久化存储,若是想持久化存储,能够考虑使用Memcachedb来存储,或用Tokyo Tyrant+Tokyo Cabinet来进行存储。ide
怎样判断session失效了呢?在php.ini中有个Session.cookie_lifetime的选项,这个表明SessionID在客户端Cookie储存的时间,默认值是“0”,表明浏览器一关闭,SessionID就做废,这样无论保存在Memcached中的Session是否还有效(保存在Memcached中的session会利用Memcached的内部机制进行处理,即便session数据没有失效,而因为客户端的SessionID已经失效,因此这个key基本上不会有机会使用了,利用Memcached的LRU原则,若是Memcached的内存不够用了,新的数据就会取代过时以及最老的未被使用的数据),由于SessionID已经失效了,因此在客户端会从新生成一个新的SessionID。
保存在Memcached中的数据最长不会超过30天,这个时间是以操做Memcached的时间为基准的,也就是说,只要key仍是原来的key,若是你从新对此key进行了相关的操做(如set操做),且从新设置了有效期,则此时此key对应的数据的有效期会从新计算的,php手册中有说明
Expiration time of the item. If it's equal to zero, the item will never expire. You can also use Unix timestamp or a number of seconds starting from current time, but in the latter case the number of seconds may not exceed 2592000 (30 days).
Memcached主要的cache机制是LRU(最近最少用)算法+超时失效。当您存数据到memcached中,能够指定该数据在缓存中能够呆多久。若是memcached的内存不够用了,过时的slabs会优先被替换,接着就轮到最老的未被使用的slabs。