이번에는 PHP 로드 밸런싱에서 세션공유 사례(코드 포함)에 대해 자세히 설명하겠습니다. PHP 로드 밸런싱에서 세션 공유에 대한 주의 사항은 무엇입니까? 다음은 실제 사례입니다. .
먼저 로드 밸런싱에 대해 이야기해 보겠습니다. 로드 밸런싱은 사용자 요청을 다형성 PC에 분산하여 처리하므로, 효과적으로 문제를 해결할 수 있다는 것은 누구나 알고 있을 것입니다. 전통적으로 PHP는 로컬 임시 파일에 세션을 저장하지만 이 경우 배포 후 세션이 손실됩니다. 실제로 가장 간단한 해결책은 memcache를 사용하여 이를 호스팅하고 설정하는 것입니다. 별도의 서버로 사용되며(메모리가 클수록 좋습니다), 다음 작업은 PHP 코드에 맡기면 됩니다. 여기서는 php.ini도 수정하고 싶지 않습니다. 각 서버를 변경하는 것도 피곤하고 게으릅니다
아마도 php.ini의 세션 저장 위치만 수정하면 memcache에 쓸 수 있다고 말할 것입니다. 예, 맞습니다. 하지만 이 메서드는 gc를 호출할 수 없습니다. 만료된 세션을 해제하는 방법, 그리고 오늘 우리가 이야기하고 싶은 것은 관리하도록 하는 것뿐만 아니라 세션을 자동으로 해제하도록 하는 것입니다.
해야 하기 때문에 아래에서는 완벽하게 만들어야 합니다. 댓글을 직접 읽는 방법을 모르는 경우:$_ENV=array( 'SYS'=>array( 'Memip'=>'127.0.0.1', //MEMCACHE的ip 'Mempt'=>11211, //MEMCACHE的port 'Memtim'=>10, //MEMCACHE的超時時間 ) ); //托管SESSION到MEMCACHE,如果开启失败,则说明MEMCACHE没有配置正确 final class S{ public static function open(){ //禁止session自动开启 session_write_close(); ini_set('session.auto_start',0); //使用五十分之一的概率启动gc清理会话 ini_set('session.gc_probability',1); ini_set('session.gc_pisor',50); ini_set('session.use_cookies',1); //session的寿命 //ini_set('session.gc_maxlifetime',$_ENV['SYS']['Memtim']); //ini_set('session.cookie_lifetime',$_ENV['SYS']['Memtim']); //ini_set('session.save_handler','files'); //ini_set('session.save_path',Run.'_tmp'); //ini_set('session.save_handler','memcache'); //ini_set('session.save_path','tcp://127.0.0.1:11211'); //$_ENV['S_tim'] = ini_get('session.gc_maxlifetime'); //建立memcache对象 $_ENV['S_mem']=new Memcache; $_ENV['S_mem']->connect($_ENV['SYS']['Memip'],$_ENV['SYS']['Mempt']) or die('Memcache連接失敗!'); return TRUE; } /** 读取 返回:读到的內容 /**/ public static function read($id){ return $_ENV['S_mem']->get('s_'.$id); } /** 写入 返回:bool /**/ public static function write($id,$data){ return $_ENV['S_mem']->set('s_'.$id,$data,MEMCACHE_COMPRESSED,$_ENV['SYS']['Memtim']); } /** 关闭 返回:bool /**/ public static function close(){ $_ENV['S_mem']->close(); unset($_ENV['S_mem'],$_ENV['SYS']['Memtim']); return TRUE; } /** 刪除 返回:bool /**/ public static function destroy($id){ return $_ENV['S_mem']->delete('s_'.$id); } /** 清理 返回:bool /**/ public static function gc(){ return TRUE; } } session_set_save_handler('S::open','S::close','S::read','S::write','S::destroy','S::gc'); $_ENV['sessionid']=(isset($_REQUEST['sessionid'])) ? trim($_REQUEST["sessionid"]) : session_id(); if($_ENV['sessionid']!=''){session_id($_ENV['sessionid']);} session_start();
php-app 개발 인터페이스의 암호화를 사용하는 단계에 대한 자세한 설명
csrf 토큰 검증 시뮬레이션 제출 예제를 사용한 php 컬에 대한 자세한 설명
위 내용은 PHP 로드 밸런싱 시 세션 공유 사례에 대한 자세한 설명(코드 포함)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!