세션은 서버 측에서 사용자 세션 데이터를 유지하는 방법이고, 해당 쿠키는 클라이언트 측에서 사용자 데이터를 유지하는 것임을 알고 있습니다. HTTP 프로토콜은 상태 비저장 프로토콜입니다. 서버가 응답한 후 브라우저와의 연결이 끊어집니다. 초기에 Netscape는 클라이언트가 페이지 간에 데이터를 교환할 수 있도록 브라우저에 쿠키를 도입했습니다. 많은 사용자의 데이터는 어떻습니까?
우선 클라이언트와 서버가 하나씩 연결되어야 합니다. 각 클라이언트는 서버가 이를 식별할 수 있도록 고유한 식별자를 가지고 있어야 합니다. 고유 식별에는 쿠키 또는 GET을 통해 지정하는 두 가지 방법이 있는 것이 좋습니다. PHP의 기본 구성은 세션을 사용할 때 "PHPSESSID"라는 쿠키를 생성합니다(php.ini에서 session.name 값을 수정하여 지정할 수 있음). 클라이언트가 쿠키를 비활성화하는 경우 세션 ID를 전달하도록 지정할 수도 있습니다. GET 서버를 통해(php.ini에서 session.use_trans_sid와 같은 매개변수 수정)
서버측 session.save_path 디렉터리를 살펴보면 sess_vv9lpgf0nmkurgvkba1vbvj915와 유사한 파일을 많이 찾을 수 있습니다. 이는 실제로 세션 ID "vv9lpgf0nmkurgvkba1vbvj915"에 해당하는 데이터입니다. 진실은 여기에 있습니다. 클라이언트는 세션 ID를 기반으로 해당 파일을 찾습니다. 읽을 때 파일 내용을 역직렬화하여 저장 시 먼저 직렬화합니다. 쓴.
사실이므로 서버가 세션을 지원하지 않거나 세션을 맞춤화하려는 경우 DIY하고 PHP의 uniqid를 사용하여 절대 반복되지 않는 세션 ID를 생성한 다음 세션 내용을 저장할 장소. MySQL 데이터베이스에 세션을 저장하는 방법을 flickr에서 배울 수도 있습니다.
원리를 이해한 후 소위 세션은 실제로 클라이언트의 세션 ID이고 서버의 세션 파일입니다. 새 세션을 생성하기 전에 session_start()를 실행하면 서버에 쿠키를 심고 준비하라고 지시합니다. 그렇지 않으면 세션 내용을 어떻게 저장합니까? 세션을 읽기 전에 session_start()를 실행하면 서버가 세션 ID에 따라 세션 파일을 빠르게 역직렬화하도록 지시합니다.
session_start() 전에는 하나의 세션 함수만 실행할 수 있습니다. session_name(): 세션 이름을 읽거나 지정합니다(예: 기본값은 "PHPSESSID"입니다). 물론 이것은 session_start 전에 실행되어야 합니다.
트래픽량이 많은 웹사이트에서는 세션이 시스템 성능에 영향을 미칩니다. 성능에 영향을 미치는 이유 중 하나는 파일 시스템 설계 때문입니다. 같은 디렉터리에 있으면 파일 위치 지정에 시간이 많이 걸립니다. PHP는 세션 디렉터리 해싱을 지원합니다. php.ini에서 session.save_path = "2;/path/to/session/dir"을 수정하면 세션이 다음 위치에 저장됩니다. 2레벨 하위 디렉터리. 각 디렉터리에는 16개의 하위 디렉터리[0~f]가 있지만 PHP 세션에서는 디렉터리 생성을 지원하지 않는 것 같으므로 해당 디렉터리를 미리 만들어야 합니다.
또 다른 문제는 작은 파일의 효율성입니다. 일반적으로 우리의 세션 데이터는 너무 크지 않습니다(1~2K). 디스크에 1~2K 파일이 많으면 IO 효율성이 확실히 떨어집니다. 매우 안타깝습니다. PHP 매뉴얼에서는 Reiserfs 파일 시스템 사용을 권장하지만 Reiserfs의 작성자는 아내를 죽였고 SuSE도 Reiserfs를 버렸습니다.
실제로 세션을 저장하는 방법은 여러 가지가 있습니다. 이는 php -i|grep "등록된 저장 핸들러"를 통해 볼 수 있습니다. 예를 들어 등록된 저장 핸들러 => 파일 사용자 sqlite eaccelerator는 파일을 통해 볼 수 있습니다. users, sqlite, eaccelerator 저장을 위해 서버에 memcached가 설치된 경우 mmcache 옵션도 있습니다. 물론 MySQL, PostgreSQL 등과 같은 더 많은 것들이 있습니다. 모두 좋은 선택입니다.
사용자가 서버 A에 로그인하고 세션 정보를 심은 다음 웹 사이트의 일부 페이지를 방문하여 서버 B로 이동할 수 있습니다. , 이때 B서버에 세션정보가 없고 특별한 처리가 이루어지지 않는다면 문제가 있을 수 있습니다.
세션 동기화에는 여러 종류가 있는데, memcached나 MySQL에 저장하면 아주 쉽습니다. 파일 형태라면 NFS를 이용하면 됩니다. 균일하게.
또 다른 방법은 암호화된 쿠키를 사용하는 것입니다. 사용자가 서버 A에 성공적으로 로그인하면 사용자가 서버 B를 방문할 때 세션이 있는지 확인합니다. 물론 문제가 없습니다. 그렇지 않은 경우 쿠키가 유효한지 확인하십시오. 쿠키가 유효한 경우 서버 B에서 세션을 다시 설정하십시오. 이 방법은 실제로 매우 유용합니다. 웹사이트에 하위 채널이 많고 서버가 동일한 컴퓨터실에 있지 않고 세션을 동기화할 수 없고 균일하게 로그인하려는 경우 매우 유용합니다.
물론, 또 다른 방법은 로드 밸런싱 계층에서 세션을 유지하고 방문자를 특정 서버에 바인딩하는 것입니다. 방문자의 모든 방문은 해당 서버에서 이루어지며 세션 동기화가 필요하지 않습니다. 모두 운영 및 유지 관리 수준에 관한 것입니다. 그게 전부입니다. 모든 사람이 세션이 시스템 성능에 영향을 미친다고 해서 소심해지지 마십시오. 기분을 상하게 하거나 숨길 수 없다면 문제를 해결하는 것이 중요합니다. 여기에는 적합하지 않습니다.
위 내용은 내용적인 측면을 포함하여 세션의 원리를 소개한 내용으로, PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.