MySQL 서버가 사라졌습니다: '일반 오류: 2006' 수수께끼
MySQL 데이터베이스에 대량 삽입을 수행할 때 두려운 "SQLSTATE[HY000]: 일반 오류: 2006 MySQL 서버가 사라졌습니다." 오류가 나타날 수 있습니다. 겉보기에 파악하기 어려운 이 문제는 데이터베이스 작업의 원활한 실행을 방해합니다. 그 비밀을 풀기 위해 우리는 이 수수께끼 같은 오류를 이해하고 잠재적인 해결책을 찾기 위한 여정을 시작합니다.
숨겨진 원인 밝히기: wait_timeout
"MySQL 서버에는 사라졌습니다" 오류는 종종 시간 초과 제한으로 인해 발생합니다. 특히 이는 wait_timeout이라는 MySQL 변수에서 시작됩니다. 이 변수는 연결을 종료하기 전에 MySQL이 클라이언트 활동을 참을성 있게 기다리는 시간(초)을 결정합니다.
기본적으로 wait_timeout은 공유 호스트에서 30초로 설정됩니다. 그러나 데이터베이스 작업이 이 시간 제한을 초과하면 연결이 갑자기 종료되어 앞서 언급한 오류가 발생합니다.
문제 해결: wait_timeout 조정
이 문제를 해결하려면 문제가 발생하면 데이터베이스 작업 기간을 수용할 수 있도록 대기 시간을 연장해야 합니다. 이는 현재 세션의 wait_timeout을 28800초(8시간)로 설정하는 "SET session wait_timeout=28800" 쿼리를 실행하여 달성할 수 있습니다.
추가 고려 사항: 대화형 시간 초과
특정 시나리오에서는 wait_timeout과 함께 Interactive_timeout 변수를 수정해야 할 수도 있습니다. 이 변수는 유휴 대화형 연결의 최대 기간을 제어합니다. Interactive_timeout이 작업 실행 시간보다 낮으면 연결이 갑자기 닫혀 동일한 오류가 발생합니다.
구현: PHP 코드
이 솔루션을 다음에서 구현하려면 PHP에서는 다음 코드 샘플을 활용하세요.
<code class="php">$results = $db->query("SHOW VARIABLES LIKE '%timeout%'", TRUE); echo "<pre class="brush:php;toolbar:false">"; var_dump($results); echo ""; $results = $db->query("SET session wait_timeout=28800", FALSE); // UPDATE - this is also needed $results = $db->query("SET session interactive_timeout=28800", FALSE); $results = $db->query("SHOW VARIABLES LIKE '%timeout%'", TRUE); echo "
"; var_dump($results); echo "";
데이터베이스 작업을 실행하기 전에 PHP 스크립트에 다음 줄을 추가하여 시간 초과 설정을 조정하세요. 이렇게 하면 "MySQL 서버가 사라졌습니다." 오류가 발생하지 않고 작업을 완료할 수 있습니다.
위 내용은 내 MySQL 서버에서 계속 \'일반 오류: 2006 MySQL 서버가 사라졌습니다\'라고 표시되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!