java用redis替代session,session存储的替代方法redis

本文介绍了如何利用PHP的session_set_save_handler函数将session存储迁移到Redis,以提升在高并发场景下的性能。通过SessionManager类实例,展示了如何设置Redis连接、回调函数及操作会话的细节,包括读写、销毁和垃圾回收。
摘要由CSDN通过智能技术生成

php默认使用文件存储session,如果并发量大,效率非常低。而redis对高并发的支持非常好,所以,可以使用redis替代文件存储session。

这里,介绍下php的session_set_save_handler 函数的作用和使用方法。该函数定义用户级session保存函数(如打开、关闭、写入等)。原型如下:

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

在使用该函数前,先把php.ini配置文件的session.save_handler选项设置为user,否则session_set_save_handle 不会生效。

下面是使用redis存储session的一个实例。

编写一个session管理类sessionManager ,代码如下:

class SessionManager {

private $reids;

private $sessionSavePath;

private $sessionName;

private $sessionExpireTime=300;

public function __construct() {

$this->reids=new Redis();

$this->reids->connect('127.0.0.1',6379);

$retval=session_set_save_handler(

array($this,"open"),

array($this,"close"),

array($this,"read"),

array($this,"write"),

array($this,"destroy"),

array($this,"gc")

);

}

public function open($path,$name) {

return true;

}

public function close() {

return true;

}

public function read($id) {

$vale=$this->reids->get($id);

if($vale) {

return $vale;

}else {

return '';

}

}

public function write($id,$data) {

if($this->reids->set($id,$data)) {

$this->reids->expire($id,$this->sessionExpireTime);

return true;

}

return false;

}

public function destroy($id) {

if($this->reids->delete($id)) {

return true;

}

return false;

}

public function gc($maxlifetime) {

return true;

}

public function __destruct() {

session_write_close();

}

}

?>

SessionManager构造函数主要用来连接Redis服务器,使用session_set_save_handler函数设置session回调函数,并调用session_start函数开启session功能。因为本例中open、close和gc回调函数的作用不是很大,所以直接返回true。

在write回调函数中,以session id 作为key,把session的数据作为value存储到redis服务器,设置session的过期时间为300秒。在read回调函数重,以session ID 作为key从redis服务器中读取数据,并返回此数据。而在destroy回调函数重,则以session ID 作为key 从redis服务器中删除对应的session数据。

使用时,只需包含SessionManager类,然后实例化一个SessionManager对象。下面建立个session_set.php文件。输入代码

include("SessionManager.php");

new SessionManager(); //开启session管理

$_SESSION['username']='hezikuang';//创建session变量

?>

然后再创建一个session_get.php文件,输入如下代码:

include("SessionManager.php");

new SessionManager(); //开启session管理

echo $_SESSION['username'];

?>

可以访问session_get.php,看看是否成功。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值