登录
首页 >  Golang >  Go问答

如何在套接字net.conn上构建grpc服务器?

来源:stackoverflow

时间:2024-02-10 19:00:21 204浏览 收藏

有志者,事竟成!如果你在学习Golang,那么本文《如何在套接字net.conn上构建grpc服务器?》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~

问题内容

go中的典型用法是:

    server := grpc.newserver()
    
    pb.registeruserserver(server, &usersrvc.userserver{})

    addr := ":" + env.getmyrpcport()

    lis, _ := net.listen("tcp", addr)

    server.serve(lis)

我想知道我是否可以在连接的 conn 上运行服务器,例如:

conn, _ := net.Dial("tcp",":8080")
server.Serve(conn)

客户端先连接到服务器,然后在连接的net.conn上构造一个grpc服务器,然后服务器可以rpc调用客户端,将一些消息作为请求推送给客户端。


正确答案


我认为您需要 bidirectional streaming。 以下是在 go 中使用双向 grpc 的一个详细示例:https://github.com/pahanini/go-grpc-bidirectional-streaming-example

conn, err := grpc.Dial(":50005", grpc.WithInsecure())
...
client := pb.NewMathClient(conn)
stream, err := client.Max(context.Background())
...
req := pb.Request{Num: rnd}
err := stream.Send(&req)

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>