在这里简单说下我遇到的memcache的一些应用场景:
1、对查询结果进行缓存,减少数据库查询次数,降低数据库查询压力;
2、mysql 主从延迟的数据可以用memcache进行适当处理,作为master和slave之间的过度,根据具体业务进行使用
3、session存入memcache
这个重点在这里提一下:
session默认是存储在服务器的临时文件夹下,量大是IO操作会限制session的存取,这里用memcache来保存session数据,通过缓存操作大大提高了session的存取性能,缺点就是一单服务器宕机,session数据存在memory中会全部丢失,但对于session存储的数据来说影响不是很大,其本身就是临时性数据。下面简述具体流程:
1、修改配置 save_handler && save_path
方式一:修改php.ini
session.save_handler = memcache
session.save_path = "tcp://127.0.0.1:11211"
方式二:项目目录下的 .htaccess :
php_value session.save_handler "memcache"
php_value session.save_path "tcp://127.0.0.1:11211"
方式三:在应用中设置
ini_set("session.save_handler", "memcache");
ini_set("session.save_path", "tcp://127.0.0.1:11211");
2、写代码测试:
session_start();
if (!isset($_SESSION['time'])) {
$_SESSION['time'] = time();
}
print $_SESSION['time'];
print "<br><br>";
print session_id();
发现session可以正常使用
倘若我们想看一下memcache中存储数据,直接用上面获得session_id去memcache中取出查看就好:
$memcache = memcache_connect('localhost', 11211);
var_dump($memcache->get('这里是刚才输出的session_id'));
这样我们可以看到具体的memcache中存储的session内容。