찾다
백엔드 개발PHP 튜토리얼PHP 데이터베이스 영구 연결

PHP 데이터베이스 영구 연결

Nov 22, 2016 am 10:23 AM
phpPHP 데이터베이스

영구 데이터베이스 연결은 스크립트 실행이 완료될 때 닫히지 않는 연결을 의미합니다. 영구 연결 요청을 받은 경우. 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으로 문의하세요.
PHP 세션의 개념을 간단한 용어로 설명하십시오.PHP 세션의 개념을 간단한 용어로 설명하십시오.Apr 26, 2025 am 12:09 AM

phpsessionstrackuserdataacrossmultiplepagerequestsususingauniqueIdStoredInAcookie.here'showtomanagetheMeftically : 1) STARTASESSIONSTART_START () andSTAREDATAIN $ _SESSION.2) RegenerATERATESSESSIDIDAFTERLOGINWITHSESSION_RATERATERATES (True) TopreventSES

PHP 세션에 저장된 모든 값을 어떻게 반복합니까?PHP 세션에 저장된 모든 값을 어떻게 반복합니까?Apr 26, 2025 am 12:06 AM

PHP에서 세션 데이터를 통한 반복은 다음 단계를 통해 달성 할 수 있습니다. 1. Session_start ()를 사용하여 세션을 시작하십시오. 2. $ _session 배열의 모든 키 값 쌍을 통해 Foreach 루프를 통과합니다. 3. 복잡한 데이터 구조를 처리 할 때 is_array () 또는 is_object () 함수를 사용하고 print_r ()를 사용하여 자세한 정보를 출력하십시오. 4. Traversal을 최적화 할 때 페이징을 사용하여 한 번에 많은 양의 데이터를 처리하지 않도록 할 수 있습니다. 이를 통해 실제 프로젝트에서 PHP 세션 데이터를보다 효율적으로 관리하고 사용하는 데 도움이됩니다.

사용자 인증에 세션을 사용하는 방법을 설명하십시오.사용자 인증에 세션을 사용하는 방법을 설명하십시오.Apr 26, 2025 am 12:04 AM

이 세션은 서버 측 상태 관리 메커니즘을 통해 사용자 인증을 인식합니다. 1) 세션 생성 및 고유 ID의 세션 생성, 2) ID는 쿠키를 통해 전달됩니다. 3) ID를 통해 서버 저장 및 세션 데이터에 액세스합니다. 4) 사용자 인증 및 상태 관리가 실현되어 응용 프로그램 보안 및 사용자 경험이 향상됩니다.

PHP 세션에 사용자 이름을 저장하는 방법의 예를 제시하십시오.PHP 세션에 사용자 이름을 저장하는 방법의 예를 제시하십시오.Apr 26, 2025 am 12:03 AM

tostoreauser'snameinaphpsession, startSessionstart_start (), wathsignthenameto $ _session [ 'username']. 1) useSentess_start () toinitializethesession.2) assimeuser'snameto $ _session [ 'username']

PHP 세션이 실패 할 수있는 몇 가지 일반적인 문제는 무엇입니까?PHP 세션이 실패 할 수있는 몇 가지 일반적인 문제는 무엇입니까?Apr 25, 2025 am 12:16 AM

phpsession 실패 이유에는 구성 오류, 쿠키 문제 및 세션 만료가 포함됩니다. 1. 구성 오류 : 올바른 세션을 확인하고 설정합니다. 2. 쿠키 문제 : 쿠키가 올바르게 설정되어 있는지 확인하십시오. 3. 세션 만료 : 세션 시간을 연장하기 위해 세션을 조정합니다 .GC_MAXLIFETIME 값을 조정하십시오.

PHP의 세션 관련 문제를 어떻게 디버그합니까?PHP의 세션 관련 문제를 어떻게 디버그합니까?Apr 25, 2025 am 12:12 AM

PHP에서 세션 문제를 디버그하는 방법 : 1. 세션이 올바르게 시작되었는지 확인하십시오. 2. 세션 ID의 전달을 확인하십시오. 3. 세션 데이터의 저장 및 읽기를 확인하십시오. 4. 서버 구성을 확인하십시오. 세션 ID 및 데이터를 출력, 세션 파일 컨텐츠보기 등을 통해 세션 관련 문제를 효과적으로 진단하고 해결할 수 있습니다.

session_start ()가 여러 번 호출되면 어떻게됩니까?session_start ()가 여러 번 호출되면 어떻게됩니까?Apr 25, 2025 am 12:06 AM

Session_Start ()로 여러 통화를하면 경고 메시지와 가능한 데이터 덮어 쓰기가 발생합니다. 1) PHP는 세션이 시작되었다는 경고를 발행합니다. 2) 세션 데이터의 예상치 못한 덮어 쓰기를 유발할 수 있습니다. 3) Session_status ()를 사용하여 반복 통화를 피하기 위해 세션 상태를 확인하십시오.

PHP에서 세션 수명을 어떻게 구성합니까?PHP에서 세션 수명을 어떻게 구성합니까?Apr 25, 2025 am 12:05 AM

SESSION.GC_MAXLIFETIME 및 SESSION.COOKIE_LIFETIME을 설정하여 PHP에서 세션 수명을 구성 할 수 있습니다. 1) SESSION.GC_MAXLIFETIME 서버 측 세션 데이터의 생존 시간을 제어합니다. 2) 세션 .Cookie_Lifetime 클라이언트 쿠키의 수명주기를 제어합니다. 0으로 설정하면 브라우저가 닫히면 쿠키가 만료됩니다.

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

뜨거운 도구

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

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

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

mPDF

mPDF

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

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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