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

    Python操作redis python连接方式:点击 下面介绍详细使用 1.String 操作 redis中的String在在内存中按照一个name对应一个value来存储 set() #在Redi ...

  2. ubuntu 安装tomcat<服务器>

    一.下载tomcat 可以先下载到本地,然后ftp到服务器 官方 Apache Tomcat 的下载页面(下面的链接是apache自己的镜像服务器的地址,不同网络连接的话,apache会给出不同的镜像 ...

  3. mysql经验总结

    1. 连接mysql遇到 Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2),mysql没有正常启动 $ ...

  4. 归并排序,时间复杂度nlogn

    思路: /*   考点:   1. 快慢指针:2. 归并排序.   此题经典,需要消化吸收.   复杂度分析:              T(n)            拆分 n/2, 归并 n/2 ...

  5. wpf GridControl selectAll UnSelect

    <Window x:Class="WpfApplication1.GridControlView" xmlns="http://schemas.microsoft. ...

  6. git 中遇到的问题

    刚创建的github版本库,在push代码时出错: $ git push -u origin masterTo git@github.com:******/Demo.git ! [rejected] ...

  7. 语音按钮功能之UIButton的UIControlEventTouchUpInside没有执行问题

    新版本im功能开发过程中,遇到个奇葩的问题. 就是点击语音按钮,点击一下松开,不执行UIControlEventTouchUpInside的方法.所以导致一直在录音 但是长按2秒以上,是可以执行UIC ...

  8. Codeforces 696E ...Wait for it...(树链剖分)

    题目链接  ...Wait for it... 考虑树链剖分. 对于树上的每个点开一个set,记录当前该节点上所有的girls. 每个节点初始的权值为set中的最小值. 询问的时候每次在路径上寻找最小 ...

  9. Unity3D Shader 入门之简单案例的实现(通过法线实现颜色变化)

    在没有接触Unity3D  Shader 之前,总感觉shader特别神奇,因为听说是对渲染流水线进行编程,就是对GPU进行编程.听着特别高大上.这不,最近刚刚接触Shader,学了几个小案例,然后本 ...

  10. 串口VMIN VTIME 详解

    原文地址: 以前跟着做过VxWorks的开发,主要通信方式是串口,因为底层BSP包已经做好了,串口通信非常简单.后来接触Linux,在一块OK6410上跑Linux串口通信,才发现原来天真的以为甚是简 ...