如何如何使用Redis保存用户会话Session详解

秋天是秋高气爽、秋风瑟瑟的季节。农民伯伯在辛勤地收谷,秋天的大树落下了好多树叶像翩翩起舞的蝴蝶。夕阳的金辉把绿色的林海染成金黄一片。

前言

PHP内置的绘画存储机制是把全部的会话数据保存在服务器上的文本文件里面,这些文件通常都是保存在服务器上的临时目录里。如果并发量大,读写效率非常低。而Redis对高并发的支持非常好,所以,可以使用redis替代文件存储session。

下载源码

session_set_save_handler函数

PHP的session_set_save_handler函数用来定义用户级session保存函数(如打开、关闭、写入等)。原型如下:

bool session_set_save_hanler(callback open,callback close,callback read,callback write,callback destory,callback gc)

参数 描述
open 当session打开时调用此函数。接收两个参数,第一个参数是保持session的路径,第二个参数是session的名字。此回调函数操作成功返回 TRUE,反之返回 FALSE。
close 当session操作完成时调用此函数。不接收参数。此回调函数操作成功返回 TRUE,反之返回 FALSE。
read 以session ID作为参数。通过session ID从数据存储方中取得数据,并返回此数据。如果数据为空,可以返回一个空字符串。此函数在调用session_start前被触发
write 当数据存储时调用。有两个参数,一个是session ID,另外一个是session的数据
destroy 当调用session_destroy函数时触发destroy函数。只有一个参数 session ID,此回调函数操作成功返回 TRUE,反之返回 FALSE。
gc 当php执行session垃圾回收机制时触发,此回调函数操作成功返回 TRUE,反之返回 FALSE。

Session管理类

找到PHP的配置文件php.ini,修改为下面内容,保存并重启php-fpm服务。

session.save_handler = redis

我们编写一个用来管理session的类:

<?php 
class SessionManager{

 private $redis;
 private $sessionSavePath;
 private $sessionName;
 private $sessionExpireTime = 60;//redis,session的过期时间为30s

 public function __construct(){
 $this->redis = new Redis();//创建phpredis实例
 $this->redis->connect('127.0.0.1', 6379);//连接redis
 //$this->redis->auth("123456x");//授权
 $retval = session_set_save_handler(
 array($this,"open"),
 array($this,"close"),
 array($this,"read"),
 array($this,"write"),
 array($this,"destroy"),
 array($this,"gc")
 );
 session_start();
 }

 public function open($path,$name){
 return true;
 }

 public function close(){
 return true;
 }

 public function read($id){
 $value = $this->redis->get($id);//获取redis中的指定记录
 if($value){
 return $value;
 }else{
 return '';
 }
 }

 public function write($id,$data){
 if($this->redis->set($id,$data)){//以session ID为键,存储
 $this->redis->expire($id,$this->sessionExpireTime);//设置redis中数据的过期时间,即session的过期时间
 return true;
 }

 return false;
 }

 public function destroy($id){
 if($this->redis->delete($id)){//删除redis中的指定记录
 return true;
 }
 return false;
 }

 public function gc($maxlifetime){
 return true;
 }

 public function __destruct(){
 session_write_close();
 }
}

SessionManager构造