欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP session文件獨(dú)占鎖引起阻塞問題解決方法

 更新時(shí)間:2015年05月12日 10:47:30   投稿:junjie  
這篇文章主要介紹了PHP session文件獨(dú)占鎖引起阻塞,本文講解PHP使用默認(rèn)文件會(huì)話處理器時(shí)容易導(dǎo)致的阻塞問題解決方法,需要的朋友可以參考下

PHP默認(rèn)的會(huì)話處理器是session.save_handler = files(即文件)。如果同一個(gè)客戶端同時(shí)并發(fā)發(fā)送多個(gè)請(qǐng)求(如ajax在頁面同時(shí)發(fā)送多個(gè)請(qǐng)求),且腳本執(zhí)行時(shí)間較長,就會(huì)導(dǎo)致session文件阻塞,影響性能。因?yàn)閷?duì)于每個(gè)請(qǐng)求,PHP執(zhí)行session_start(),就會(huì)取得文件獨(dú)占鎖,只有在該請(qǐng)求處理結(jié)束后,才會(huì)釋放獨(dú)占鎖。這樣,同時(shí)多個(gè)請(qǐng)求就會(huì)引起阻塞。解決方案如下:

(1)修改會(huì)話變量后,立即使用session_write_close()來保存會(huì)話數(shù)據(jù)并釋放文件鎖。

session_start();
 
$_SESSION['test'] = 'test';
session_write_close();
 
//do something

(2)利用session_set_save_handler()函數(shù)是實(shí)現(xiàn)自定義會(huì)話處理。

function open($savePath, $sessionName)
{
  echo 'open is called';
  return true;
}
 
function close()
{
  echo 'close is called';
  return true;
}
 
function read($sessionId)
{
  echo 'read is called';
  return '';
}
 
function write($sessionId, $data)
{
  echo 'write is called';
  return true;
}
 
function destroy($sessionId)
{
  echo 'destroy is called';
  return true;
}
 
function gc($lifetime)
{
  echo 'gc is called';
  return true;
}
 
session_set_save_handler("open", "close", "read", "write", "destroy", "gc");
register_shutdown_function ( 'session_write_close' );
 
session_start();
 
$_SESSION['foo'] = "bar";

當(dāng)然,在 php 5.4.0之后,你可以通過實(shí)現(xiàn) SessionHandlerInterface 接口或繼承 SessionHandler 類來使用。

class MySessionHandler extends SessionHandler {
 
  public function __construct()
  {
  }
 
  public function open($save_path, $session_id)
  {
  }
 
  public function close()
  {
 
  }
 
  public function create_sid()
  {
  }
 
  public function read($id)
  {
  }
 
  public function write($id, $data)
  {
  }
 
  public function destroy($id)
  {
  }
}
 
$handler = new MySessionHandler();
 
//第2個(gè)參數(shù)將函數(shù) session_write_close() 注冊為 register_shutdown_function() 函數(shù)。
session_set_save_handler($handler, true);

你可以對(duì)上面的代碼進(jìn)行具體實(shí)現(xiàn)和封裝,利用mysql或其它內(nèi)存數(shù)據(jù)庫來管理會(huì)話數(shù)據(jù)。還能解決使用集群
時(shí),session數(shù)據(jù)共享問題。

相關(guān)文章

最新評(píng)論