51工具盒子

依楼听风雨
笑看云卷云舒,淡观潮起潮落

php使用redis存储session

phpinfo,可以看到session存储,可以使用files user memcache
redis,使用数据库存储session的好处是较之文件存储,在大用户量下速度更快,性能更优,而且如果做分布式系统,肯定是需要使用数据库存储
session的。这里总结下使用redis存储session的两种方式

使用mysql存储session大家应该使用过,session生命周期的原理其实就是session.gcprobability,session.gcdivisor这两个参数和最大生命时间决定的。每次php请求,有一定几率触发session的检测机制。我们使用session_setsavehandler,是可以重定义session的行为的。这里有两种方式实现redis存储session

代码实例1:

<?php

ini_set('session.gc_maxlifetime', 3600);

ini_set("session.save_handler","redis");

ini_set("session.save_path","tcp://127.0.0.1:6379?auth=authpwd");

session_start();

//$_SESSION['session'] = 'this is session content!';

echo $_SESSION['session'];

echo session_id().'<br/>';

$redis = new redis();

$redis->connect('127.0.0.1', 6379);

//redis用session_id作为key并且是以string的形式存储

echo $redis->get('PHPREDIS_SESSION:' . session_id());

?>

代码实例2:

<?php

class RedisSessionHandler { public $ttl = 1800; // 30 minutes default protected $db; protected $prefix;

public function __construct($db, $prefix = 'PHPSESSID1:',$time=1800) {
    $this-&gt;db = $db;
    $this-&gt;prefix = $prefix;
    $this-&gt;ttl =  $time;
}

function _open() { //一般不需要操作什么 }

function _close() { $this-&gt;db = null; unset($this-&gt;db); }

function _read($id) { $id = $this-&gt;prefix . $id; $sessData = $this-&gt;db-&gt;get($id); $this-&gt;db-&gt;expire($id, $this-&gt;ttl); return $sessData; }

function _write($id, $data) { $id = $this-&gt;prefix . $id; $this-&gt;db-&gt;set($id, $data); $this-&gt;db-&gt;expire($id, $this-&gt;ttl); }

function _destroy($id) { $this-&gt;db-&gt;del($this-&gt;prefix . $id); }

function _clean($max) { //一般不需要操作什么 }

}

$redis = new Redis(); $redis->connect('127.0.0.1',6379); $redis->select(1); $SESSION_ID_PREFIX = 'RSID:'; $SESSION_MAX_TIME = 1440; $sessHandler = new RedisSessionHandler($redis,$SESSION_ID_PREFIX,$SESSION_MAX_TIME);

session_set_save_handler( array($sessHandler, '_open'), array($sessHandler, '_close'), array($sessHandler, '_read'), array($sessHandler, '_write'), array($sessHandler, '_destroy'), array($sessHandler, '_clean') );

session_start(); echo session_id(); echo $_SESSION['name']='zhangcunchao';

第一种方式比较简单,但是无法选择库号,并且session_id的前缀信息比较难以控制,但是此方法也可以直接修改php配置文件,使所有程序的session使用redis
第二种方式相对麻烦一点,但是使用起来比方方便
第二种有并发一致性问题,所有的哈希算法肯定都会有这样的问题,不过可以通过 ip前缀哈希组合 来一定程度解决(这个IP是客户端IP,实际应用中,这个IP也不可靠,客户端重拨号IP更换,有些网络IP是跳动的,等问题,所以放一个COOKIE在客户端来做为前缀(比如第一次访问的服务器IP MD5hash值) 是比较可靠的, 如果是移动APP 就写一个配置参数,序列号hash什么的。) 标签: files,数据库,mysql,而且,检测

赞(4)
未经允许不得转载:工具盒子 » php使用redis存储session