monorepo は、さまざまなチームが使用できる複数の関連サービス、プロジェクト、コンポーネントを含む単一の リポジトリです It 関連または無関係のプロジェクトのコードを保存します。 モノリポという言葉は、単一を意味する mono とリポジトリの略語である repo に由来しています。
Monorepo の主な利点の一部を次に示します。モノリポジトリの使用:
各ツールには特定の利点と機能があるため、選択はプロジェクトの要件と好みによって異なります。
Lerna は、複数の npm パッケージを含むリポジトリを管理するために設計されたツールです。 これにより、単一の git リポジトリ内の複数のパッケージ リポジトリ間での依存関係の処理、パッケージ の公開および公開のプロセスが簡素化されます。 Lerna は、同じリポジトリ内の異なる npm パッケージを開発する開発者間での効率的なコード共有とコラボレーションを可能にするため、モノリポジトリに特に役立ちます。 開発者が複数のパッケージを含むプロジェクトを 1 つのエンティティとして扱うことができるため、開発ライフサイクル管理が向上します。
npm -v
。
#バックエンド サーバーで使用される支払いサービスを含む単一のリポジトリを作成しています。 さらに、バックエンド サーバーと決済サービスはログ サービスを共有します。
次に、Lerna を使用した Monorepo の実装について詳しく見ていきましょう。
プロジェクトのルート ディレクトリに移動し、Lerna を初期化します:
mkdir monorepo # create a repo directory of the monorepo cd monorepo npx lerna@latest init # initalize the repo
上記の npx
コマンドは、Lerna が管理する新しいリポジトリを作成します。 lerna.json
: 構成ファイルには、バージョン管理モード、パッケージの場所など、Lerna の動作の設定が含まれています。 #package.json
git config user.name ${username} git config user.email ${email}
ステップ 2: バックエンド パッケージの生成
パッケージを作成するための Lerna コマンド:
npx lerna create #{packageName} #{directory}here 、ディレクトリはデフォルトです:
上面的命令,不带 运行后,包后端将如下所示: 再次执行相同的过程,但指定要创建的服务的目录,因为我们希望包位于该 ルート Main package.json ## 在该目录中,通过简单的配置使用 Bunyan 库 在日志服务中安装 Buyan 库,并将 Mocha 作为开发依赖项安装在根目录中,以测试所有服务。 替换日志功能文件的内容 支払いサービスには、 services/payment 我们将使用基本的 GET API 配置服务器,该 API 利用记录器和支付服务。此设置将有助于付款和记录相应的活动。
バックエンド サーバー、支払いサービス、ログを作成するロギング サービスのモノリポジトリは、統合開発アプローチの利点を強調しています。 この設定では、関連コンポーネントを 1 つのリポジトリに統合することで、効率的なコード管理と共有が促進されます。 ロギング サービスを決済サービスとバックエンド サーバーに統合すると、コードの再利用性とサービス間での一貫したロギングの実践の力が実証されます。 #モノリポジトリ アーキテクチャを採用すると、組織化された共同開発環境が実現します。 モジュール化により開発が簡素化され、効率が向上し、長期的なメンテナンスが可能になります。 これは、透過的な通信、コードの再利用性、効果的なテストを備えた、複雑なアプリケーションの強固な基盤を提供します。 以上がLerna を使って Monorepo を簡単に構築してみましょうの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。npx lerna create back-end
//or
//this will skip the questionnaire related to package
npx lerna create back-end -y
-y
会提示你各种问题,比如覆盖包名、添加描述等等。但是,这些详细信息对于本示例来说并不重要,因此请按“Enter”键。步骤3:生成支付和日志服务包
"services/"
目录中。package.json
ファイルで、ディレクトリ services/
にあるパッケージについて Lerna に伝える必要もあります。 ###。 package.jsonワークスペース構成を編集し、"services/*"
に追加しますそれ。 構成は次のようになります。
##ルート レベル # ファイルを作成するには、services/ ディレクトリ内のパッケージについて Lerna に通知する必要があります。 ワークスペース構成を変更しますpackage.json
を追加し、
"services/*" を含めます。 設定は次のようになります:
npx lerna create payment services -y
npx lerna create logging services -y
第 4 步:设置日志服务
services/logging
设置日志记录服务。// root folder install test dependencies
npm install mocha --save-dev
//inside logging
cd services/logging
npm install bunyan
services/logging/lib/logging.js
const bunyan = require('bunyan');
const logger = bunyan.createLogger({
name: 'my-logging-service',
level: 'info',
});
module.exports = logger;
services/logging/__tests__/logging.test.js
const loggingService = require('../lib/logging'); // Import the logging service
describe('Logging Service', () => {
it('should log messages', () => {
loggingService.info('Test log message');
});
});
"test": "mocha ./__tests__/logging.test.js"
npx lerna run test --scope="logging"
ステップ 5: 支払いサービスを設定する
makePayment# という関数があります。
## は、単一のパラメーターを量として受け入れ、ロガー サービスを利用してアクティビティを記録します。 ディレクトリで、簡単な関数を使用して支払いサービスを設定します。
npm i
在services/payment
目录中运行进行安装。"scripts": {
"test": "mocha ./__tests__/payment.test.js"
},
"dependencies": {
"logging": "file:../logging"
}
package.json
应该如图片所示services/payment/lib/payment.js
const loggingService = require('logging');
const paymentService = {
makePayment: (amount) => {
loggingService.info('Payment processing initiated');
// Implement payment logic here
loggingService.info('Payment processed successfully');
return `Payment of ${amount} processed successfully`;
},
};
module.exports = paymentService;
makePayment
支付服务功能测试用例。services/payment/__tests__/payment.test.js
const chai = require('chai');
const paymentService = require('../lib/payment'); // Import the payment service
const expect = chai.expect;
describe('Payment Service', () => {
it('should make a payment successfully', () => {
const paymentResult = paymentService.makePayment(100);
expect(paymentResult).to.equal('Payment of 100 processed successfully');
});
});
npx lerna run test --scope="payment"
第 6 步:设置后端服务器
//from root
cd packages/back-end
npm install express
packages/back-end/lib/back-end.js
package.json
of的依赖项中添加以下代码片段packages/back-end
"logging": "file:../services/logging",
"payment": "file:../services/payment"
"scripts": {
"start": "node ./lib/back-end.js",
"test": "mocha ./__tests__/back-end.test.js --exit"
}
package.json
应该如所附图片所示npm update
。packages/back-end/lib/back-end.js
为以下代码:get / API
端口的服务器3000
,并使用日志记录和支付服务。 const express = require('express');
const loggingService = require('logging');
const paymentService = require('payment');
const app = express();
app.get('/', (req, res) => {
// Use of logging service
loggingService.info('Backend server received a request');
// Use the payment service
const paymentResult = paymentService.makePayment(100);
loggingService.info('Payment result:', paymentResult);
res.send('Backend Server: Running!');
});
app.listen(3000, () => {
console.log('Backend server is running on port 3000');
});
chai-http
以对目录上的 API 进行单元测试packages/back-end
。npm i chai-http --save-dev
const chai = require('chai');
const chaiHttp = require('chai-http');
const app = require('../lib/back-end'); // Import the Express app
// using request server as chaiHttp;
chai.use(chaiHttp);
const expect = chai.expect;
describe('Backend Server', () => {
it('should log a request and process payment', (done) => {
chai.request(app)
.get('/')
.end((err, res) => {
expect(res).to.have.status(200);
expect(res.text).to.equal('Backend Server: Running!');
done();
});
});
});
第 7 步:运行应用程序
lerna run start
在根文件夹中执行。这将在端口 3000 上启动服务器。打开浏览器并导航至localhost:3000/
。您将观察到输出“后端服务器:正在运行!” 显示在浏览器中。
lerna run test
、これにより、すべてのマイクロサービスですべてのテストが実行されます。なぜなら、すべてのマイクロサービス #testスクリプト内にコマンドがあります。
結論