Nodejs接続mysqlエラー

WBOY
WBOYオリジナル
2023-05-25 12:58:081456ブラウズ

Node.js は効率的、高速、信頼性の高いサーバー側プログラミング言語であり、サーバー側データのリアルタイム更新と処理を非常にうまく実現できます。 MySQL は、インターネットやエンタープライズ レベルのソフトウェアのデータ ストレージ分野で広く使用されているリレーショナル データベース管理システムです。 Node.js と MySQL を組み合わせることで、サーバー側のデータの保存と管理を実現できますが、実際の開発プロセスではいくつかの問題が発生する可能性があります。この記事では、MySQL への接続時の node.js エラーという一般的な問題について紹介します。

1. エラー パフォーマンス

Node.js を使用して MySQL に接続すると、次のようなエラー パフォーマンスが発生する可能性があります:

  1. エラー: connect ETIMEDOUT
  2. エラー: connect ECONNREFUSED
  3. エラー: ER_ACCESS_DENIED_ERROR
  4. エラー: quit を呼び出した後にハンドシェイクをキューに入れることができません

2. エラーの理由の分析

  1. 接続タイムアウト

エラー: connect ETIMEDOUT

このエラーは、通常、MySQL サーバーがリクエストに応答できない可能性があるため、ネットワーク接続タイムアウトによって発生します。またはユーザーの接続リクエスト 比較的遅い。 Node.js が MySQL に接続するときは、接続タイムアウト時間を指定し、指定された時間内に接続を確立する必要があります。そうしないと、接続 ETIMEDOUT エラーが報告されます。

  1. 接続が拒否されました

エラー: 接続 ECONNREFUSED

このエラーは通常、ホスト名など、MySQL への接続に関連するパラメータの設定が間違っていることが原因で発生します。 、ユーザー名、パスワードなど。このエラーは通常、サーバーにリモートで接続するときに発生します。サーバーがファイアウォールを設定しているか、特定の IP アドレスまたはネットワーク セグメントのみが MySQL に接続できるように指定されていることが原因である可能性があります。

  1. 権限の検証に失敗しました

エラー: ER_ACCESS_DENIED_ERROR

このエラーは通常、ユーザー名またはパスワードの入力が間違っているか、権限が不十分であるか、サーバーで禁止されていることが原因で発生します。特定の権限によるものです。このエラーは、入力されたユーザー名またはパスワードが正しくない場合に MySQL に接続するときに発生します。このエラーは、ユーザーがデータベースにアクセスするための十分な権限を持っていない場合にも発生します。

  1. アプリケーション エラー

エラー: quit を呼び出した後、ハンドシェイクをキューに追加できません

このエラーは通常、アプリケーション エラーによって発生します。おそらく、MySQL 接続にエラーが発生している可能性があります。アプリケーションが終了する前に閉じられました。この場合、接続プール内の接続が正しく閉じられているか、他に問題がないかを注意深く確認する必要があります。

3. エラー解決方法

  1. 接続タイムアウト

接続タイムアウトエラーを回避するには、チェック待ち時間と接続タイムアウト時間を設定する必要があります。 。通常、これを 5 秒から 10 秒の範囲に設定します。以下は、MySQL に接続するためのコード スニペットの例です。

const mysql = require('mysql');

const connection = mysql.createConnection({
host : 'localhost' ,
ユーザー : 'root',
パスワード : 'password',
データベース : 'mydatabase',
connectTimeout: 10000,
AcquireTimeout: 10000
});

connection.connect((err) => {
if (err) throw err;
console.log('Connected!');
});

    # 接続が拒否されました
接続が拒否されましたエラーは、正しいホスト名、ユーザー名、パスワードを設定することで解決できます。リモート サーバーに接続している場合は、接続の IP アドレスとポート番号が正しいこと、サーバーにファイアウォールが設定されていないこと、または特定の IP アドレスやネットワーク セグメントへのアクセスが制限されていないことを確認する必要があります。以下は、MySQL に接続するためのサンプル コード スニペットです:

const mysql = require('mysql');

const connection = mysql.createConnection({

host : 'remote- server.com',
ポート : '3306',
ユーザー : 'root',
パスワード : 'password',
データベース : 'mydatabase'
});

connection.connect((err) => {

if (err) throw err;
console.log('Connected!');
});

#権限の検証に失敗しました
  1. MySQL への接続時に権限の検証失敗エラーが発生した場合は、入力されたユーザー名とパスワードが正しいこと、およびユーザーがデータベースにアクセスする権限を持っていることを確認する必要があります。 root ユーザーを使用している場合、MySQL サーバーには、特定のホストにのみログインして root アカウントを使用するルールが設定されている可能性があることに注意する必要があります。

アプリケーション エラー
  1. MySQL への接続時にアプリケーション エラーが発生した場合は、接続プール内の接続が閉じられているかどうか、およびその他の考えられる質問を確認する必要があります。接続プールを適切に閉じるために使用できるサンプル コードを次に示します。

const mysql = require('mysql');

const pool = mysql.createPool({

connectionLimit : 10,
ホスト : 'localhost',
ユーザー : 'root',
パスワード : 'password',
データベース : 'mydatabase'
});

pool.getConnection ((err , connection) => {

console.log('idとして接続', connection.threadId);


connection.query('SELECT * FROM users', function (error, results 、フィールド) {

if (error) throw error;

console.log('The solution is: ', results);

// Connection is automatically released when query resolves
connection.release();

});

});

結論として、Node.js から MySQL エラーに接続するのは難しい作業になる可能性がありますが、問題の根本原因を特定して解決を試みることができれば、これらの問題はすぐに解決できます。開発中に問題が発生した場合、コードをデバッグおよびテストすることで問題を見つけて解決できるため、より信頼性が高く効率的なアプリケーションを構築できます。

以上がNodejs接続mysqlエラーの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。