インターネット技術の継続的な発展に伴い、分散アーキテクチャが現代のインターネット アプリケーションの基盤になりました。分散システムでは、リモート プロシージャ コール (RPC) プロトコルはコンポーネント間の通信を実現する重要な方法です。この記事では、開発者が分散アプリケーションをより迅速かつ簡単に構築できるように、Node.js を使用して RPC を実装する方法を紹介します。
1. RPCの概要
RPC、正式名称はRemote Procedure Call、つまり遠隔手続き呼び出しを意味します。ネットワーク呼び出しを介して異なるコンピューター間でプログラム呼び出しを実装し、ローカル関数を呼び出すのと同じようにプログラム呼び出しを実行し、基礎となるネットワーク送信の詳細を保護して、開発者がビジネス ロジックの実装に集中できるようにします。
従来の RPC プロトコルは、Thrift、Avro、Protocol Buffer などのバイナリ プロトコルに基づいて実装されています。これらのプロトコルは通常、IDL を使用してインターフェイスを記述し、コード生成ツールを使用して対応するクライアント側コードとサーバー側コードを生成します。これにより、クライアントはローカル関数を呼び出すのと同じくらい簡単にインターフェイスを呼び出すことができます。
Node.js では、JSON-RPC プロトコルを使用して RPC 呼び出しを実装できます。 JSON-RPC は、JSON エンコーディングに基づく軽量で高速なリモート プロシージャ コール プロトコルであり、軽量で言語に依存しないため、Web アプリケーションで広く普及しています。
2. Node.js を使用して RPC を実装する
Node.js では、json-rpc2 ミドルウェアを使用して RPC を実装できます。このミドルウェアは、JSON-RPC 2.0 プロトコルを実装した Node.js モジュールであり、Node.js 環境で JSON-RPC API を簡単に作成および呼び出すことができます。以下では、このミドルウェアを使用して RPC 呼び出しを実装する方法を紹介します。
1. 依存関係のインストール
まず、json-rpc2 依存関係パッケージをインストールする必要があります。コマンド ラインに次のコマンドを入力します:
npm install json-rpc2 --save
2. サーバー側コードの作成
サーバー側コードを作成する必要があります。その機能は、クライアントのリクエストを受け入れ、を要求して対応する操作を実行し、結果をクライアントに返します。
const jsonrpc = require('json-rpc2'); const server = jsonrpc.Server.$create({ 'add': function(params, ret) { ret(null, params[0] + params[1]); }, 'sub': function(params, ret) { ret(null, params[0] - params[1]); }, }); server.listen(8000, 'localhost');
上記のコードは、単純な RPC サーバーを実装しています。 add
と sub
という 2 つの API を定義し、それぞれ加算演算と減算演算を実装します。 jsonrpc.Server.$create()
を使用してサーバーを作成し、add
メソッドと sub
メソッドを定義し、listen()# を渡しました。 ##このメソッドはポート 8000 をリッスンし、クライアント要求を待ちます。
const jsonrpc = require('json-rpc2'); const client = jsonrpc.Client.$create(8000, 'localhost'); client.call('add', [1, 2], function(err, result) { console.log(result); }); client.call('sub', [5, 3], function(err, result) { console.log(result); });
Client.$create() メソッドを通じてクライアントを作成します。
call() メソッドを使用して、サーバーに
add リクエストと
sub リクエストをそれぞれ発行し、コールバック関数を使用して応答結果を取得し、出力を出力します。 。
node server.js
node client.js
以上がnodejsはrpcを実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。