地址:http://blog.chinaunix.net/uid-11121450-id-3284875.html

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

    这个月我们新开发了一个项目,由于使用到了4台机器做web,使用dns做负载均衡, 上面图上用户通过DNS的调度(一个域名对应多个ip)分别访问到VM2-VM5上,四台机器都访问VM1上的redis,两 ...

  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. 题解 Cover

    传送门 考场上坚持认为树上背包可以有70pts,于是爆零了 首先我以为是树上背包的部分分其实是树形DP 然后极其魔鬼的正解: 首先我们令 \(dp[i][j]\) 为以i为根的子树覆盖次数至多为j时的 ...

  2. CF1264D2 Beautiful Bracket Sequence

    我们枚举每两个字符的空档,统计一个空档左边有 \(l\) 个左括号, 右边有 \(r\) 个右括号,左边有 \(u\) 个问号,右边有 \(v\) 个问号. 则对于 \(p\) 的答案 \(ans_p ...

  3. C#中的几种锁:用户模式锁、内核模式锁、动态计数、监视锁

    参考网址: https://blog.csdn.net/weixin_43989331/article/details/105356008 C#中的几种锁:用户模式锁.内核模式锁.动态计数.监视锁介绍 ...

  4. 第13篇-通过InterpreterCodelet存储机器指令片段

    在TemplateInterpreterGenerator::generate_all()函数中生成了许多字节码指令以及一些虚拟机辅助执行的机器指令片段,例如生成空指针异常抛出入口的实现如下: { C ...

  5. APMServ中Apache启动失败的原因

    APMServ中Apache启动失败绝大多数的情况是因为APMServ得路径出错和80端口被占用,也有可能您使用的是WIN8系统,下面SJY根据不同情况告诉大家如何解决APMServ中Apache启动 ...

  6. shell脚本 批量添加删除用户

    2021-07-26 1.批量添加用户 # 编写脚本 vi add_student_50.sh # 添加用户组 student groupadd student # 添加用户 student1-stu ...

  7. Blazor 组件库开发指南

    翻译自 Waqas Anwar 2021年5月21日的文章 <A Developer's Guide To Blazor Component Libraries> [1] Blazor 的 ...

  8. SSH无法正常连接服务器

    远程权限没有打开 #允许root登录 PermitRootLogin yes #不允许空密码登录 PermitEmptyPasswords no 远端的ssh信息有变化,本地保存的那个需要删掉 Use ...

  9. 从零开始实现简单 RPC 框架 9:网络通信之心跳与重连机制

    一.心跳 什么是心跳 在 TPC 中,客户端和服务端建立连接之后,需要定期发送数据包,来通知对方自己还在线,以确保 TPC 连接的有效性.如果一个连接长时间没有心跳,需要及时断开,否则服务端会维护很多 ...

  10. rtsp->rtmp 推流直播 Plan B

    上篇文章我们谈到使用 EasyDarwin 推流后 前端HTML播放器 播放无画面的情况,找了各种播放器都服务正常解决,但使用VLC却能正常播放的问题,我们尝试了很久最后另辟蹊径,找到 nginx安装 ...