>  기사  >  백엔드 개발  >  PHP 데이터베이스 영구 연결

PHP 데이터베이스 영구 연결

伊谢尔伦
伊谢尔伦원래의
2016-11-22 10:23:011403검색

영구 데이터베이스 연결은 스크립트 실행이 완료될 때 닫히지 않는 연결을 의미합니다. 영구 연결 요청을 받은 경우. PHP는 이미 동일한 영구 연결(이전에 열렸던)이 있는지 확인합니다. 존재하는 경우 이 연결이 직접 사용되며 존재하지 않는 경우 새 연결이 설정됩니다. 소위 "동일" 연결은 동일한 사용자 이름과 비밀번호를 사용하여 동일한 호스트에 연결하는 것을 의미합니다.

웹 서버의 작동과 분산 로드를 완전히 이해하지 못하는 독자는 지속적인 연결의 역할을 오해할 수 있습니다. 특히 영구 연결은 동일한 연결에서 "사용자 세션"을 설정하는 기능을 제공하지 않으며 트랜잭션을 효과적으로 설정하는 기능도 제공하지 않습니다. 실제로 엄밀히 말하면 영구 연결은 비영구 연결이 제공하지 않는 특별한 기능을 제공하지 않습니다.

왜요?

이는 웹 서버가 작동하는 방식과 관련이 있습니다. 웹 서버가 PHP를 사용하여 웹 페이지를 생성할 수 있는 세 가지 방법이 있습니다.

첫 번째 방법은 PHP를 "쉘"로 사용하는 것입니다. 이런 방식으로 실행하면 PHP는 웹 서버에 대한 각 PHP 페이지 요청에 대해 PHP 인터프리터 스레드를 생성하고 종료합니다. 이 스레드는 각 요청이 끝날 때 끝나기 때문에 이 스레드에서 사용되는 모든 리소스(예: SQL 데이터베이스 서버에 대한 연결)는 스레드가 끝날 때 닫힙니다. 이 경우 영구 연결을 사용해도 아무런 변화가 없습니다. 전혀 영구적이지 않기 때문입니다.

두 번째이자 가장 일반적인 방법은 현재 Apache에서만 작동하는 다중 프로세스 웹 서버에서 PHP를 모듈로 사용하는 것입니다. 다중 프로세스 서버의 일반적인 특징은 상위 프로세스와 하위 프로세스 그룹이 함께 실행되며, 그 중 하위 프로세스가 실제로 웹 페이지를 생성한다는 것입니다. 클라이언트가 상위 프로세스에 요청할 때마다 해당 요청은 다른 클라이언트 요청에 의해 점유되지 않은 하위 프로세스로 전달됩니다. 이는 동일한 클라이언트가 두 번째로 서버에 요청을 하면 다른 하위 프로세스에 의해 처리될 수 있음을 의미합니다. 영구 연결을 연 후 SQL 서비스를 요청하는 모든 후속 페이지는 설정된 SQL Server 연결을 재사용할 수 있습니다.

마지막 방법은 PHP를 멀티 스레드 웹 서버용 플러그인으로 사용하는 것입니다. 현재 PHP 4는 이미 ISAPI, WSAPI 및 NSAPI(Windows 환경에서)를 지원하므로 PHP를 Netscape FastTrack(iPlanet), Microsoft의 Internet Information Server(IIS) 및 O'Reilly의 WebSite Pro와 같은 다중 스레드 웹 서버로 사용할 수 있습니다. . 영구 연결의 동작은 기본적으로 이전에 설명한 다중 프로세스 모델과 동일합니다. PHP 3은 SAPI를 지원하지 않습니다.

영구 연결에 추가 기능이 없다면 이를 사용하면 어떤 이점이 있나요?

답은 매우 간단합니다. 바로 효율성입니다. SQL Server 연결에 대한 클라이언트 요청이 매우 빈번할 때 영구 연결이 더 효율적입니다. 빈번한 연결 요청에 대한 기준은 여러 요인에 따라 달라집니다. 예를 들어 데이터베이스 유형, 데이터베이스 서비스와 웹 서비스가 동일한 서버에 있는지 여부, SQL 서버가 부하를 로드하는 방법 등이 있습니다. 그러나 우리는 적어도 연결 요청이 빈번할 때 영구 연결이 효율성을 크게 향상시킨다는 것을 알고 있습니다. 이를 통해 각 하위 프로세스는 페이지가 처리될 때마다 SQL 서버에 연결을 요청하는 대신 수명 주기 동안 하나의 연결 작업만 수행할 수 있습니다. 이는 각 하위 프로세스가 서버에 대한 자체의 독립적인 영구 연결을 설정한다는 것을 의미합니다. 예를 들어, 20개의 서로 다른 하위 프로세스가 SQL Server에 대한 영구 연결을 설정하는 스크립트를 실행하는 경우 실제로 각 프로세스마다 하나씩, SQL Server에 대해 20개의 서로 다른 영구 연결이 설정됩니다.

영구적으로 연결된 하위 프로세스 수가 설정된 데이터베이스 연결 제한을 초과하면 시스템에 일부 결함이 발생합니다. 데이터베이스에 동시 연결이 16개로 제한되어 있고 바쁜 세션의 경우 17개의 스레드가 연결을 시도하면 하나의 스레드가 연결에 실패합니다. 이때 연결이 닫히지 못하게 하는 오류(예: 무한 루프)가 스크립트에 발생하면 데이터베이스에 대한 16개의 연결이 빠르게 영향을 받게 됩니다. 중단된 연결과 유휴 연결을 처리하는 방법에 대한 자세한 내용은 데이터베이스 사용 설명서를 참조하세요.

영구 연결을 사용할 때 주의해야 할 몇 가지 특별한 문제가 있습니다. 예를 들어, 영구 연결에서 테이블 잠금을 사용할 때 스크립트가 어떤 이유로든 테이블 잠금을 해제할 수 없으면 동일한 연결을 사용하는 후속 스크립트가 영구적으로 차단되어 httpd 서비스 또는 데이터베이스 서비스를 다시 시작해야 합니다. 또한 트랜잭션 처리를 사용할 때 트랜잭션 차단이 발생하기 전에 스크립트가 종료되면 동일한 연결을 사용하는 다음 스크립트에도 차단이 영향을 미칩니다. 상황에 관계없이 간단한 정리 함수를 등록하여 데이터 테이블 잠금을 열거나 트랜잭션을 롤백하려면 Register_shutdown_function() 함수를 사용하면 됩니다. 또는 더 좋은 방법은 데이터 테이블 잠금이나 트랜잭션 처리를 사용하는 스크립트에서 영구 연결을 사용하지 않는 것입니다. 이렇게 하면 이 문제를 근본적으로 해결할 수 있습니다(물론 다른 위치에서도 영구 연결을 사용할 수도 있습니다).

다음은 중요한 요약입니다. 영구 연결은 공통 연결에 대해 일대일 배포를 설정하도록 설계되었습니다. 이는 영구 연결을 비영구 연결로 바꿀 때 스크립트의 동작이 변경되지 않도록 보장할 수 있어야 함을 의미합니다. 영구 연결을 사용하면 스크립트의 효율성이 (매우) 변경될 가능성이 높지만 해당 동작은 변경되지 않습니다!


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.