Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Cara memasang gRPC di golang

Cara memasang gRPC di golang

PHPz
PHPzasal
2023-04-05 13:47:22732semak imbas

Dalam beberapa tahun kebelakangan ini, dengan perkembangan pesat pengkomputeran awan dan data besar, semakin banyak perusahaan telah mula menggunakan seni bina perkhidmatan mikro untuk membina aplikasi. gRPC ialah rangka kerja RPC yang cekap dan moden yang digunakan secara meluas untuk komunikasi antara perkhidmatan mikro. Dalam artikel ini, kami akan memperkenalkan cara memasang gRPC dalam golang supaya anda boleh menggunakan rangka kerja komunikasi ini dengan lebih mudah.

  1. Pertama, anda perlu memasang persekitaran golang. Anda boleh memuat turun pakej pemasangan yang sesuai untuk sistem pengendalian anda dari laman web rasmi https://golang.org/dl/ Selepas pemasangan selesai, gunakan arahan berikut untuk menyemak sama ada pemasangan berjaya:
.
go version

Jika maklumat Versi yang dikembalikan serupa dengan "go version go1.14.4 darwin/amd64" bermakna pemasangan berjaya.

  1. Muat turun dan pasang pakej pergantungan. gRPC memerlukan penggunaan beberapa perpustakaan pergantungan Di sini kami menggunakan alat pengurusan pakej golang untuk memuat turun dan mengurus pakej pergantungan yang diperlukan secara automatik. Dalam mana-mana direktori kosong, laksanakan arahan berikut:
go mod init example.com/hello
go get google.golang.org/grpc

Antaranya, "example.com/hello" boleh digantikan dengan mana-mana nama yang anda suka, ia hanyalah contoh.

  1. Tulis perkhidmatan gRPC. Selepas memasang gRPC, anda boleh mula menulis perkhidmatan anda sendiri. Katakan kita ingin menulis perkhidmatan penyambut tetamu untuk menyambut pelanggan. Cipta dua fail greeter.pb.go dan greeter.grpc.go dalam direktori akar projek Arahan adalah seperti berikut:
$ touch greeter.proto
$ protoc --go_out=. --go-grpc_out=. greeter.proto

Tulis fail greeter.proto untuk menerangkan definisi bagi Perkhidmatan gRPC:

syntax = "proto3";

package helloworld;

// 定义服务接口
service Greeter {
  rpc SayHello (HelloRequest) returns (HelloReply) {}
}

// 定义请求和响应结构体
message HelloRequest {
  string name = 1;
}

message HelloReply {
  string message = 1;
}

Kompilasi fail protok dan jana fail perkhidmatan greeter.pb.go dan greeter.grpc.go yang sepadan. Perlu diingat bahawa apabila menyusun dengan protoc, kami menambah dua parameter --go_out dan --go-grpc_out untuk menjana fail pb dan grpc yang sepadan.

  1. Tulis klien gRPC. Seterusnya, kami perlu menulis kod pelanggan untuk memanggil perkhidmatan yang kami tentukan. Cipta fail greetercli.go dalam projek dan tulis kod berikut:
package main

import (
    "context"
    "log"

    "google.golang.org/grpc"
    pb "example.com/hello" // 这里是我们定义的服务包名

)

const (
    address     = "localhost:50051" // 服务端地址
    defaultName = "world"
)

func main() {
    // 和服务端建立连接
    conn, err := grpc.Dial(address, grpc.WithInsecure())
    if err != nil {
        log.Fatalf("did not connect: %v", err)
    }
    defer conn.Close()

    // 创建客户端
    c := pb.NewGreeterClient(conn)

    // 调用服务方法
    name := defaultName
    if len(os.Args) > 1 {
        name = os.Args[1]
    }
    r, err := c.SayHello(context.Background(), &pb.HelloRequest{Name: name}
    if err != nil {
        log.Fatalf("could not greet: %v", err)
    }
    log.Printf("Greeting: %s", r.Message)
}

Dalam ulasan kod, kami telah menerangkannya dengan jelas, jadi kami tidak akan mengulanginya di sini.

  1. Jalankan perkhidmatan gRPC.

Sekarang kami telah melengkapkan kod pelayan dan pelanggan, mari jalankan perkhidmatan kami dan lihat!

Laksanakan arahan berikut dalam direktori yang sama seperti greetercli.go:

$ go run greetersrv.go

Jika tiada output, ini bermakna perkhidmatan gRPC telah berjaya dimulakan secara setempat. Seterusnya, jalankan klien dalam tetingkap terminal baharu:

$ go run greetercli.go
Greeting: Hello world

Output di sini boleh dilaraskan mengikut parameter input yang anda tentukan.

Setakat ini, kandungan dalam artikel ini pada asasnya merangkumi keseluruhan proses pemasangan gRPC dalam golang. Sudah tentu, untuk kajian mendalam tentang perkhidmatan gRPC, kami masih perlu menguasai lebih banyak butiran dan spesifikasi, serta sentiasa menambah baik dan mengembangkan sistem pengetahuan kami.

Atas ialah kandungan terperinci Cara memasang gRPC di golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn