再利用性を最適化するための Node.js アプリケーションでのデータベース接続の管理
アプリケーション全体でデータベース接続を共有すると、パフォーマンスが向上し、リソースのボトルネックが回避されます。広く使用されている NoSQL データベースである MongoDB では、シームレスなデータ対話のために効率的な接続管理が必要です。 MongoDB 接続を再利用するためのベスト プラクティスを理解することは、Node.js アプリケーションのパフォーマンスを最適化するために重要です。
現在の実装:
提供された例では、一元化されたアプローチは次のとおりです。ここでは、メイン アプリケーション ファイル (server.js) で接続が確立され、モジュールと共有されます。これによりモジュールがデータベースにアクセスできるようになりますが、次のような潜在的な問題が発生します。
改善されたアプローチ:
詳細堅牢かつスケーラブルなアプローチには、データベース接続を管理し、他のモジュールがデータベースにアクセスするための一貫したインターフェイスを提供するユーティリティ モジュールを使用することが含まれます。通常、ユーティリティ モジュールには 2 つの主要な関数が含まれています。
実装:
接続ロジックをカプセル化する mongoUtil.js モジュールを作成します:
const MongoClient = require('mongodb').MongoClient; const url = "mongodb://localhost:27017"; var _db; module.exports = { connectToServer: function(callback) { MongoClient.connect(url, { useNewUrlParser: true }, function(err, client) { _db = client.db('test_db'); return callback(err); }); }, getDatabase: function() { return _db; } };
主にアプリケーション ファイル (app.js) を使用して、データベース接続を初期化し、アプリケーションを起動します。
var mongoUtil = require('mongoUtil'); mongoUtil.connectToServer(function(err, client) { if (err) console.log(err); // start the rest of your app here });
データベース アクセスが必要な他のモジュールでは、mongoUtil.getDatabase() を使用します。方法:
var mongoUtil = require('mongoUtil'); var db = mongoUtil.getDatabase(); db.collection('users').find();
利点:
以上が再利用性とパフォーマンスのために Node.js で MongoDB 接続管理を最適化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。