`wait_timeout`이 훨씬 높음에도 불구하고 MySQL 쿼리가 60초 후에 시간 초과되는 이유는 무엇입니까?

Susan Sarandon
풀어 주다: 2024-11-27 05:07:13
원래의
297명이 탐색했습니다.

Why is my MySQL query timing out after 60 seconds, even though `wait_timeout` is much higher?

MySQL 서버가 사라졌습니다. 예상보다 60초 정도 늦었습니다.

이 문서에서는 MySQL 서버가 쿼리를 수행하게 된 원인에 대해 설명합니다. 120초 동안 지속된 문제 60초 후에 시간이 초과되고 오류가 발생하는 문제입니다. 쿼리가 제대로 실행되었음에도 불구하고 PHP 스크립트의 문제로 인해 이 오류가 발생했습니다.

문제 증상

  • PHP SELECT SLEEP(120)을 통한 쿼리 실행 시간이 60초 후에 초과됩니다.
  • MySQL 클라이언트에서 동일한 쿼리를 실행하면 성공적으로 실행됩니다.
  • 제한 시간은 매번 60초로 고정되어 있으며 이는 리소스 제한이 아닌 설정 문제일 수 있음을 나타냅니다.

시스템 구성

  • Windows Server 2003
  • MySql 5.1.36-커뮤니티
  • PHP 5.3

분석

SHOW VARIABLES 출력을 확인한 결과 wait_timeout이 28800(480분)으로 설정되어 있는 것을 확인했지만 여전히 오류가 발생합니다. 이는 wait_timeout이 문제가 아님을 보여줍니다.

해결 방법

문제의 원인은 PHP 옵션 mysql.connect_timeout입니다. 이 옵션은 연결 시간 초과뿐만 아니라 서버의 첫 번째 응답을 기다리는 데에도 사용됩니다. 쿼리 시간은 120초로 설정되어 있고 mysql.connect_timeout은 기본적으로 60초로 설정되어 있으므로 서버는 60초 후에 연결을 종료하여 오류가 발생합니다.

mysql.connect_timeout을 120초 이상으로 늘려 이 문제를 해결했습니다. 이는 다음 코드를 사용하여 달성됩니다:

ini_set('mysql.connect_timeout', 300);
ini_set('default_socket_timeout', 300); 
로그인 후 복사

이렇게 하면 mysql.connect_timeout이 300초로 늘어나 서버 응답을 기다리는 동안 연결이 조기에 종료되는 것을 방지할 수 있습니다.

위 내용은 `wait_timeout`이 훨씬 높음에도 불구하고 MySQL 쿼리가 60초 후에 시간 초과되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿