草庐IT

grpc-precompiled-binaries

全部标签

go - 在一个 Go 应用程序中提供 gRPC 和 Restful 服务

我有一个用Go编写的restful应用程序,现在我必须让这个应用程序也充当gRPC服务器(我已经创建了所需的文件)。我在端口8000上运行了restful端点,现在我有下一个问题:我可以在同一个实例中同时使用grpc和restful应用程序吗?我应该分配一个不同的端口来为gRPC服务吗?在这种情况下推荐的方法是什么?因为grpcstub将只是被我们的一些微服务消耗,但其余的将被被一些应用程序的前端消耗如果我可以为两者提供服务,我应该如何初始化服务器? 最佳答案 是的!如果您想将gRPC作为RESTful服务来提供服务,可以使用gRP

go - 如何在 Go 和 gRPC 中构建结构数组?

我正在尝试将字符串数组添加到结构的内容部分,并将Id作为数组索引。我的代码适用于一个元素,但是当我尝试添加循环时出现各种错误。欢迎任何想法。我正在使用Go。funcbuildRequest(s[]string)[]*storepb.LongStoreRequest{//ss:=[]storepb.LongStoreRequest//int32i=0stringv:=s[0]//fori:=0;i 最佳答案 如果我对你的描述理解正确,你想要构建一个LongStoreRequests数组,其中每个元素对应于字符串数组中的一个项目,Id给

go - 如何访问代理的 grpc 服务中的请求 header 。 golang 中的 grpc 网关

我有一个由grpc-gateway代理的grpc服务器。当我对网关端点进行HTTP调用时,会调用相应的grpc服务方法。现在,grpc服务实现接收到一个包含header的上下文。我不知道如何访问header。当我调试我的grpc服务并设置断点时,这是我的服务接收到的Context对象的结构。现在,如何获取任何HTTP请求header的值? 最佳答案 HTTPheader存储在元数据中。md,ok:=metadata.FromIncomingContext(ctx)应该可以获取传入的元数据。

go - binary.Write() 字节排序不适用于 []byte

packagemainimport("encoding/binary""fmt""bytes")funcmain(){b:=new(bytes.Buffer)c:=new(bytes.Buffer)binary.Write(b,binary.LittleEndian,[]byte{0,1})binary.Write(b,binary.BigEndian,[]byte{0,1})binary.Write(c,binary.LittleEndian,uint16(256))binary.Write(c,binary.BigEndian,uint16(256))fmt.Println(b.B

戈朗 : convert IPv4 and IPv6 addresses from text to binary form

希望发送4个字节的ipv4地址和16个字节的ipv6地址-类似于inet_pton()去吗?structsockaddr_insa;charstr[INET_ADDRSTRLEN];inet_pton(AF_INET,"192.0.2.33",&(sa.sin_addr));structsockaddr_in6sa;charstr[INET6_ADDRSTRLEN];inet_pton(AF_INET6,"2001:db8:8714:3a90::12",&(sa.sin6_addr));我知道https://play.golang.org/p/jn8t7zJzT5v-虽然IPV6地址看

go - 如何在 Go 中将 bson.Binary 转换为 []byte

我正在编写一个小应用程序,它从网络(不是MongoDB)接收BSON格式的消息,并且必须将字段保存在本地机器上的文件中。我正在使用gopkg.in/mgo.v2/bson进行消息解码,它工作正常。几乎所有的东西都可以工作,除了一个。消息中有“用户定义的”二进制字段,我必须将其保存到单独的文件中。我尝试使用:varpwr=msg["pwr"].([]byte)但出现“错误panic:接口(interface)转换:接口(interface)是bson.Binary,而不是[]uint8”。谁能给我一个例子,说明如何将bson.Binary转换为[]byte,这样我就可以将它保存到文件中。

go - 如何关闭服务器的grpc流

在grpc中,客户端可以调用CloseSend来关闭到服务器的流,但服务器似乎无法切断与客户端的连接。 最佳答案 解决这个问题的最好方法是使用三个goroutines。问题在于bidi处理程序将被阻塞在Recv()中,因此当它想要完成流时无法轻易“返回到调用者”。另一个问题是,如果网络条件不好,或者另一端不合作,Send()可能会阻塞(这是您首先要终止连接的一个非常常见的原因!)通常,您还希望从接收方循环外部向发送方发送消息——使用双向流的典型情况是与世界其他地方进行实际通信。对于更隔离的请求/响应模式,其他模式通常更易于使用。允许

sockets - golang grpc 套接字调整

我有一个golang客户端应用程序通过GRPC与服务器通信。我注意到,在应用程序运行时,客户端应用程序上累积的套接字数量一直在攀升,直到9000左右。此时我暂停了客户端。然而,在客户端和服务器之间不再有流量之后,即使在8小时后,套接字数量仍保持在该水平。我们是否可以针对套接字使用调整GRPC?比如超时后关闭套接字?使用流式传输是否是另一种限制打开的套接字数量的方法?感谢您的帮助。 最佳答案 我首先要确保您的客户端应用程序通过调用Close()方法清除未使用的连接(grpc.ClientConn)。此外,由于我不知道您的应用程序究竟做

go - Cloud EndPoint GRPC 不匹配原型(prototype)定义

我正在使用GoogleCloudEndPoints访问以GoLang编写并在Kuberkules中运行的GRPC服务器。我正在关注here的教程.一切正常,但当我尝试请求时出现此错误rpc错误:code=NotFounddesc=方法不存在。EndPoint没有保存URL在我的原型(prototype)文件中有一个,名称中包含包。这是一个例子:logrequest在最后一个请求中,我更改了生成的protobuf文件中url的值,它通过了端点,但我的服务器不识别它......我得到了这个错误:rpcerror:code=Unimplementeddesc=unknownservicecl

go - 如何从 gRPC 获取方法扩展

我正在使用拦截器根据在传入和传出RPC上的RPC上设置的可选扩展执行额外验证。给定以下gRPC架构:extendgoogle.protobuf.MethodOptions{stringmy_option=50006;}serviceMyService{rpcFoo(FooRequest)returns(FooResponse){option(my_option)="foo"}}如何获取my_option的值?起初我想使用this从请求中获取它.但是,由于这是一个MethodOptions,它似乎不是描述符的一部分。想法? 最佳答案