这个月我们新开发了一个项目,由于使用到了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管理
 

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

  1. [转载]用redis实现跨服务器session

    地址:http://blog.chinaunix.net/uid-11121450-id-3284875.html 这个月我们新开发了一个项目,由于使用到了4台机器做web,使用dns做负载均衡, 上 ...

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

    今天带来PHP实现跨服务器session共享的方法教程. 本文实例讲述了PHP实现cookie跨域session共享的方法.分享给大家供大家参考,具体如下: 做过web开发的小伙伴们都了解cookie ...

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

    1.跨子域和跨服务器解决方式 Session主要分两部分:   一个是Session数据,该数据默认情况下是存放在服务器的tmp文件下的,是以文件形式存在    另一个是标志着Session数据的Se ...

  4. 跨服务器的session共享

    四种 一.NFS(Net FileSystem): sun公司提供的,并发处理的效率不高,但操作方便 二.基于数据库的session共享 三.基于cookie的session共享 原理:将sessio ...

  5. PHP多台服务器跨域SESSION共享

    网站业务规模和访问量的逐步发展,原本由单台服务器.单个域名的迷你网站架构已经无法满足发展需要. 此时我们可能会购买更多服务器,并且启用多个二级子域名以频道化的方式,根据业务功能将网站分布部署在独立的服 ...

  6. 跨服务器之间的session共享

    跨服务器之间的Session共享方案需求变得迫切起来,最终催生了多种解决方案,下面列举4种较为可行的方案进行对比探讨: 1. 基于NFS的Session共享 NFS是Net FileSystem的简称 ...

  7. Redis安装及实现session共享

    一.Redis介绍 1.redis是key-value的存储系统,属于非关系型数据库 2.特点:支持数据持久化,可以让数据在内存中保存到磁盘里(memcached:数据存在内存里,如果服务重启,数据会 ...

  8. Using Redis to store php session

    Using Redis to store php session 默认情况下,php将会将session信息存储在文件系统上,在单机情况下没有问题,但是当系统负载增大,或者在对系统可用性要求很高的场景 ...

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

    php默认使用文件存储session,如果并发量大,效率非常低.而Redis对高并发的支持非常好,所以,可以使用redis替代文件存储session. 这里,介绍下php的 session_set_s ...

随机推荐

  1. 通过FEDERATED存储引擎同步两实例间的表数据

    需求情景:实例1中A库中的三个视图是实例2中的B库所依赖的,B需要A库中三个视图的实时数据. 方案:通过FEDERATED来完成跨势力的查询FEDERATED存储引擎表只会创建表结构,不会存储表数据, ...

  2. Linux Shell系列教程之(八)Shell printf命令详解

    本文是Linux Shell系列教程的第(八)篇,更多shell教程请看:Linux Shell系列教程 在上一篇:Linux Shell系列教程之(七)Shell输出这篇文章中,已经对Shell p ...

  3. 知名游戏引擎公司Havok发布免费3D移动游戏引擎“Project Anarchy”

    自EA发布“寒霜”引擎(Frostbite Engine)移动版后,知名游戏引擎公司Havok也发布了免费的3D移动游戏引擎“Project Anarchy”. 据悉,6月底时候,Intel旗下知名游 ...

  4. 【bzoj4292】[PA2015]Równanie 暴力

    题目描述 对于一个正整数n,定义f(n)为它十进制下每一位数字的平方的和.现在给定三个正整数k,a,b,请求出满足a<=n<=b且k*f(n)=n的n的个数. 输入 第一行包含三个正整数k ...

  5. HDU——1272小希的迷宫(并查集+拓扑排序)

    小希的迷宫 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Subm ...

  6. BZOJ2326 [HNOI2011]数学作业 【矩阵快速幂】

    题解 我们设f[i]表示前i个数模M意义下的答案 则f[i] = f[i - 1] * 100...0 + i[i是几位就有几个0] 可以写出矩阵递推式: 之后按位数分组矩乘就好了 #include& ...

  7. [USACO Section 4.4]追查坏牛奶Pollutant Control (最小割)

    题目链接 Solution 一眼看过去就是最小割,但是要求割边最少的最小的割. 所以要用骚操作... 建边的时候每条边权 \(w = w * (E+1) + 1;\) 那么这样建图跑出来的 \(max ...

  8. P2258 子矩阵 (搜索,动态规划)

    题目链接 Solution 搜索+DP. 刚好把搜索卡死的数据范围... 然后应该可以很容易想到枚举行的情况,然后分列去DP. 行的情况直接全排列即可,复杂度最高 \(O(C_{16}^{8})\). ...

  9. java面试题之happens before原则

    JSR-133使用happens-before的概念来指定两个操作之间的执行顺序.由于这两个操作可以在一个线程内,也可以在不同线程之间.因此,JMM可以通过happens-before关系向程序员提供 ...

  10. JDBC链接mysql,时间时0000-00-00 00:00:00时报错

    应为mysql默认最小timestamp是0001-01-01 00:00:00,所以查询出来会报错 需要加在链接的url中加入 &zeroDateTimeBehavior=convertTo ...