Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Inventori rangka kerja RPC bahasa Go: Senarai lima pilihan popular

Inventori rangka kerja RPC bahasa Go: Senarai lima pilihan popular

WBOY
WBOYasal
2024-02-27 13:03:04366semak imbas

Inventori rangka kerja RPC bahasa Go: Senarai lima pilihan popular

Dengan perkembangan teknologi Internet, sistem yang diedarkan semakin digunakan secara meluas, dan Panggilan Prosedur Jauh (RPC), sebagai kaedah komunikasi penting dalam sistem teragih, juga telah mendapat perhatian dan aplikasi yang lebih banyak. Di antara banyak rangka kerja RPC, bahasa Go, sebagai bahasa pengaturcaraan yang pantas dan cekap, juga mempunyai banyak pilihan rangka kerja RPC. Artikel ini akan mengambil kira rangka kerja RPC bahasa Go, memperkenalkan lima pilihan popular dan memberikan contoh kod khusus untuk membantu pembaca lebih memahami dan memilih rangka kerja RPC yang sesuai untuk projek mereka sendiri.

1. gRPC

gRPC ialah rangka kerja RPC sumber terbuka berprestasi tinggi yang dibangunkan oleh Google, berdasarkan protokol HTTP/2 dan protokol bersiri Protocol Buffers (ProtoBuf). gRPC menyediakan ciri berkuasa seperti sokongan silang bahasa, pengesahan, pengimbangan beban, dsb. Berikut ialah contoh pelayan dan pelanggan gRPC yang mudah:

Contoh kod pelayan:

package main

import (
    "context"
    "log"
    "net"

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

type server struct{}

func (s *server) SayHello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloResponse, error) {
    return &pb.HelloResponse{Message: "Hello " + in.Name}, nil
}

func main() {
    lis, err := net.Listen("tcp", ":50051")
    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)
    }
}

Contoh kod pelanggan:

package main

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

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

func main() {
    conn, err := grpc.Dial("localhost:50051", grpc.WithInsecure())
    if err != nil {
        log.Fatalf("did not connect: %v", err)
    }
    defer conn.Close()
    c := pb.NewGreeterClient(conn)

    name := "World"
    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)
}

Atas ialah kandungan terperinci Inventori rangka kerja RPC bahasa Go: Senarai lima pilihan popular. 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