nodejsはrpcを実装します

PHPz
PHPzオリジナル
2023-05-18 09:21:371294ブラウズ

インターネット技術の継続的な発展に伴い、分散アーキテクチャが現代のインターネット アプリケーションの基盤になりました。分散システムでは、リモート プロシージャ コール (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 サーバーを実装しています。 addsub という 2 つの API を定義し、それぞれ加算演算と減算演算を実装します。 jsonrpc.Server.$create() を使用してサーバーを作成し、add メソッドと sub メソッドを定義し、listen()# を渡しました。 ##このメソッドはポート 8000 をリッスンし、クライアント要求を待ちます。

3. クライアント コードの作成

サーバー側コードの作成後、サーバーにリクエストを送信し、応答結果を取得できるクライアント コードを作成する必要があります。

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);
});

上記のコードは、単純な Node.js クライアントを実装し、

Client.$create() メソッドを通じてクライアントを作成します。 call() メソッドを使用して、サーバーに add リクエストと sub リクエストをそれぞれ発行し、コールバック関数を使用して応答結果を取得し、出力を出力します。 。

4. テスト プログラム

上記の 2 つのコード スニペットをserver.js および client.js ファイルとして保存し、次のコマンドを実行してサーバーとクライアントを起動します:

node server.js

次に、新しいコマンド ラインで次のコマンドを実行します。

node client.js

出力結果は、加算と減算の計算にそれぞれ対応する 3 と 2 になるはずです。

3. 概要

この記事では、Node.js を使用して RPC 呼び出しを実装する方法を紹介し、開発者が分散アプリケーションをより迅速かつ簡単に構築できるようにします。実際の開発プロセスでは、アプリケーション層とプロトコル層の分離、APIインターフェースの抽象化、サービスの信頼性と安定性の確保に注意する必要があります。さらに、RPC 呼び出しの安全性と信頼性を確保するために、認証や通信の暗号化などの RPC セキュリティの問題も考慮する必要があります。

以上がnodejsはrpcを実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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