memcache(三)应用场景,session存入memcache

在这里简单说下我遇到的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内容。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值