찾다
백엔드 개발PHP 튜토리얼PHP로 데이터베이스에 효율적으로 연결하는 방법은 무엇입니까?

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 스크립트의 문제뿐만 아니라 데이터베이스와 서버의 설정도 관련이 있습니다.


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

aphpdectionenceindectioncontainerisatoolthatmanagesclassdependencies, 향상 Codemodularity, testability 및 maintainability.itactAsacentralHubForCreatingAndingDinjectingDingingDingingdecting.

PHP의 종속성 주입 대 서비스 로케이터PHP의 종속성 주입 대 서비스 로케이터May 13, 2025 am 12:10 AM

대규모 응용 프로그램의 경우 SELLENCIONINGESS (DI)를 선택하십시오. ServicElocator는 소규모 프로젝트 또는 프로토 타입에 적합합니다. 1) DI는 생성자 주입을 통한 코드의 테스트 가능성과 모듈성을 향상시킵니다. 2) Servicelocator는 센터 등록을 통해 서비스를 얻습니다. 이는 편리하지만 코드 커플 링이 증가 할 수 있습니다.

PHP 성능 최적화 전략.PHP 성능 최적화 전략.May 13, 2025 am 12:06 AM

phPapplicationSCanBeoptimizedForsPeedandefficiencyby : 1) ENABLEOPCACHEINPHP.INI, 2) PREPAREDSTATEMENTSWITHPDOFORDATABASEQUERIES 사용

PHP 이메일 검증 : 이메일이 올바르게 전송되도록합니다PHP 이메일 검증 : 이메일이 올바르게 전송되도록합니다May 13, 2025 am 12:06 AM

phpeMailValidationInvoLvestHreesteps : 1) formatValidationUsingRegularexpressionsTochemailformat; 2) dnsValidationToErethedomainHasaValidMxRecord; 3) smtpvalidation, theSTHOROUGHMETHOD, theCheckSiftheCefTHECCECKSOCCONNECTERTETETETETETETWERTETWERTETWER

PHP 응용 프로그램을 더 빨리 만드는 방법PHP 응용 프로그램을 더 빨리 만드는 방법May 12, 2025 am 12:12 AM

TomakePhPapplicationSfaster, followthesesteps : 1) useopCodeCaching likeOpcachetOrpectipiledScriptBecode.2) MinimizedAtabaseQueriesByUsingQueryCachingandEfficientIndexing.3) leveragephp7 assistorBetterCodeeficiession.4) 구현 전략적 지시

PHP 성능 최적화 점검표 : 지금 속도를 향상시킵니다PHP 성능 최적화 점검표 : 지금 속도를 향상시킵니다May 12, 2025 am 12:07 AM

toImprovePhPapplicationSpeed, followthesesteps : 1) enableOpCodeCachingWithApcuTeCeScripteXecutionTime.2) 구현 구현

PHP 의존성 주입 : 코드 테스트 가능성을 향상시킵니다PHP 의존성 주입 : 코드 테스트 가능성을 향상시킵니다May 12, 2025 am 12:03 AM

의존성 주입 (DI)은 명시 적으로 전이적 종속성에 의해 PHP 코드의 테스트 가능성을 크게 향상시킵니다. 1) DI 디퍼 커플 링 클래스 및 특정 구현은 테스트 및 유지 보수를보다 유연하게 만듭니다. 2) 세 가지 유형 중에서, 생성자는 상태를 일관성있게 유지하기 위해 명시 적 표현 의존성을 주입합니다. 3) DI 컨테이너를 사용하여 복잡한 종속성을 관리하여 코드 품질 및 개발 효율성을 향상시킵니다.

PHP 성능 최적화 : 데이터베이스 쿼리 최적화PHP 성능 최적화 : 데이터베이스 쿼리 최적화May 12, 2025 am 12:02 AM

DatabaseQuesyOptimizationInphPinVolvesVesstoigiestoInsperferferferferformance.1) SelectOnlyNecessaryColumnstoredAtatatransfer.2) useinDexingTeSpeedUpdatarretieval.3) ubstractOrerEresultSoffRequeries.4) UtilizePreDstatements Offeffi

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.