Heim  >  Artikel  >  Backend-Entwicklung  >  PHP löst die Blockierung von Sitzungsdateien

PHP löst die Blockierung von Sitzungsdateien

*文
*文Original
2017-12-26 14:40:461929Durchsuche

Wie löst PHP die Blockierung von Sitzungsdateien? In diesem Artikel wird hauptsächlich die durch die exklusive Sperre der PHP-Sitzungsdatei verursachte Blockierung vorgestellt und die Lösung für das Blockierungsproblem vorgestellt, das leicht verursacht werden kann, wenn PHP den Standard-Dateisitzungsprozessor verwendet. Ich hoffe, es hilft allen.

Der Standard-Sitzungshandler von PHP ist session.save_handler = files (d. h. Dateien). Wenn derselbe Client mehrere Anforderungen gleichzeitig sendet (z. B. wenn Ajax mehrere Anforderungen gleichzeitig auf der Seite sendet) und die Skriptausführungszeit lang ist, wird die Sitzungsdatei blockiert und die Leistung beeinträchtigt. Da PHP für jede Anfrage session_start() ausführt, erhält es eine exklusive Sperre für die Datei und die exklusive Sperre wird erst freigegeben, nachdem die Anfrage verarbeitet wurde. Auf diese Weise führen mehrere gleichzeitige Anfragen zu einer Blockierung. Die Lösung lautet wie folgt:

(1) Verwenden Sie nach dem Ändern der Sitzungsvariablen sofort session_write_close(), um die Sitzungsdaten zu speichern und die Dateisperre aufzuheben.

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


(2) Verwenden Sie die Funktion session_set_save_handler(), um eine benutzerdefinierte Sitzungsverarbeitung zu implementieren.

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";

Natürlich können Sie es nach PHP 5.4.0 verwenden, indem Sie die SessionHandlerInterface-Schnittstelle implementieren oder die SessionHandler-Klasse erben.

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个参数将函数 session_write_close() 注册为 register_shutdown_function() 函数。
session_set_save_handler($handler, true);

Sie können den obigen Code implementieren und kapseln und MySQL oder eine andere In-Memory-Datenbank verwenden, um Sitzungsdaten zu verwalten. Es kann auch das Problem der gemeinsamen Nutzung von Sitzungsdaten bei Verwendung von Cluster
lösen.

Verwandte Empfehlungen:

PHP verwendet Redis, um die gemeinsame Nutzung von Sitzungsinstanzen zu implementieren

Einführung in die PHP-Sitzung

Gültigkeitsdauer der PHP-Sitzung

Das obige ist der detaillierte Inhalt vonPHP löst die Blockierung von Sitzungsdateien. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn