用redis实现跨服务器session(转)

这个月我们新开发了一个项目,由于使用到了4台机器做web,使用dns做负载均衡,

上面图上用户通过DNS的调度(一个域名对应多个ip)分别访问到VM2-VM5上,四台机器都访问VM1上的redis,两个redis值主从结构.

因此需要使用跨服务器的session保存用户登录状态,于是我写了一个跨站的session共享的类

点击(此处)折叠或打开

  1. <?php
  2. /*
  3. *用redis实现跨服务器session
  4. *注意需要安装phpredis模块
  5. *
  6. *作者:yifangyou
  7. *日期:2012-07-23 22:55:00
  8. **/
  9. class RedisSession{
  10. var $expire=86400;//过期时间
  11. var $sso_session;//session id
  12. var $session_folder;//session目录
  13. var $cookie_name;//cookie的名字
  14. var $redis;//redis连接
  15. var $cache;//缓存session
  16. var $expireAt;//过期时间
  17. /*
  18. *初始化
  19. *参数
  20. *$redis:php_redis的类实例
  21. *$cookie_name:cookie的名字
  22. *$session_id_prefix:sesion id的前缀
  23. **/
  24. function RedisSession($redis,$expire=86400,$cookie_name="sso_session",$session_id_prefix=""){
  25. $this->redis=$redis;
  26. $this->cookie_name=$cookie_name;
  27. $this->session_folder="sso_session:";
  28. //若是cookie已经存在则以它为session的id
  29. if(isset($_COOKIE[$this->cookie_name])){
  30. $this->sso_session=$_COOKIE[$this->cookie_name];
  31. }else{
  32. $this->expire=$expire;
  33. $this->expireAt=time()+$this->expire;
  34. //在IE6下的iframe无法获取到cookie,于是我使用了get方式传递了cookie的名字
  35. if(isset($_GET[$this->cookie_name])){
  36. $this->sso_session=$_GET[$this->cookie_name];
  37. }else{
  38. $this->sso_session=$this->session_folder.$session_prefix.md5(uniqid(rand(), true));
  39. }
  40. setcookie($this->cookie_name,$this->sso_session,$this->expireAt,"/");
  41. }
  42. }
  43. /*
  44. *设置过期时间
  45. *参数
  46. **/
  47. function expire($expire=86400){
  48. $this->expire=$expire;
  49. $this->expireAt=time()+$this->expire;
  50. //设置session过期时间
  51. setcookie($this->cookie_name,$this->sso_session,$this->expireAt,"/",".greatwallwine.com.cn");
  52. $this->redis->expireAt($this->sso_session, $this->expireAt);
  53. }
  54. /*
  55. *设置多个session的值
  56. *参数
  57. *$array:值
  58. **/
  59. function setMutil($array){
  60. $this->redis->hMset($this->sso_session,$array);
  61. }
  62. /*
  63. *设置session的值
  64. *参数
  65. *$key:session的key
  66. *$value:值
  67. **/
  68. function set($key,$value){
  69. $this->redis->hSet($this->sso_session,$key,$value);
  70. }
  71. /*
  72. *设置session的值为对象
  73. *参数
  74. *$key:session的key
  75. *$object:对象
  76. **/
  77. function setObject($key,$object){
  78. $this->redis->hSet($this->sso_session,$key,serialize($object));
  79. }
  80. /*
  81. *获取全部session的key和value
  82. @return: array
  83. **/
  84. function getAll(){
  85. return $this->redis->hGetAll($this->sso_session);
  86. }
  87. /*
  88. *获取一个session的key和value
  89. @return: array
  90. **/
  91. function get($key){
  92. return $this->redis->hGet($this->sso_session,$key);
  93. }
  94. /*
  95. *获取session的值为对象
  96. *参数
  97. *$key:session的key
  98. *$value:cookie的名字
  99. **/
  100. function getObject($key){
  101. return unserialize($this->redis->hGet($this->sso_session,$key));
  102. }
  103. /*
  104. *从缓存中获取一个session的key和value
  105. @return: array
  106. **/
  107. function getFromCache($key){
  108. if(!isset($this->cache)){
  109. $this->cache=$this->getAll();
  110. }
  111. return $this->cache[$key];
  112. }
  113. /*
  114. *删除一个session的key和value
  115. @return: array
  116. **/
  117. function del($key){
  118. return $this->redis->hDel($this->sso_session,$key);
  119. }
  120. /*
  121. *删除所有session的key和value
  122. @return: array
  123. **/
  124. function delAll(){
  125. return $this->redis->delete($this->sso_session);
  126. }
  127. }
  128. ?>

使用方法:

点击(此处)折叠或打开

  1. <?php
  2. error_reporting(0);
  3. $redisHost="192.168.1.2";
  4. $redisPort="6379";
  5. $redis = new Redis();
  6. $redis->connect($redisHost,$redisPort);
  7. include_once("inc/RedisSession.php");
  8. $redisSession=new RedisSession($redis);
  9. /*
  10. $redisSession->set("name","sdf4");
  11. $redisSession->set("age",1234);
  12. $redisSession->set("***","man14");
  13. $redisSession->set("name","abc4");
  14. $redisSession->setMutil(array("province"=>"guangdong","city"=>"guangzhou"));
  15. */
  16. $redisSession->setObject("obj",array("test1"=>array("test2")));
  17. $obj=$redisSession->getObject("obj");
  18. print_r($obj);
  19. die();
  20. print_r($redisSession->getAll());
  21. //$redisSession->del("name");
  22. print_r($redisSession->get("name"));
  23. //print_r($redisSession->get("province"));
  24. //$redisSession->delAll();
  25. //print_r($redisSession->getAll());
  26. print_r($redisSession->getFromCache("name"));
  27. /*
  28. $redisSession->del("name");
  29. $redisSession->delAll();
  30. */

比较常用的估计是set,get,setObject,getOject

我用sso_session:我主要是方便用phpRedisAdmin管理

时间: 2024-10-13 20:28:06

用redis实现跨服务器session(转)的相关文章

PHP实现跨服务器session共享的方法教程

今天带来PHP实现跨服务器session共享的方法教程. 本文实例讲述了PHP实现cookie跨域session共享的方法.分享给大家供大家参考,具体如下: 做过web开发的小伙伴们都了解cookie和session,cookie是存储在客户端的,session是存储在服务器的. 本篇主要通过一些实践中的案例和大家分享一下踩到坑,重点说明了cookie跨域问题和session服务器共享问题,以php语言为使用语言进行说明. 先聊聊cookie 设置cookie无效 1 setcookie("ss

Resin 跨服务器的session传递

Resin 跨服务器的session传递 --By oldjavaman 1.   基于文件的session持久化技术 Seesion能够被跨服务器持久化, 包含我们的web应用的Class发生变化, 譬如在开发期间,使用基于文件的持久化Seesion技术是非常便捷的, 尤其是我们在开发时, 当Servlet会发生经常变化 在resin.conf中配置如下 <web-app xmlns="http://caucho.com/ns/resin">   <session-

PHP多台服务器跨域SESSION共享

网站业务规模和访问量的逐步发展,原本由单台服务器.单个域名的迷你网站架构已经无法满足发展需要. 此时我们可能会购买更多服务器,并且启用多个二级子域名以频道化的方式,根据业务功能将网站分布部署在独立的服务器上:或通过负载均衡技术 (如:DNS轮询.Radware.F5.LVS等)让多个频道共享一组服务器. OK,头脑中我们已经构思了这样的解决方案,不过进入深入开发后新的技术问题又随之而来: 我们把网站程序分布部署到多台服务器上,而且独立为几个二级域名,由于Session受实现原理的局限(PHP中S

跨服务器之间的session共享

跨服务器之间的Session共享方案需求变得迫切起来,最终催生了多种解决方案,下面列举4种较为可行的方案进行对比探讨: 1. 基于NFS的Session共享 NFS是Net FileSystem的简称,最早由Sun公司为解决Unix网络主机间的目录共享而研发. 这个方案实现最为简单,无需做过多的二次开发,仅需将共享目录服务器mount到各频道服务器的 本地session目录即可,缺点是NFS依托于复杂的安全机制和文件系统,因此并发效率不高,尤其对于session这类高并发读写的小文件, 会由于共

php 跨域、跨子域,跨服务器读取session

1.跨子域和跨服务器解决方式 Session主要分两部分:   一个是Session数据,该数据默认情况下是存放在服务器的tmp文件下的,是以文件形式存在    另一个是标志着Session数据的Session Id,Session ID,就是那个 Session 文件的文件名,Session ID 是随机生成的,因此能保证唯一性和随机性,确保 Session 的安全.一般如果没有设置 Session 的生存周期,则 Session ID 存储在内存中,关闭浏览器后该 ID 自动注销,重新请求该

Using Redis to store php session

Using Redis to store php session 默认情况下,php将会将session信息存储在文件系统上,在单机情况下没有问题,但是当系统负载增大,或者在对系统可用性要求很高的场景下,当台机器不仅处理能力跟不上,而且当机器故障时整个系统就处于不可用状态了.所以多机器负载均衡就非常有必要了.但是问题来了,假设现在系统有两台应用服务器serverA,serverB,用户X现在已经登录了,而登录状态众所周知是存储在应用服务器的session中的,如果用户X的登录请求是serverA

缓存一致性和跨服务器查询的数据异构解决方案canal

当你的项目数据量上去了之后,通常会遇到两种情况,第一种情况应是最大可能的使用cache来对抗上层的高并发,第二种情况同样也是需要使用分库 分表对抗上层的高并发...逼逼逼起来容易,做起来并不那么乐观,由此引入的问题,不见得你有好的解决方案,下面就具体分享下. 一:尽可能的使用Cache 比如在我们的千人千面系统中,会针对商品,订单等维度为某一个商家店铺自动化建立大约400个数据模型,然后买家在淘宝下订单之后,淘宝会将订单推 送过来,订单会在400个模型中兜一圈,从而推送更贴切符合该买家行为习惯的

数据异构解决方案缓存一致性和跨服务器查询

缓存一致性和跨服务器查询的数据异构解决方案canal 当你的项目数据量上去了之后,通常会遇到两种情况,第一种情况应是最大可能的使用cache来对抗上层的高并发,第二种情况同样也是需要使用分库 分表对抗上层的高并发...逼逼逼起来容易,做起来并不那么乐观,由此引入的问题,不见得你有好的解决方案,下面就具体分享下. 一:尽可能的使用Cache 比如在我们的千人千面系统中,会针对商品,订单等维度为某一个商家店铺自动化建立大约400个数据模型,然后买家在淘宝下订单之后,淘宝会将订单推 送过来,订单会在4

PHP中Redis替代文件存储Session语句

php默认使用文件存储session,如果并发量大,效率非常低.而Redis对高并发的支持非常好,所以,可以使用redis替代文件存储session. 这里,介绍下php的 session_set_save_handler 函数的作用和使用方法.该函数定义用户级session保存函数(如打开.关闭.写入等).原型如下: bool session_set_save_hanler(callback open,callback close,callback read,callback write,ca