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=密码"
测试代码
<?phpini_set("session.save_handler","redis");
ini_set("session.save_path","tcp://127.0.0.1:6379");
session_start();
echo"<pre>";
$_SESSION['usertest'.rand(1,5)]=1;
var_dump($_SESSION);echo"</pre>";
输出 ↓
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框架代码):