redis接管session共享

前言

小型web服务, session数据基本是保存在本地(更多是本地磁盘文件), 但是当部署多台服务, 且需要共享session, 确保每个服务都能共享到同一份session数据.

redis 数据存储在内存中, 性能好, 配合持久化可确保数据完整.

设计方案

1. 通过php自身session配置实现

1. 通过php自身session配置实现

# 使用 redis 作为存储方案

session.save_handler = redis

session.save_path = "tcp://127.0.0.1:6379"

# 若设置了连接密码, 则使用如下

session.save_path = "tcp://127.0.0.1:6379?auth=密码"

测试代码

ini_set("session.save_path","tcp://127.0.0.1:6379");

session_start();

echo"

";

$_SESSION['usertest'.rand(1,5)]=1;

var_dump($_SESSION);echo"

";

输出 ↓

array(2) { 

 ["usertest1"]=>int(88) 

 ["usertest3"]=>int(1)

}

usertest1|i:1;usertest3|i:1;

评价

优点: 实现简单, 无需修改php代码

缺点: 配置不支持多样化, 只能应用于简单场景


2. 设置用户自定义会话存储函数

通过 session_set_save_handler() 函数设置用户自定义会话函数.

session_set_save_handler ( callable $open , callable $close , callable $read , callable $write , callable $destroy , callable $gc [, callable $create_sid [, callable $validate_sid [, callable $update_timestamp ]]] ) : bool

    # >= php5.4

session_set_save_handler ( object $sessionhandler [, bool $register_shutdown = TRUE ] ) : bool

在配置完会话存储函数后, 再执行 session_start() 即可.

具体代码略, 以下提供一份 Memcached 的(来自Symfony框架代码):


原文地址cnblogs.com/youjiaxing/p/10407361.html

你可能感兴趣的:(redis接管session共享)