fiollr 发表于 2015-8-18 11:31:01

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]
查看完整版本: Yii 2.0.6 发布,PHP 开发框架