[转载]用redis实现跨服务器session
地址:http://blog.chinaunix.net/uid-11121450-id-3284875.html
这个月我们新开发了一个项目,由于使用到了4台机器做web,使用dns做负载均衡,
点击(此处)折叠或打开
- <?php
- /*
- *用redis实现跨服务器session
- *注意需要安装phpredis模块
- *
- *作者:yifangyou
- *日期:2012-07-23 22:55:00
- **/
- class RedisSession{
- var $expire=86400;//过期时间
- var $sso_session;//session id
- var $session_folder;//session目录
- var $cookie_name;//cookie的名字
- var $redis;//redis连接
- var $cache;//缓存session
- var $expireAt;//过期时间
- /*
- *初始化
- *参数
- *$redis:php_redis的类实例
- *$cookie_name:cookie的名字
- *$session_id_prefix:sesion id的前缀
- **/
- function RedisSession($redis,$expire=86400,$cookie_name="sso_session",$session_id_prefix=""){
- $this->redis=$redis;
- $this->cookie_name=$cookie_name;
- $this->session_folder="sso_session:";
- //若是cookie已经存在则以它为session的id
- if(isset($_COOKIE[$this->cookie_name])){
- $this->sso_session=$_COOKIE[$this->cookie_name];
- }else{
- $this->expire=$expire;
- $this->expireAt=time()+$this->expire;
- //在IE6下的iframe无法获取到cookie,于是我使用了get方式传递了cookie的名字
- if(isset($_GET[$this->cookie_name])){
- $this->sso_session=$_GET[$this->cookie_name];
- }else{
- $this->sso_session=$this->session_folder.$session_prefix.md5(uniqid(rand(), true));
- }
- setcookie($this->cookie_name,$this->sso_session,$this->expireAt,"/");
- }
- }
- /*
- *设置过期时间
- *参数
- **/
- function expire($expire=86400){
- $this->expire=$expire;
- $this->expireAt=time()+$this->expire;
- //设置session过期时间
- setcookie($this->cookie_name,$this->sso_session,$this->expireAt,"/",".greatwallwine.com.cn");
- $this->redis->expireAt($this->sso_session, $this->expireAt);
- }
- /*
- *设置多个session的值
- *参数
- *$array:值
- **/
- function setMutil($array){
- $this->redis->hMset($this->sso_session,$array);
- }
- /*
- *设置session的值
- *参数
- *$key:session的key
- *$value:值
- **/
- function set($key,$value){
- $this->redis->hSet($this->sso_session,$key,$value);
- }
- /*
- *设置session的值为对象
- *参数
- *$key:session的key
- *$object:对象
- **/
- function setObject($key,$object){
- $this->redis->hSet($this->sso_session,$key,serialize($object));
- }
- /*
- *获取全部session的key和value
- @return: array
- **/
- function getAll(){
- return $this->redis->hGetAll($this->sso_session);
- }
- /*
- *获取一个session的key和value
- @return: array
- **/
- function get($key){
- return $this->redis->hGet($this->sso_session,$key);
- }
- /*
- *获取session的值为对象
- *参数
- *$key:session的key
- *$value:cookie的名字
- **/
- function getObject($key){
- return unserialize($this->redis->hGet($this->sso_session,$key));
- }
- /*
- *从缓存中获取一个session的key和value
- @return: array
- **/
- function getFromCache($key){
- if(!isset($this->cache)){
- $this->cache=$this->getAll();
- }
- return $this->cache[$key];
- }
- /*
- *删除一个session的key和value
- @return: array
- **/
- function del($key){
- return $this->redis->hDel($this->sso_session,$key);
- }
- /*
- *删除所有session的key和value
- @return: array
- **/
- function delAll(){
- return $this->redis->delete($this->sso_session);
- }
- }
- ?>
使用方法:
点击(此处)折叠或打开
- <?php
- error_reporting(0);
- $redisHost="192.168.1.2";
- $redisPort="6379";
- $redis = new Redis();
- $redis->connect($redisHost,$redisPort);
- include_once("inc/RedisSession.php");
- $redisSession=new RedisSession($redis);
- /*
- $redisSession->set("name","sdf4");
- $redisSession->set("age",1234);
- $redisSession->set("***","man14");
- $redisSession->set("name","abc4");
- $redisSession->setMutil(array("province"=>"guangdong","city"=>"guangzhou"));
- */
- $redisSession->setObject("obj",array("test1"=>array("test2")));
- $obj=$redisSession->getObject("obj");
- print_r($obj);
- die();
- print_r($redisSession->getAll());
- //$redisSession->del("name");
- print_r($redisSession->get("name"));
- //print_r($redisSession->get("province"));
- //$redisSession->delAll();
- //print_r($redisSession->getAll());
- print_r($redisSession->getFromCache("name"));
- /*
- $redisSession->del("name");
- $redisSession->delAll();
- */
比较常用的估计是set,get,setObject,getOject

[转载]用redis实现跨服务器session的更多相关文章
- 用redis实现跨服务器session(转)
这个月我们新开发了一个项目,由于使用到了4台机器做web,使用dns做负载均衡, 上面图上用户通过DNS的调度(一个域名对应多个ip)分别访问到VM2-VM5上,四台机器都访问VM1上的redis,两 ...
- PHP实现跨服务器session共享的方法教程
今天带来PHP实现跨服务器session共享的方法教程. 本文实例讲述了PHP实现cookie跨域session共享的方法.分享给大家供大家参考,具体如下: 做过web开发的小伙伴们都了解cookie ...
- php 跨域、跨子域,跨服务器读取session
1.跨子域和跨服务器解决方式 Session主要分两部分: 一个是Session数据,该数据默认情况下是存放在服务器的tmp文件下的,是以文件形式存在 另一个是标志着Session数据的Se ...
- 跨服务器的session共享
四种 一.NFS(Net FileSystem): sun公司提供的,并发处理的效率不高,但操作方便 二.基于数据库的session共享 三.基于cookie的session共享 原理:将sessio ...
- PHP多台服务器跨域SESSION共享
网站业务规模和访问量的逐步发展,原本由单台服务器.单个域名的迷你网站架构已经无法满足发展需要. 此时我们可能会购买更多服务器,并且启用多个二级子域名以频道化的方式,根据业务功能将网站分布部署在独立的服 ...
- 跨服务器之间的session共享
跨服务器之间的Session共享方案需求变得迫切起来,最终催生了多种解决方案,下面列举4种较为可行的方案进行对比探讨: 1. 基于NFS的Session共享 NFS是Net FileSystem的简称 ...
- Redis安装及实现session共享
一.Redis介绍 1.redis是key-value的存储系统,属于非关系型数据库 2.特点:支持数据持久化,可以让数据在内存中保存到磁盘里(memcached:数据存在内存里,如果服务重启,数据会 ...
- Using Redis to store php session
Using Redis to store php session 默认情况下,php将会将session信息存储在文件系统上,在单机情况下没有问题,但是当系统负载增大,或者在对系统可用性要求很高的场景 ...
- PHP中Redis替代文件存储Session语句
php默认使用文件存储session,如果并发量大,效率非常低.而Redis对高并发的支持非常好,所以,可以使用redis替代文件存储session. 这里,介绍下php的 session_set_s ...
随机推荐
- NOIP 模拟 $21\; \rm Game$
题解 考试的时候遇到了这个题,没多想,直接打了优先队列,但没想到分差竟然不是绝对值,自闭了. 正解: 值域很小,所以我们开个桶,维护当前最大值. 如果新加入的值大于最大值,那么它肯定直接被下一个人选走 ...
- sudo apt install net-tools [sudo] zyw 的密码: 正在读取软件包列表... 完成 正在分析软件包的依赖关系树,正在读取状态信息... 完成,没有可用的软件包 net-tools,但是它被其它的软件包引用了。这可能意味着这个缺失的软件包可能已被废弃,或者只能在其他发布源中找到
截图: 先执行: sudo apt-get update 再执行: sudo apt install net-tools 即可安装成功!!
- FileUtils 文件工具类
FileUtils 下载jar中的文件 package com.meeno.chemical.common.utils; import lombok.extern.slf4j.Slf4j; impor ...
- SpringBoot启动标识修改
在src/main/resources下新建一个banner.txt ${AnsiColor.BRIGHT_RED} ///////////////////////////////////////// ...
- mzy,struts学习(二):struts.xml的配置
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE struts PUBLIC "- ...
- Servlet学习之复习
Servlet的注册与运行(Servlet程序通常需要存储在<web应用程序目录>\WEB-INF\classes\目录中) 1.注册Servlet:在web.xml文件中,一个<s ...
- Docker与数据:三种挂载方式
操作系统与存储 操作系统中将存储定义为 Volume(卷) ,这是对物理存储的逻辑抽象,以达到对物理存储提供有弹性的分割方式.另外,将外部存储关联到操作系统的动作定义为 Mount(挂载). Dock ...
- springgateway
SpringGateAway: 先进行鉴权,然后进行路由,日志什么等等
- 786. 第k个数
题目传送门 一.理解感悟 1.这是快速排序模板的练习题. 2.不一样的地方在于它可以利用快排模板,但却不需要真的把所有数据排序完成,每次一分为二后,只关心自己所有的那一半,就是可以节约一半的递归. 3 ...
- 分布式系列-分布式ID
一.数据库自增(单实例) 1.方案描述 基于数据库自增ID(auto_increment)利用其来充当分布式ID.实现方式就是用一张表来充当ID生成器,当我们需要ID时,向表中插入一条记录返回主键ID ...