通过redis实现session共享-php

<?php
class redisSession{
    /**
     * 保存session的数据库表的信息
     */
    private $_options = array(
        ‘handler‘ => null, //数据库连接句柄
        ‘host‘ => null,
        ‘port‘ => null,
        ‘lifeTime‘ => null,
        ‘prefix‘   => ‘PHPREDIS_SESSION:‘
    );

    /**
     * 构造函数
     * @param $options 设置信息数组
     */
    public function __construct($options=array()){
        if(!class_exists("redis", false)){
            die("必须安装redis扩展");
        }
        if(!isset($options[‘lifeTime‘]) || $options[‘lifeTime‘] <= 0){
            $options[‘lifeTime‘] = ini_get(‘session.gc_maxlifetime‘);
        }
        $this->_options = array_merge($this->_options, $options);
    }

    /**
     * 开始使用该驱动的session
     */
    public function begin(){
        if($this->_options[‘host‘] === null ||
           $this->_options[‘port‘] === null ||
           $this->_options[‘lifeTime‘] === null
        ){
            return false;
        }
        //设置session处理函数
        session_set_save_handler(
            array($this, ‘open‘),
            array($this, ‘close‘),
            array($this, ‘read‘),
            array($this, ‘write‘),
            array($this, ‘destory‘),
            array($this, ‘gc‘)
        );
    }
    /**
     * 自动开始回话或者session_start()开始回话后第一个调用的函数
     * 类似于构造函数的作用
     * @param $savePath 默认的保存路径
     * @param $sessionName 默认的参数名,PHPSESSID
     */
    public function open($savePath, $sessionName){
        if(is_resource($this->_options[‘handler‘])) return true;
        //连接redis
        $redisHandle = new Redis();
        $redisHandle->connect($this->_options[‘host‘], $this->_options[‘port‘]);
        if(!$redisHandle){
            return false;
        }

        $this->_options[‘handler‘] = $redisHandle;
//        $this->gc(null);
        return true;

    }

    /**
     * 类似于析构函数,在write之后调用或者session_write_close()函数之后调用
     */
    public function close(){
        return $this->_options[‘handler‘]->close();
    }

    /**
     * 读取session信息
     * @param $sessionId 通过该Id唯一确定对应的session数据
     * @return session信息/空串
     */
    public function read($sessionId){
        $sessionId = $this->_options[‘prefix‘].$sessionId;
        return $this->_options[‘handler‘]->get($sessionId);
    }

    /**
     * 写入或者修改session数据
     * @param $sessionId 要写入数据的session对应的id
     * @param $sessionData 要写入的数据,已经序列化过了
     */
    public function write($sessionId, $sessionData){
        $sessionId = $this->_options[‘prefix‘].$sessionId;
        return $this->_options[‘handler‘]->setex($sessionId, $this->_options[‘lifeTime‘], $sessionData);
    }

    /**
     * 主动销毁session会话
     * @param $sessionId 要销毁的会话的唯一id
     */
    public function destory($sessionId){
        $sessionId = $this->_options[‘prefix‘].$sessionId;
//        $array = $this->print_stack_trace();
//        log::write($array);
        return $this->_options[‘handler‘]->delete($sessionId) >= 1 ? true : false;
    }

    /**
     * 清理绘画中的过期数据
     * @param 有效期
     */
    public function gc($lifeTime){
        //获取所有sessionid,让过期的释放掉
        //$this->_options[‘handler‘]->keys("*");
        return true;
    }
    //打印堆栈信息
    public function print_stack_trace()
    {
        $array = debug_backtrace ();
        //截取用户信息
        $var = $this->read(session_id());
        $s = strpos($var, "index_dk_user|");
        $e = strpos($var, "}authId|");
        $user = substr($var,$s+14,$e-13);
        $user = unserialize($user);
        //print_r($array);//信息很齐全
        unset ( $array [0] );
        if(!empty($user)){
          $traceInfo = $user[‘id‘].‘|‘.$user[‘user_name‘].‘|‘.$user[‘user_phone‘].‘|‘.$user[‘presona_name‘].‘++++++++++++++++\n‘;
        }else{
          $traceInfo = ‘++++++++++++++++\n‘;
        }
        $time = date ( "y-m-d H:i:m" );
        foreach ( $array as $t ) {
            $traceInfo .= ‘[‘ . $time . ‘] ‘ . $t [‘file‘] . ‘ (‘ . $t [‘line‘] . ‘) ‘;
            $traceInfo .= $t [‘class‘] . $t [‘type‘] . $t [‘function‘] . ‘(‘;
            $traceInfo .= implode ( ‘, ‘, $t [‘args‘] );
            $traceInfo .= ")\n";
        }
        $traceInfo .= ‘++++++++++++++++‘;
        return $traceInfo;
    }

}

入口处调用

$handler = new redisSession(array(
                ‘host‘ => "127.0.0.1",
                ‘port‘ => "6379"
        ));
$handler->begin();
时间: 2024-10-13 00:00:37

通过redis实现session共享-php的相关文章

spring boot + redis 实现session共享

这次带来的是spring boot + redis 实现session共享的教程. 在spring boot的文档中,告诉我们添加@EnableRedisHttpSession来开启spring session支持,配置如下: @Configuration @EnableRedisHttpSession public class RedisSessionConfig { } 而@EnableRedisHttpSession这个注解是由spring-session-data-redis提供的,所以

项目分布式部署那些事(1):ONS消息队列、基于Redis的Session共享,开源共享

因业务发展需要现在的系统不足以支撑现在的用户量,于是我们在一周之前着手项目的性能优化与分布式部署的相关动作. 概况 现在的系统是基于RabbitHub(一套开源的开发时框架)和Rabbit.WeiXin(开源的微信开发SDK)开发的一款微信应用类系统,主要业务是围绕当下流行的微信元素,如:微官网.微商城.微分销.营销活动.会员卡等. 关于RabbitHub详情请戳: .NET 平台下的插件化开发内核(Rabbit Kernel) RabbitHub开源情况及计划 关于Rabbit.WeiXin详

分布式中使用Redis实现Session共享(二)

上一篇介绍了一些redis的安装及使用步骤,本篇开始将介绍redis的实际应用场景,先从最常见的session开始,刚好也重新学习一遍session的实现原理.在阅读之前假设你已经会使用nginx+iis实现负载均衡搭建负载均衡站点了,这里我们会搭建两个站点来验证redis实现的session是否能共享. 阅读目录 Session实现原理 session共享实现方案 问题拓展 总结 回到顶部 Session实现原理 session和cookie是我们做web开发中常用到的两个对象,它们之间会不会

nginx+redis实现session共享 .NET分布式架构

上两篇文件介绍了如何安装和封装redis 本篇主要是记录下怎么实现 nginx+redis实现session共享 目前session问题点 又爱又恨的Session 刚接触程序开发的人一定爱死Session了,因为Session让Http从无状态变成有状态了,页面之间传值.用户相关信息.一些不变的数据.甚至于查出来的DataTable也可以放进去,取值的时候只需要Session[Key]即可,真是方便极了.Session真是个利器,人挡杀人佛挡杀佛,但任何事物被封为利器基本也是双刃剑,Sessi

使用 Redis 实现 Session 共享

1    第4-3课:使用 Redis 实现 Session 共享 在微服务架构中,往往由多个微服务共同支撑前端请求,如果涉及到用户状态就需要考虑分布式 Session 管理问题,比如用户登录请求分发在服务器 A,用户购买请求分发到了服务器 B, 那么服务器就必须可以获取到用户的登录信息,否则就会影响正常交易.因此,在分布式架构或微服务架构下,必须保证一个应用服务器上保存 Session 后,其他应用服务器可以同步或共享这个 Session. 目前主流的分布式 Session 管理有两种方案.

springboot+redis实现session共享

1.场景描述 因项目访问压力有点大,需要做负载均衡,但是登录使用的是公司统一提供的单点登录系统,需要做session共享,否则假如在A机器登录成功,在B机器上操作就会存在用户未登录情况. 2. 解决方案 因项目是springboot项目,采用Springboot+Springsession+Redis来实现session共享. 2.1 pom.xml文件 <dependency> <groupId>org.springframework.boot</groupId> &

Spring Boot 多站点利用 Redis 实现 Session 共享

如何在不同站点(web服务进程)之间共享会话 Session 呢,原理很简单,就是把这个 Session 独立存储在一个地方,所有的站点都从这个地方读取 Session. 通常我们使用 Redis 来解决这个问题 Spring Boot 2.1.8 Redis 5.0.3 本项目源码 github 下载 本章解决前面文章 Spring Boot 利用 nginx 实现生产环境的伪热更新 产生的session共享问题. 1 Redis 准备 本示例使用 Redis 5.0.3 操作系统为 Mac

nginx+tomcat+redis完成session共享

环境准备:实验环境有限,都安装在一台机器上了 tomcat7 两个 nginx1.8 redis3.2.8 准备两个tomcat,修改相应的端口 名称 IP 端口 tomcat版本 JDK tomcat-1 192.168.1.133 8081 7.0.69 1.7.0_79 tomcat-2 192.168.1.133 8082 7.0.69 1.7.0_79 nginx.conf配置: 下载tomcat-redis-session-manager相应的jar包,主要有四个: 修改两个tomc

分布式中使用Redis实现Session共享(转)

上一篇介绍了如何使用nginx+iis部署一个简单的分布式系统,文章结尾留下了几个问题,其中一个是"如何解决多站点下Session共享".这篇文章将会介绍如何使用Redis,下一篇在此基础上实现Session. 这里特别说明一下,其实没有必要使用Redis来解决Session共享.Asp.net提供了StateServer模式来共享Session,这里重复造轮子的目的1:熟悉Redis的基本知识和使用 2.学习和巩固Session的实现原理. 3.学习Redis应用场景 阅读目录 Re

分布式中使用Redis实现Session共享(一)

上一篇介绍了如何使用nginx+iis部署一个简单的分布式系统,文章结尾留下了几个问题,其中一个是"如何解决多站点下Session共享".这篇文章将会介绍如何使用Redis,下一篇在此基础上实现Session. 这里特别说明一下,其实没有必要使用Redis来解决Session共享.Asp.net提供了StateServer模式来共享Session,这里重复造轮子的目的1:熟悉Redis的基本知识和使用 2.学习和巩固Session的实现原理. 3.学习Redis应用场景 阅读目录 Re