ホームページ バックエンド開発 Golang golangでrpcを実装する方法

golangでrpcを実装する方法

Apr 25, 2023 am 10:44 AM

近年、インターネットの急速な発展に伴い、分散システムがますます注目を集めています。 RPC (リモート プロシージャ コール) テクノロジは、分散システムの主要なテクノロジであり、異なるシステムが相互に通信し、連携できるようにします。さまざまな言語の中でも、ほとんどの言語には独自の RPC フレームワークがあります。この記事では、システムが快適に連携できるように、Golang を使用して RPC を実装する方法を紹介します。

1. RPC の基本概念

1.1.

RPC とはリモート プロシージャ コール (Remote Procedure Call) であり、クライアントがローカルでリモート サービスを呼び出すことを意味します。 , ネイティブコードを呼び出すのと同じように、ネイティブコードを呼び出すのと同じようにパラメータを渡したり戻り値を取得したりできます。実際には、ネットワーク通信プロセスをローカル呼び出しと同様のパターンに抽象化します。

1.2. 理由

分散システムでは、各ノードが分散され、それぞれが異なるタスクやビジネス サービスを引き受けます。これらのノードが連携して動作するには、ネットワーク経由で通信する必要があります。 RPC を使用すると、これらのノードがネットワーク経由でデータを交換し、ビジネス ロジックの実行を実装できるようになります。

1.3. 機能

RPC の中心原理は、ネットワーク通信プロセスをローカル呼び出しプロセスに抽象化することであり、クライアントはパラメータをローカルでリモート サービスに渡し、サーバーはパラメータを処理します。そして処理結果をクライアントに返却します。これにより、分散システム内のさまざまなノードが相互に連携して、分散システムのさまざまなタスクを完了できるようになります。 RPC の特徴は次のとおりです。

  • 抽象化: ネットワーク通信プロセスがローカル呼び出しプロセスに抽象化されるため、RPC フレームワークを使用する開発者はローカル サービスと同様にリモート サービスを使用できます。
  • 透過的: RPC は、ほとんどの通信関連の詳細をユーザーに対して保護し、開発者がビジネス ロジックに集中できるようにします。
  • 効率的: RPC はバイナリを使用してデータを送信するため、シリアル化と逆シリアル化の効率が高く、転送速度が速く、ネットワーク帯域幅が狭い場合でも大量のデータを送信できます。

2. Golang で RPC を実装するための基本手順

2.1. インターフェイスの定義

Golang では、まず公開するインターフェイスを定義する必要があります。インターフェースは、リモート呼び出しの関数プロトタイプに相当します。

type Server struct {}

type Args struct {
    A, B int
}

func (s *Server) Multiply(args *Args, reply *int) error {
    *reply = args.A * args.B
    return nil
}
ログイン後にコピー

コードでは、Server 構造体と Args 構造体が定義されています。Server 構造体は Multiply 関数を定義しています。Multiply 関数は、2 つの整数の積を計算するために使用されます。 Multiply 関数のパラメータと戻り値は RPC 仕様を満たす必要があることに注意してください。

2.2. RPC サービスの登録

インターフェースを定義した後、クライアントが RPC サービスを呼び出せるように、インターフェースを RPC サービスに登録する必要があります。サービスを RPC サーバーに登録するには、Golang の rpc.Serve() 関数を使用する必要があります。

func main() {
    server := new(Server)
    rpc.Register(server)
    rpc.HandleHTTP()

    listener, err := net.Listen("tcp", ":8080")
    if err != nil {
        log.Fatal("listen error:", err)
    }

    http.Serve(listener, nil)
}
ログイン後にコピー

上記のコードでは、最初に Server 構造を作成し、次に rpc.Register 関数を通じて Server 構造に定義されたインターフェイスを RPC サーバーに登録し、次に rpc.HandleHTTP() を使用して RPC にアクセスします。サーバーは http パッケージ内のデフォルト マルチプレクサにバインドされ、最後に RPC サーバーは http.Serve を通じて TCP リスニング アドレスにバインドされます。

2.3. クライアント コードを記述する

RPC サービスの登録が完了したら、RPC サービスを呼び出すためのクライアント コードを記述する必要があります。 Golang の rpc パッケージは、RPC クライアント接続の確立に使用できる rpc.DialHTTP 関数を提供します。以下は、単純な RPC クライアントの実装です。

func main() {
    client, err := rpc.DialHTTP("tcp", "localhost:8080")
    if err != nil {
        log.Fatal("dialing:", err)
    }

    args := &Args{7, 8}
    var reply int
    err = client.Call("Server.Multiply", args, &reply)
    if err != nil {
        log.Fatal("Server error:", err)
    }

    fmt.Printf("Multiply: %d*%d=%d", args.A, args.B, reply)
}
ログイン後にコピー

クライアントは、rpc.DialHTTP 関数を通じて RPC サーバーとの接続を確立し、client.Call メソッドを呼び出して RPC サーバー関数を実行します。 Call の最初のパラメータは呼び出される関数の名前、2 番目のパラメータは関数のパラメータ、3 番目のパラメータは関数の戻り値です。

3. Golang RPC サンプル コード

以下は、Golang に基づいた RPC 実装の完全な例です:

package main

import (
    "fmt"
    "log"
    "net"
    "net/http"
    "net/rpc"
)

type Server struct{}

type Args struct {
    A, B int
}

func (s *Server) Multiply(args *Args, reply *int) error {
    *reply = args.A * args.B
    return nil
}

func main() {
    server := new(Server)
    rpc.Register(server)
    rpc.HandleHTTP()

    listener, err := net.Listen("tcp", ":8080")
    if err != nil {
        log.Fatal("listen error:", err)
    }

    go http.Serve(listener, nil)

    client, err := rpc.DialHTTP("tcp", "localhost:8080")
    if err != nil {
        log.Fatal("dialing:", err)
    }

    args := &Args{7, 8}
    var reply int
    err = client.Call("Server.Multiply", args, &reply)
    if err != nil {
        log.Fatal("Server error:", err)
    }

    fmt.Printf("Multiply: %d*%d=%d", args.A, args.B, reply)
}
ログイン後にコピー

上記のコードを通して、Golang でのことがわかります。 , RPC の実装は非常に簡単です。インターフェイスを定義し、RPC サービスを登録し、クライアント コードを記述するだけで済みます。もちろん、RPC クライアントとサーバーの両方を異種混合にすることができ、これは分散システムを拡張するときに非常に役立ちます。

4. 概要

この記事では、RPC とは何か、RPC が必要な理由、および Golang を使用して RPC を実装する方法を紹介します。この記事を読むと、RPC が分散システムの基礎技術として広く使われていることがわかります。 Golang は効率的なプログラミング言語として、開発者が分散システムをより適切に実装するのに役立つ優れた RPC フレームワークを備えています。分散システムを開発する必要がある場合は、Golang を使用して RPC を実装してみるのもよいでしょう。

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

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

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Golangの目的:効率的でスケーラブルなシステムの構築 Golangの目的:効率的でスケーラブルなシステムの構築 Apr 09, 2025 pm 05:17 PM

GO言語は、効率的でスケーラブルなシステムの構築においてうまく機能します。その利点には次のものがあります。1。高性能:マシンコードにコンパイルされ、速度速度が速い。 2。同時プログラミング:ゴルチンとチャネルを介してマルチタスクを簡素化します。 3。シンプルさ:簡潔な構文、学習コストとメンテナンスコストの削減。 4。クロスプラットフォーム:クロスプラットフォームのコンパイル、簡単な展開をサポートします。

Golang and C:Concurrency vs. Raw Speed Golang and C:Concurrency vs. Raw Speed Apr 21, 2025 am 12:16 AM

Golangは並行性がCよりも優れていますが、Cは生の速度ではGolangよりも優れています。 1)Golangは、GoroutineとChannelを通じて効率的な並行性を達成します。これは、多数の同時タスクの処理に適しています。 2)Cコンパイラの最適化と標準ライブラリを介して、極端な最適化を必要とするアプリケーションに適したハードウェアに近い高性能を提供します。

Golang vs. Python:重要な違​​いと類似点 Golang vs. Python:重要な違​​いと類似点 Apr 17, 2025 am 12:15 AM

GolangとPythonにはそれぞれ独自の利点があります。Golangは高性能と同時プログラミングに適していますが、PythonはデータサイエンスとWeb開発に適しています。 Golangは同時性モデルと効率的なパフォーマンスで知られていますが、Pythonは簡潔な構文とリッチライブラリエコシステムで知られています。

Golang vs. Python:パフォーマンスとスケーラビリティ Golang vs. Python:パフォーマンスとスケーラビリティ Apr 19, 2025 am 12:18 AM

Golangは、パフォーマンスとスケーラビリティの点でPythonよりも優れています。 1)Golangのコンピレーションタイプの特性と効率的な並行性モデルにより、高い並行性シナリオでうまく機能します。 2)Pythonは解釈された言語として、ゆっくりと実行されますが、Cythonなどのツールを介してパフォーマンスを最適化できます。

Golangの影響:速度、効率、シンプルさ Golangの影響:速度、効率、シンプルさ Apr 14, 2025 am 12:11 AM

speed、効率、およびシンプル性をspeedsped.1)speed:gocompilesquilesquicklyandrunseffictient、理想的なlargeprojects.2)効率:等系dribribraryreducesexexternaldedenciess、開発効果を高める3)シンプルさ:

パフォーマンスレース:ゴラン対c パフォーマンスレース:ゴラン対c Apr 16, 2025 am 12:07 AM

GolangとCにはそれぞれパフォーマンス競争において独自の利点があります。1)Golangは、高い並行性と迅速な発展に適しており、2)Cはより高いパフォーマンスと微細な制御を提供します。選択は、プロジェクトの要件とチームテクノロジースタックに基づいている必要があります。

CとGolang:パフォーマンスが重要な場合 CとGolang:パフォーマンスが重要な場合 Apr 13, 2025 am 12:11 AM

Cは、ハードウェアリソースと高性能の最適化が必要なシナリオにより適していますが、Golangは迅速な開発と高い並行性処理が必要なシナリオにより適しています。 1.Cの利点は、ハードウェア特性と高い最適化機能に近いものにあります。これは、ゲーム開発などの高性能ニーズに適しています。 2.Golangの利点は、その簡潔な構文と自然な並行性サポートにあり、これは高い並行性サービス開発に適しています。

GolangとC:パフォーマンスのトレードオフ GolangとC:パフォーマンスのトレードオフ Apr 17, 2025 am 12:18 AM

GolangとCのパフォーマンスの違いは、主にメモリ管理、コンピレーションの最適化、ランタイム効率に反映されています。 1)Golangのゴミ収集メカニズムは便利ですが、パフォーマンスに影響を与える可能性があります。

See all articles