찾다
백엔드 개발PHP 튜토리얼PHP를 사용하여 데이터베이스에 효율적으로 연결하는 방법

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

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
PHP 세션에 어떤 데이터를 저장할 수 있습니까?PHP 세션에 어떤 데이터를 저장할 수 있습니까?May 02, 2025 am 12:17 AM

phpsessionscanstorestrings, 숫자, 배열 및 객체 1.Strings : TextDatalikeUsernames.2.numbers : integorfloatsforcounters.3.arrays : listslikeshoppingcarts.4.objects : complexStructuresThatareserialized.

PHP 세션을 어떻게 시작합니까?PHP 세션을 어떻게 시작합니까?May 02, 2025 am 12:16 AM

tostartAphPessession, us

세션 재생이란 무엇이며 보안을 어떻게 개선합니까?세션 재생이란 무엇이며 보안을 어떻게 개선합니까?May 02, 2025 am 12:15 AM

세션 재생은 세션 고정 공격의 경우 사용자가 민감한 작업을 수행 할 때 새 세션 ID를 생성하고 이전 ID를 무효화하는 것을 말합니다. 구현 단계에는 다음이 포함됩니다. 1. 민감한 작업 감지, 2. 새 세션 ID 생성, 3. 오래된 세션 ID 파괴, 4. 사용자 측 세션 정보 업데이트.

PHP 세션을 사용할 때 몇 가지 성능 고려 사항은 무엇입니까?PHP 세션을 사용할 때 몇 가지 성능 고려 사항은 무엇입니까?May 02, 2025 am 12:11 AM

PHP 세션은 응용 프로그램 성능에 큰 영향을 미칩니다. 최적화 방법은 다음과 같습니다. 1. 데이터베이스를 사용하여 세션 데이터를 저장하여 응답 속도를 향상시킵니다. 2. 세션 데이터 사용을 줄이고 필요한 정보 만 저장하십시오. 3. 비 차단 세션 프로세서를 사용하여 동시성 기능을 향상시킵니다. 4. 사용자 경험과 서버 부담의 균형을 맞추기 위해 세션 만료 시간을 조정하십시오. 5. 영구 세션을 사용하여 데이터 읽기 및 쓰기 시간의 수를 줄입니다.

PHP 세션은 쿠키와 어떻게 다릅니 까?PHP 세션은 쿠키와 어떻게 다릅니 까?May 02, 2025 am 12:03 AM

phpsessionsareser-side, whilecookiesareclient-side.1) sessions stessoredataontheserver, andhandlargerdata.2) cookiesstoredataonthecure, andlimitedinsize.usesessionsforsensitivestataondcookiesfornon-sensistive, client-sensation.

PHP는 사용자 세션을 어떻게 식별합니까?PHP는 사용자 세션을 어떻게 식별합니까?May 01, 2025 am 12:23 AM

phpidifiesauser의 sssessionusessessioncookiesandssessionids.1) whensession_start () iscalled, phpgeneratesauniquessessionStoredInacookienamedPhpsSessIdonSeuser 'sbrowser.2) thisidallowsphptoretrievessessionDataTromServer.

PHP 세션을 확보하기위한 모범 사례는 무엇입니까?PHP 세션을 확보하기위한 모범 사례는 무엇입니까?May 01, 2025 am 12:22 AM

PHP 세션의 보안은 다음 측정을 통해 달성 할 수 있습니다. 1. Session_REGENEREAT_ID ()를 사용하여 사용자가 로그인하거나 중요한 작업 일 때 세션 ID를 재생합니다. 2. HTTPS 프로토콜을 통해 전송 세션 ID를 암호화합니다. 3. 세션 _save_path ()를 사용하여 세션 데이터를 저장하고 권한을 올바르게 설정할 보안 디렉토리를 지정하십시오.

PHP 세션 파일은 기본적으로 어디에 저장됩니까?PHP 세션 파일은 기본적으로 어디에 저장됩니까?May 01, 2025 am 12:15 AM

phpsessionfilesarestoredInTheRectorySpecifiedBysession.save_path, 일반적으로/tmponunix-likesystemsorc : \ windows \ temponwindows.tocustomizethis : 1) austession_save_path () toSetacustomDirectory, verlyTeCustory-swritation;

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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

메모장++7.3.1

메모장++7.3.1

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

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)