How to deploy golang grpc

PHPz
Lepaskan: 2023-04-04 17:23:00
asal
660 orang telah melayarinya

Dalam beberapa tahun kebelakangan ini, bahasa golang telah digemari oleh semakin ramai pembangun, dan ciri ringan serta tinggi konkurensinya digunakan secara meluas dalam perkhidmatan bahagian belakang beberapa perusahaan besar. Dengan populariti perkhidmatan mikro dan teknologi asli awan, golang semakin digunakan dalam medan pelayan, dan rangka kerja rpc golang grpc juga telah digunakan secara meluas.

Artikel ini terutamanya memperkenalkan penggunaan grpc Sebelum penggunaan, anda perlu memahami konsep asas golang dan grpc.

1. Konsep asas golang

Golang ialah bahasa pengaturcaraan yang ditaip secara statik, disusun dan serentak, yang dilahirkan daripada Google. Terdapat beberapa konsep khusus dalam bahasa golang yang perlu difahami.

  1. goroutine: benang ringan dalam golang dan cara utama untuk mencapai keselarasan tinggi.
  2. Saluran: Jenis data khas dalam golang, digunakan untuk komunikasi antara goroutine.
  3. pilih: kata kunci untuk pemultipleksan saluran dalam golang.
  4. tunda: kata kunci yang digunakan untuk menangguhkan pelaksanaan fungsi dalam golang.
  5. antara muka: Satu cara untuk menentukan tingkah laku dalam golang.

2. Konsep asas grpc

grpc ialah rangka kerja RPC sumber terbuka dan berprestasi tinggi, dibangunkan dan sumber terbuka oleh Google. grpc menyokong berbilang bahasa, termasuk golang, C++, Java, dll. Ciri-ciri grpc ialah:

  1. Menyokong berbilang protokol siri, termasuk protobuf dan json.
  2. Berdasarkan protokol http2, ia menyokong ciri lanjutan seperti penstriman dua arah, kawalan aliran dan pemampatan pengepala.
  3. Menyokong pengesahan tersuai, pengimbangan beban dan sambungan lain.

3. Penggunaan grpc

Selepas mempunyai konsep asas, mari perkenalkan penggunaan grpc.

  1. Tulis kod pelayan grpc

Andaikan kita ingin menulis program pelayan grpc yang mudah, kodnya adalah seperti berikut:

package main

import (
    "context"
    "fmt"
    "log"
    "net"

    "google.golang.org/grpc"
    pb "path/to/your/proto"
)

const (
    port = ":50051"
)

type server struct{}

func (s *server) SayHello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloReply, error) {
    log.Printf("Received: %v", in.Name)
    return &pb.HelloReply{Message: "Hello " + in.Name}, nil
}

func main() {
    lis, err := net.Listen("tcp", port)
    if err != nil {
        log.Fatalf("failed to listen: %v", err)
    }
    s := grpc.NewServer()
    pb.RegisterGreeterServer(s, &server{})
    if err := s.Serve(lis); err != nil {
        log.Fatalf("failed to serve: %v", err)
    }
}
Salin selepas log masuk
  1. Menulis kod klien grpc

Katakan kita ingin menulis program klien grpc yang mudah, kodnya adalah seperti berikut:

package main

import (
    "context"
    "log"
    "os"
    "time"

    "google.golang.org/grpc"
    pb "path/to/your/proto"
)

const (
    address     = "localhost:50051"
    defaultName = "world"
)

func main() {
    conn, err := grpc.Dial(address, grpc.WithInsecure(), grpc.WithBlock())
    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]
    }
    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)
}
Salin selepas log masuk
  1. Kompil dan jana fail binari

Arahan kompilasi adalah seperti berikut:

$ go build -o greeter_server ./server/main.go
$ go build -o greeter_client ./client/main.go
Salin selepas log masuk
  1. Jalankan program pelayan grpc
$ ./greeter_server
Salin selepas log masuk

Selepas berjalan, anda akan melihat output berikut:

2021/05/07 10:37:30 Listening on :50051
Salin selepas log masuk
  1. Jalankan program klien grpc
$ ./greeter_client
Salin selepas log masuk

Selepas dijalankan, anda akan melihat output berikut:

2021/05/07 10:38:28 Greeting: Hello world
Salin selepas log masuk

Antaranya, dunia ialah parameter lalai, atau anda boleh Lulus dalam parameter lain, seperti:

$ ./greeter_client Tim
Salin selepas log masuk

Selepas berjalan, anda akan melihat output berikut:

2021/05/07 10:39:22 Greeting: Hello Tim
Salin selepas log masuk

4. Ringkasan

Artikel ini terutamanya memperkenalkan penggunaan grpc Ini termasuk menulis program pelayan grpc, menulis program klien grpc, menyusun dan menjana fail binari, dan menjalankan pelayan grpc dan program klien. Jika anda ingin mengetahui lebih lanjut tentang golang dan grpc, anda boleh merujuk kepada dokumen rasmi dan bahan lain yang berkaitan.

Atas ialah kandungan terperinci How to deploy golang grpc. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan