phpchina에서 컴파일된 질문:
1. mysql_connect() 함수를 사용하여 다음과 같은 싱글톤 클래스를 만듭니다.
[code=PHP]class DB
{
private static $ db =NULL; | | > [/code]2. pconnect 긴 연결을 직접 사용
3. 데이터베이스 작업 클래스를 생성하고 인스턴스 구축 시 데이터베이스에 연결한 후 연결을 닫습니다. (mysql_close) 파기할 때
4. 긴 연결 PHP 코드를 우선시합니다
[code="PHP"]if(mysql_pconnect())
{
$conn=mysql_pconnect();
}else{
$conn=mysql_connect();
}[/ code] 위의 네 가지 방법 중 성능이 더 높은 것은 무엇입니까? 아니면 다른 동시성 상황에서 어떤 시나리오에서 어떤 연결이 더 좋습니까? >
다음과 같이 답변하시는 분들도 계십니다.
PHP 레벨에서는 어떻게 코드를 작성해도 똑같고 차이가 없습니다. 긴 연결과 일반 링크의 차이점을 강조하겠습니다.
영구 링크는 서버가 연결을 열고 모든 사람이 링크를 공유한다는 의미는 아닙니다. 영구 연결은 또한 각 클라이언트에 대한 연결을 엽니다. 200명이 방문하면 200개의 연결이 있게 됩니다. 실제로 mysql_pconnect() 자체는 많은 처리를 수행하지 않습니다. 단지 PHP 실행이 완료된 후 mysql 연결을 적극적으로 닫지 않는 것뿐입니다.
PHP가 CGI를 통해 실행되는 경우 기본적으로 pconnect와 차이는 없습니다. cgi 메소드는 각 PHP 액세스에 대해 프로세스를 시작하므로 액세스가 완료된 후 프로세스가 종료되고 모든 리소스가 해제됩니다. PHP가 Apache 모듈 모드에서 실행되면 Apache는 프로세스 풀인 httpd를 사용합니다. 프로세스는 종료된 후 삭제되며, pconnect로 열린 mysql 연결 리소스가 해제되는 것을 방지하여 다음 연결 요청이 있을 때 재사용할 수 있습니다. 동시접속량이 크지 않은데, pconnect를 사용하지 않으면 PHP는 db에 반복적으로 접속하는 시간을 절약하여 접속속도를 더욱 빠르게 해준다. 닫지 않으면 mysql이 최대 연결 수에 도달하여 최대 mysql 연결 수가 설정된 경우 일부 후속 요청이 충족되지 않을 수 있습니다. 500으로 설정하고, apache의 최대 동시 접속 횟수를 2000으로 설정하면, 모든 접속에는 Access db가 필요한 것으로 가정하고, 현재 500개의 httpd 요청이 끝나지 않았을 때 이후의 httpd 처리 시간이 상대적으로 길어질 것입니다. (최대 mysql 연결 수에 도달했기 때문에) 현재 500개의 httpd 프로세스만 종료되었거나 db 작업을 재사용할 때 mysql
에 연결할 수 있습니다. 복잡하고 시간이 오래 걸리므로 httpd는 많은 동시 프로세스를 포크하고 처음 생성된 httpd 프로세스는 db 연결을 해제하지 않으므로 나중에 생성된 httpd 프로세스는 mysql 연결을 재사용하지 않기 때문에 db에 연결할 수 없습니다. 따라서 다른 httpd 프로세스의 연결 시간 초과가 많이 발생합니다. 동시 접속량이 많지 않은 경우 pconnect를 사용하면 단순히 접속 속도를 향상시킬 수 있지만, 동시 접속량이 증가한 후에는 pconnect를 다시 사용할지 여부는 프로그래머의 선택에 달려 있습니다.
PHP의 mysql 연결은 실제로 사용되지 않습니다. pool, pconnect는 Apache의 프로세스 풀을 빌리는 것과 같기 때문에 동시 접속량이 많을 경우 pconnect는 db 접속 효율성을 향상시킬 수 없습니다.
실제 애플리케이션에서는 mysql_pconnect를 사용하면 매번 새로 고침하는 것이 더 빠릅니다. 매번 새 페이지를 요청하지만 mysql_connect를 사용하면 데이터베이스 연결이 느려질 때마다 새로 요청해야 합니다. 데이터베이스 연결이 느린 경우, DB 작업이 크게 복잡하지 않은 경우, 교착 상태가 발생하지 않을 것이라는 프로그램에 대한 확신이 있는 경우, 서버에 대한 제어권이 있는 경우 위 네 가지 조건 중 두 가지를 모두 충족해야 합니다. 그런 다음 pconnect를 사용할 수 있습니다.
pconnect는 스크립트에서 닫을 필요가 없습니다. mysql에서 수명을 설정하거나 쉘을 작성하여 정기적으로 스캔하고 너무 오랫동안 휴면 상태였던 연결을 종료할 수 있습니다. 한 문장 요약: pconnect를 잘 사용하려면 PHP 스크립트의 문제뿐만 아니라 데이터베이스와 서버의 설정도 관련이 있습니다.