>데이터 베이스 >MySQL 튜토리얼 >MySQL을 사용할 때 내 Node.js 앱에 '연결 끊김: 서버가 연결을 닫았습니다' 오류가 발생하는 이유는 무엇이며 어떻게 해결할 수 있습니까?

MySQL을 사용할 때 내 Node.js 앱에 '연결 끊김: 서버가 연결을 닫았습니다' 오류가 발생하는 이유는 무엇이며 어떻게 해결할 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-13 03:09:10342검색

Why Does My Node.js App Get

연결 끊김: Node.js에서 MySQL 연결 끊김 문제 해결

Node.js 사용자는 "연결 끊김: 서버가 연결을 닫았습니다. mysql 모듈을 사용할 때 " 오류가 발생했습니다. 이 문제는 종종 특정 시간 범위(예: 자정부터 오전 2시 사이) 내에서 서버가 TCP 연결을 갑자기 종료할 때 발생합니다.

원인

오류는 다음을 나타냅니다. Node.js와 MySQL 서버 사이의 연결이 일반적으로 예기치 않은 연결 끊김 또는 서버로 인해 서버에 의해 끊어졌습니다. 다시 시작하세요.

해결 방법

이 문제를 해결하려면 끊어진 연결을 자동으로 감지하고 다시 설정하는 연결 처리 메커니즘을 사용할 수 있습니다. 예는 다음과 같습니다.

var db_config = {
  host: 'localhost',
  user: 'root',
  password: '',
  database: 'example'
};

var connection;

function handleDisconnect() {
  connection = mysql.createConnection(db_config);

  connection.connect(function(err) {
    if (err) {
      console.log('error when connecting to db:', err);
      setTimeout(handleDisconnect, 2000);
    }
  });

  connection.on('error', function(err) {
    console.log('db error', err);
    if (err.code === 'PROTOCOL_CONNECTION_LOST') {
      handleDisconnect();
    } else {
      throw err;
    }
  });
}

handleDisconnect();

설명

이 솔루션에서는

  1. db_config 개체가 데이터베이스 연결 매개변수를 지정합니다.
  2. handleDisconnect 함수가 호출되어 새 연결을 생성하고 오류 핸들러를 연결합니다.
  3. 서버 재시작 또는 유휴 시간 초과로 인해 연결이 끊어지면 오류 처리기가 이를 감지하고 다시 handlerDisconnect 함수를 호출하여 연결을 다시 생성합니다.
  4. setTimeout 함수는 과도한 연결을 방지합니다. 재시도 전에 지연을 도입하여 재연결 시도를 시도합니다.

이 연결 처리 메커니즘을 구현하면 애플리케이션이 원활하게 연결되도록 할 수 있습니다. 서버를 다시 시작하거나 유지 관리 기간 동안에도 일시적인 연결 손실을 처리하고 MySQL 데이터베이스에 대한 안정적인 연결을 유지합니다.

위 내용은 MySQL을 사용할 때 내 Node.js 앱에 '연결 끊김: 서버가 연결을 닫았습니다' 오류가 발생하는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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