Nodejs パス印刷エラー例外

王林
王林オリジナル
2023-05-11 13:33:37658ブラウズ

Node.js では、エラーと例外の処理はアプリケーションの安定性と信頼性にとって非常に重要です。エラーや例外を処理しないと、アプリケーションがクラッシュしたり、誤った操作が実行されたりする可能性があります。

この記事では、問題を時間内に発見して解決できるように、Node.js でエラー例外を出力する方法について説明します。

エラーと例外について

Node.js では、エラーと例外は異なる概念ですが、どちらもアプリケーションの実行中に問題が発生したことを示します。

エラーは通常、必要なパラメーターが欠落していたり​​、間違った操作を実行したりするなど、プログラマーによって引き起こされた問題を指します。これらのエラーは、ユーザー エラーまたはプログラミング エラーと呼ばれることがよくあります。

例外は通常、データベースに接続できない、メモリが不足しているなど、システムまたはサードパーティのライブラリによって引き起こされる問題を指します。これらの例外は、システム例外またはランタイム例外と呼ばれることがよくあります。

エラーであっても例外であっても、時間内に検出して解決する必要があります。そうしないと、アプリケーションがハングしたりクラッシュしたりする可能性があります。

エラーと例外のキャッチ

Node.js では、エラーと例外のキャッチには通常、try...catch ステートメントを使用します。

たとえば、2 つの数値を加算して結果を返す関数 add があるとします。文字列や null などの無効な引数を指定してこの関数を呼び出すと、関数はエラーをスローします。 try...catch ステートメントを使用すると、このエラーを捕捉し、適切なアクションを実行できます。

function add(a, b) {
  if (typeof a !== 'number' || typeof b !== 'number') {
    throw new Error('Invalid arguments');
  }
  return a + b;
}

try {
  const result = add(1, 'two');
  console.log(result);
} catch (error) {
  console.error(error);
}

上記のコードでは、「one」は数値ではないため、add 関数はエラーをスローします。 try...catch ステートメントは、このエラーをキャッチしてログに記録するために使用されます。 console.error 関数は、エラー メッセージを標準エラー ストリームに書き込み、コンソールまたはログ ファイルに記録されるようにするために使用されます。

例外をキャッチした場合は、問題を解決するために適切な手順を実行する必要があります。考えられる解決策には、操作の再試行、構成オプションの変更、または管理者への通知が含まれます。

エラーと例外をログ システムに送信する

運用環境の Node.js アプリケーションの場合は、エラーと例外を分析して問題を解決できるように、ログ システムに送信することを検討する必要があります。

一般的なログ システムには、Loggly、Splunk、Elasticsearch などがあります。これらのシステムでは通常、ログ データを中央サーバーに送信し、問題をタイムリーに発見して解決できるように分析および警告機能を提供できます。

エラーと例外をログ システムに送信するには、Node.js のログ ライブラリを使用する必要があります。人気のあるログ ライブラリには、Winston や Bunyan などがあります。

これは、Winston を使用してエラーと例外をログ ファイルに記録するサンプル コードです:

const winston = require('winston');

const logger = winston.createLogger({
  level: 'error',
  transports: [
    new winston.transports.File({ filename: 'error.log' }),
  ],
});

function add(a, b) {
  if (typeof a !== 'number' || typeof b !== 'number') {
    logger.error('Invalid arguments', { a, b });
    throw new Error('Invalid arguments');
  }
  return a + b;
}

try {
  add(1, 'two');
} catch (error) {
  logger.error(error.message, { stack: error.stack });
}

上記のコードでは、Winston を使用してロガーを作成し、レベル ' のすべてのメッセージを記録します。 error」は「error.log」ファイルに送信されます。 add 関数はパラメーターが有効かどうかをチェックし、有効でない場合はエラー メッセージをログ ファイルに記録し、エラーをスローします。 catch ブロックでは、スローされたエラーをログ ファイルに記録します。

結論

Node.js アプリケーションでは、エラーと例外の処理が非常に重要です。 try...catch ステートメントとログ ライブラリを使用すると、問題を時間内に発見して解決できるため、アプリケーションの信頼性と安定性が向上します。

開発環境であっても実稼働環境であっても、問題を迅速に解決してアプリケーションの品質を向上させるために、エラーと例外をログに記録し、それらを定期的に分析することを検討する必要があります。

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

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