sql >> データベース >  >> RDS >> Mysql

ノードアプリがしばらく動作してクラッシュするのはなぜですか(heroku)?

    これ 問題になる可能性があります

    次のコードを使用して、サーバーの切断を処理できます

    var db_config = {
      host: 'localhost',
        user: 'root',
        password: '',
        database: 'example'
    };
    
    var connection;
    
    function handleDisconnect() {
      connection = mysql.createConnection(db_config); // Recreate the connection, since
                                                      // the old one cannot be reused.
    
      connection.connect(function(err) {              // The server is either down
        if(err) {                                     // or restarting (takes a while sometimes).
          console.log('error when connecting to db:', err);
          setTimeout(handleDisconnect, 2000); // We introduce a delay before attempting to reconnect,
        }                                     // to avoid a hot loop, and to allow our node script to
      });                                     // process asynchronous requests in the meantime.
                                              // If you're also serving http, display a 503 error.
      connection.on('error', function(err) {
        console.log('db error', err);
        if(err.code === 'PROTOCOL_CONNECTION_LOST') { // Connection to the MySQL server is usually
          handleDisconnect();                         // lost due to either server restart, or a
        } else {                                      // connnection idle timeout (the wait_timeout
          throw err;                                  // server variable configures this)
        }
      });
    }
    
    handleDisconnect();
    



    1. MySQLとPHPを使用したベストマッチ

    2. データベース内の重複する一時レコードをマージします

    3. MariaDB FLOOR()とTRUNCATE()

    4. 日時形式の NULL 値を空の文字列に変更します