gRPC は、Google によって開発され、オープンソース化された、高性能、多用途のオープンソース RPC フレームワークです。 gRPC は、Golang を含む複数のプログラミング言語をサポートしています。この記事ではgRPC Golangの使い方を紹介します。
1. gRPC のインストール
gRPC Golang を開発する前に、まず gRPC をインストールする必要があります。次のコマンドでインストールできます:
go get -u google.golang.org/grpc
インストールが完了したら、gRPC の Go 言語コード ジェネレーター protoc-gen-go もインストールする必要があります。これは次のコマンドでインストールできます:
go get -u github.com/golang/protobuf/protoc-gen-go
2. .proto ファイルの作成
gRPC Golang を開発に使用する前に、まず .proto ファイルを定義する必要があります。 .proto ファイルは、サービス インターフェイスとメッセージ形式を定義します。以下は、.proto ファイルの例です。
syntax = "proto3"; package helloworld; service Greeter { rpc SayHello (HelloRequest) returns (HelloReply) {} } message HelloRequest { string name = 1; } message HelloReply { string message = 1; }
- syntax は、.proto ファイルで使用される構文バージョンを定義します。
- package は、パッケージ名を定義します。
- serviceサービスを定義します
- rpc はリクエスト入力と戻り出力を含むメソッドを定義します ##message メッセージの形式を定義します
- ##3. Go 言語コードを生成します
.proto 内 ファイルを定義したら、protoc ツールを使用して Go 言語コードを生成する必要があります。次のコマンドで生成できます。
protoc -I helloworld/ helloworld/helloworld.proto --go_out=plugins=grpc:helloworld
生成された Go 言語コードは、指定されたディレクトリ helloworld に保存されます。
4. サーバーの実装
Go 言語コードを生成した後、サービスを実装する必要があります。以下は、SayHello メソッドを実装するサービスの例です。
package main import ( "context" "fmt" "net" "google.golang.org/grpc" pb "github.com/your_username/helloworld" ) const ( port = ":50051" ) type server struct{} func (s *server) SayHello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloReply, error) { return &pb.HelloReply{Message: "Hello " + in.Name}, nil } func main() { lis, err := net.Listen("tcp", port) if err != nil { fmt.Printf("failed to listen: %v", err) return } s := grpc.NewServer() pb.RegisterGreeterServer(s, &server{}) fmt.Printf("server listening at %v", lis.Addr()) if err := s.Serve(lis); err != nil { fmt.Printf("failed to serve: %v", err) } }SayHello メソッドを実装するサーバー構造
- SayHello メソッドは、コンテキスト (ctx) と HelloRequest を受け取ります。オブジェクトを入力として返し、HelloReply オブジェクトとエラーを返します。
- grpc.NewServer() を通じて gRPC サーバーを作成します。
- pb.RegisterGreeterServer を使用してサーバーにサービスを登録します。
- サーバーの起動
- 5. クライアントの実装
package main import ( "context" "log" "os" "time" "google.golang.org/grpc" pb "github.com/your_username/helloworld" ) const ( address = "localhost:50051" defaultName = "world" ) func main() { // Set up a connection to the server. conn, err := grpc.Dial(address, grpc.WithInsecure(), grpc.WithTimeout(10*time.Second)) if err != nil { log.Fatalf("did not connect: %v", err) } defer conn.Close() c := pb.NewGreeterClient(conn) // Contact the server and print out its response. name := defaultName if len(os.Args) > 1 { name = os.Args[1] } ctx, cancel := context.WithTimeout(context.Background(), time.Second) defer cancel() r, err := c.SayHello(ctx, &pb.HelloRequest{Name: name}) if err != nil { log.Fatalf("could not greet: %v", err) } log.Printf("Greeting: %s", r.Message) }
grpc.Dial メソッドを使用して接続を作成します
#GreeterClient オブジェクトを作成します c- c. SayHello メソッド リクエスト サービスを使用します
- サービス レスポンスを印刷します
- 6. プログラムをコンパイルして実行します
- 次のコマンドを使用して、サーバー プログラムとクライアント プログラムをコンパイルします。 :
go build -o server ./server/main.go go build -o client ./client/main.go
サーバー プログラムを実行する:
./server
クライアント プログラムを実行する:
./client
7. まとめ
この記事では、gRPC Golang の使用方法を紹介します。これには、gRPC と protoc-gen-go のインストールが含まれ、.proto ファイルの作成、Go 言語コードの生成、サーバーとクライアントの実装、そして最後にプログラムのコンパイルと実行が行われます。 gRPC Golang は、分散システム内のサービス間の通信に使用できる、高性能で汎用性の高い RPC フレームワークを提供します。
以上がgRPC Golangの使い方を紹介した記事の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

Golangは実際のアプリケーションに優れており、そのシンプルさ、効率性、並行性で知られています。 1)同時プログラミングはゴルチンとチャネルを通じて実装されます。2)柔軟なコードは、インターフェイスと多型を使用して記述されます。3)ネット/HTTPパッケージを使用したネットワークプログラミングを簡素化、4)効率的な同時クローラーを構築する、5)ツールと最高の実践を通じてデバッグと最適化。

GOのコア機能には、ガベージコレクション、静的リンク、並行性サポートが含まれます。 1. GO言語の並行性モデルは、GoroutineとChannelを通じて効率的な同時プログラミングを実現します。 2.インターフェイスと多型は、インターフェイスメソッドを介して実装されているため、異なるタイプを統一された方法で処理できます。 3.基本的な使用法は、関数定義と呼び出しの効率を示しています。 4。高度な使用法では、スライスは動的なサイズ変更の強力な機能を提供します。 5.人種条件などの一般的なエラーは、Getest Raceを通じて検出および解決できます。 6.パフォーマンス最適化Sync.Poolを通じてオブジェクトを再利用して、ゴミ収集圧力を軽減します。

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

SQLクエリの結果の並べ替えについて混乱しています。 SQLを学習する過程で、しばしば混乱する問題に遭遇します。最近、著者は「Mick-SQL Basics」を読んでいます...

テクノロジースタックの収束とテクノロジーの選択の関係ソフトウェア開発におけるテクノロジーの選択、テクノロジースタックの選択と管理は非常に重要な問題です。最近、一部の読者が提案しています...

ゴーラン...

GO言語で3つの構造を比較および処理する方法。 GOプログラミングでは、2つの構造の違いを比較し、これらの違いを...


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

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