Yii 2.0.6 发布,PHP 开发框架
基于数据库实现会话: online(sessid,session,version)sessid是用户ID.
session存储用户会话,内容是会话数组serialize序列化后的串.
version是版本号,用于实现乐观锁.
function my_session_get() { return unserialize($session); }
function my_session_set() { serialize($session); }
$session = my_session_get();
$session['ip'] = $_SERVER['REMOTE_ADDR'];
my_session_set($session);
my_session_set时用版本号version乐观锁控制session字段的同步:
SELECT * FROM online WHERE sessid=1;
UPDATE online SET session=$session,version=last_version+1 WHERE> 如果没有更新记录,则返回操作失败的提示.
对比PHP内置的会话机制使用的是悲观锁,session_start()开启的是一个对sess_ID会话文件的写保护锁,
其他页面的操作同一个sess_ID会话文件的session_start()将会被阻塞.
这样的SESSION锁机制就避免了下面的情况:
A页面和B页面读取了相同的一份会话信息.
A页面修改并写入了会话变量a.
B页面随后也修改并写入了会话变量b.
这时B页面会覆盖了之前A页面写入的会话变量a.
这种情况一般很少发生,所以基于数据库实现的会话机制使用乐观锁,应该也是合理的.
页:
[1]