专注WEB开发 分享经验,沉淀知识

php项目redis实现session共享案例

 作者:chenxing  时间:2017-09-14 09:32  评论:

当然你可以把以上的配置直接更改php.ini中的session.save_handler和session.save_path,这样所以的项目都会用的这个redis共享session了

前两天分别写了开发环境和生产环境下的php-redis拓展安装。

有前面两天的铺垫,今天来谈谈redis的一次实践——实现session共享。

案例场景

网站在线上生产环节中做了负载均衡,之前常用的文件形式存储的session,不在适合当前的环境,session必须实现共享。

如何实现共享

线上生产环境使用的是阿里云服务器,所以redis选择阿里的redis云数据库。redis云数据库(注意是云数据库)天然具有共享的特性,我们可以把负载均衡中多个服务器的共享信息存到了云这个公共区域。这样子就实现了共享的目的。

剩下的事儿就是考虑如何把session存到redis中。

redis如何存session

这个redis存储session网上资料很多。但大多数都是针对本地redis,学习测试还是可以得。实际的生成环境使用redis云比较多,从硬件角度看,既然用的了redis肯定是本地的资源不够用了,如果还在本地配redis只会更加消耗本地内存,使用额外的硬件配置就成了一个选择——redis云数据库。

那么redis云数据库是怎么存session的呢?

如果你现在手里有redis云数据库那么就可以开始了,没有直接去官网买一个来做测试吧。花一两块钱就可以做一次生产环境中的redis实践,这个买卖还是值得的。

如果你是土豪那就无所谓了!

到控制面板上获取redis云数据库的地址,端口,密码,再选择一个database值(有256可以使用)这四个参数组成session.save_path值。在项目开启session_start之前的位置添加以下代码,在thinkphp3.2中可以直接加在入口文件上,因为session默认是开启得。

ini_set('session.save_handler','redis');
ini_set('session.save_path','tcp://r-m5e1d555c570d0f4.redis.rds.aliyuncs.com:6379?auth=mimi666&database=1');

当然你可以把以上的配置直接更改php.ini中的session.save_handler和session.save_path,不过这样有一个缺点就是所有在此服务器的php的项目都会用到这个redis共享session。在代码层配置是比较稳妥的方式。

测试结束请及时释放实例

如果你不是土豪,测试完了请及时释放实例,我就被阿里坑了一把,发邮件说只欠费1块多就没有及时释放,过了一天跑后台一看欠费70多块钱。啊,心痛,我一天的饭钱没了。

好了,以上就是线上php项目中redis的共享实践,只是这次测试代价有点大~

除特别注明外,本站所有文章均为作者原创。 或分享自己的编程经验,或探讨工作中的问题,或聊以人生趣事。 转载请注明出处来自 https://www.qiusuoweb.com/96.html

发布评论

 提交评论
有人回复时邮件通知我

 评论(0)

站长头像
chenxing(PHP攻城狮)

运营天数

总访问量

文章数量

-

-

-

交流群:157451741

新浪微博:草莽兴

 近期文章

ssh 使用密钥登录

 2025-06-12 18:33  9

聊聊国产化

 2024-08-24 15:56  108

内网穿透工具frp配置详情

 2024-07-18 22:30  212

mac在终端复制出现乱码00~ *** 01~

 2024-07-16 20:38  47

php html生成图片

 2024-07-08 20:25  87

scp命令使用说明

 2024-07-06 12:14  123

 最新评论

 tradeOff: 08月30日 10:19
在某些领域国产化是一个迫不得已的事儿
来源: 聊聊国产化
 sue: 07月03日 10:24
可以
来源: 微信小程序如何获取单个input值
 流年: 07月02日 11:31
不错的尝试
来源: 博客系统如何用markdown编辑器发布文章
 诚心: 09月29日 23:01
学到了
来源: 如何一次性推送百万级别的消息
 Nick: 04月14日 12:26
网上的资料还是太老,都只是取一个元素,解决了一大难题
来源: redis set集合取出一组数据并删除
 skywalker: 11月03日 18:21
简洁明了
来源: mysql 获取某个日期的前一天或后一天