PHP의 기본 세션 핸들러는 session.save_handler = 파일(예: 파일)입니다. 동일한 클라이언트가 동시에 여러 요청을 보내고(예: 페이지에서 동시에 여러 요청을 보내는 ajax) 스크립트 실행 시간이 길면 세션 파일이 차단되고 성능에 영향을 미칩니다. 각 요청에 대해 PHP는 session_start()를 실행하여 파일 배타적 잠금을 획득하고 배타적 잠금은 요청이 처리된 후에만 해제됩니다. 이러한 방식으로 동시에 여러 요청이 발생하면 차단이 발생합니다. 해결 방법은 다음과 같습니다.
(1) 세션 변수를 수정한 후 즉시 session_write_close()를 사용하여 세션 데이터를 저장하고 파일 잠금을 해제합니다.
session_start(); $_SESSION['test'] = 'test'; session_write_close(); //do something
(2) session_set_save_handler() 함수를 사용하여 사용자 정의 세션 처리를 구현합니다.
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";
물론 PHP 5.4.0 이후부터는 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个参数将函数 session_write_close() 注册为 register_shutdown_function() 函数。 session_set_save_handler($handler, true);
위 코드를 구현 및 캡슐화하고 mysql이나 기타 인메모리 데이터베이스를 사용하여 세션 데이터를 관리할 수 있습니다. 클러스터를 사용하여 해결할 수도 있습니다
세션 데이터 공유 문제가 발생한 경우.