phpchina에서 컴파일된 질문:
1. mysql_connect() 함수를 사용하여 다음과 같은 싱글톤 클래스를 만듭니다.
[code=PHP]class DB { private static $db=NULL; private function __construct() { ; } public static function conn() { if(self::$db==NULL) { self::$db=mysql_connect('localhost','root','****'); } return self::$db; }[/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는 프로세스 풀을 사용하므로 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 스크립트의 문제뿐만 아니라 데이터베이스와 서버의 설정도 관련이 있습니다.