grpc中的api是如何实现的?

首页 编程分享 PHP丨JAVA丨OTHER 正文

王林 转载 编程分享 2024-02-16 21:27:36

简介 我使用了官方文档https://grpc.io/docs/languages/go/basics/,但是实现后,出现了问题。当我创建tcp服务器时,我必须指定主机和端口(在我的例子中为mcrsrv-book:7561)。但是如果我想为grpc实现另一个api该怎么办?我是否需要在新端口上启动另一台服务器(例如mcrsrv-book:7562)?grpc中的路由和api是如何实现的?我的服务器代码是:typerouteGuideServerstruct{pb.Un


在php小编鱼仔的帮助下,我们来探究一下grpc中的api是如何实现的。gRPC是一个高性能、开源的远程过程调用(RPC)框架,它使用了Google的Protocol Buffers作为接口描述语言,并支持多种编程语言。gRPC的核心机制是基于HTTP/2协议,通过序列化和反序列化消息来实现客户端和服务器之间的通信。在本文中,我们将深入了解gRPC的工作原理、消息传递方式以及如何使用它来构建强大的分布式应用程序。让我们开始吧!

问题内容

我使用了官方文档https://grpc.io/docs/languages/go/basics/,但是实现后,出现了问题。 当我创建 tcp 服务器时,我必须指定主机和端口(在我的例子中为 mcrsrv-book:7561)。 但是如果我想为 grpc 实现另一个 api 该怎么办?我是否需要在新端口上启动另一台服务器(例如 mcrsrv-book:7562)? grpc中的路由和api是如何实现的?

我的服务器代码是:

type routeGuideServer struct {
    pb.UnimplementedRouteGuideServer
    savedFeatures []*pb.Response // read-only after initialized
}

// GetFeature returns the feature at the given point.
func (s *routeGuideServer) GetFeature(ctx context.Context, request *pb.Request) (*pb.Response, error) {

    context := localContext.LocalContext{}
    book := bookRepository.FindOrFailBook(context, int(request.BookId))

    return &pb.Response{
        Name:        book.Name,
        BookId:      int32(book.BookId),
        AuthorId:    int32(book.AuthorId),
        Category:    book.Category,
        Description: "Описание",
    }, nil
}

func newServer() *routeGuideServer {
    s := &routeGuideServer{}
    return s
}

func SomeAction() {
    lis, err := net.Listen("tcp", fmt.Sprintf("mcrsrv-book:7561"))
    if err != nil {
        log.Fatalf("failed to listen: %v", err)
    }
    var opts []grpc.ServerOption
    grpcServer := grpc.NewServer(opts...)
    pb.RegisterRouteGuideServer(grpcServer, newServer())
    grpcServer.Serve(lis)
}

我认为除了为每个 grpc 服务打开单独的端口之外,还应该有其他选择。

grpc中的api是如何实现的?

解决方法

如果您想将同一地址用于不同的服务,只需在启动 grpc 服务器之前重新注册其他服务即可。

grpcServer := grpc.NewServer(opts...)
pb.RegisterRouteGuideServer(grpcServer, newServer())

#register other server here with the same 'grpcServer'

grpcServer.Serve(lis)

这个 stackoverflow 线程可能会帮助您作为您想要实现的目标的示例。该问题提供了一个示例代码,我认为该代码与您的要求相符。

通过同一连接访问多个 grpc 服务

以上就是grpc中的api是如何实现的?的详细内容,更多请关注php中文网其它相关文章!

转载链接:https://www.php.cn/faq/678802.html


Tags:


本篇评论 —— 揽流光,涤眉霜,清露烈酒一口话苍茫。


    声明:参照站内规则,不文明言论将会删除,谢谢合作。


      最新评论




ABOUT ME

Blogger:袅袅牧童 | Arkin

Ido:PHP攻城狮

WeChat:nnmutong

Email:nnmutong@icloud.com

标签云