草庐IT

grpc-precompiled-binaries

全部标签

asynchronous - Go lang gRPC异步操作的理解与实现

我还在为这个问题苦恼:我知道使用Golang我们可以轻松实现高性能的网络服务。我选择了gRPC协议(protocol),我最好实现异步操作,因为它比同步更强大:你能告诉我更多关于使用异步操作相对于同步操作的好处的细节吗?能否指导我如何实现Golang或Python异步服务,或者给我它的示例代码,我已经阅读了这篇文章https://grpc.io/docs/tutorials/async/helloasync-cpp.html但这些代码超出了我的知识范围非常感谢! 最佳答案 我认为对你来说做更多的研究和弄清楚你正在处理的一些概念很重要

go - 在 golang 中更新 grpc 的接收和发送消息大小

我有一个用Go编写的grpc服务器,我正在尝试使用以下代码将接收和发送消息的大小更新为20MB而不是默认的4MBvars*grpc.Servers=grpc.NewServer(grpc.MaxRecvMsgSize(1024*1024*20),grpc.MaxSendMsgSize(1024*1024*20))pb.RegisterProductServer(s,mysrv)但上面的方法似乎不起作用,因为当我尝试从客户端调用receivedmessagelargerthanmax(5807570vs.4194304)时我仍然收到错误消息”不确定是什么覆盖了大小

docker - 我尝试在 docker 中部署 gRPC (go) 服务器并在本地端口中公开端口,但端口绑定(bind)不起作用

我尝试在docker中部署gRPC服务器和mongodb。之后我尝试将docker端口绑定(bind)到我的本地端口。mongodb端口绑定(bind)工作正常。但是,gRPC服务器端口没有绑定(bind)我的本地端口ports:-"50051:50051"像这样我在docker-compose.yml中尝试过docker-compose.ymlservices:auth_server:container_name:auth_servicebuild:.command:gorunserver.govolumes:-.:/go/src/auth_serverworking_dir:/go

go - 如何在 go 中对 gRPC 服务进行单元测试

我在对gRPC服务进行单元测试时遇到困难。我看了TestingagRPCservice但它对我不起作用,不确定我做错了什么。Add方法的gRPC服务实现:typeserverstruct{}funcmain(){listener,err:=net.Listen("tcp",":4040")iferr!=nil{panic(err)}srv:=grpc.NewServer()service.RegisterMathOpServiceServer(srv,&server{})reflection.Register(srv)ife:=srv.Serve(listener);e!=nil{pa

go - GRPC:什么时候有新客户?

我在我的项目中使用grpc,如果我有一个grpc服务调用helloService,我应该使用GetNewHelloServiceClient在每个函数中获取一个新的客户端吗?或者只在启动程序中获取一次?//forexample:c.GET("/hello",SayHello)funcSayHello(){c:=pb.GetNewHelloServiceClient()res,err:=c.SayHello(context.Background(),&request)iferr!=nil{return}fmt.print(res.Hello)} 最佳答案

go - grpc 服务器在同时发送多条消息后停止接收消息

我正在实现一个简单的grpc服务,其中任务摘要将被发送到grpc服务器。如果我发送的消息数量较少,一切正常,但是当我开始发送5000条消息时,服务器停止并在客户端收到超出截止日期的消息。我也尝试重新连接,但发现错误消息为。rpcerror:code=Unavailabledesc=allSubConnsareinTransientFailure,latestconnectionerror:timedoutwaitingforserverhandshake服务器未显示任何错误并且处于事件状态。我也尝试设置GRPC_GO_REQUIRE_HANDSHAKE=off但错误仍然存​​在。我还实

go - grpc:使用 oneof 会导致无效的内存地址或 nil 指针取消引用

我正在尝试使用Go将proto3结构发送到gRPC服务器。该结构有一个oneof类型,我似乎很好地填充了它。将消息发送到我的gRPC客户端时,我对无效内存地址或nil指针引用感到panic。我有原型(prototype)定义(完整文件位于https://github.com/MovingGauteng/geofancy-rs/blob/master/proto/geofancy.proto:#proto3messageDocument{stringcollection=1;stringid=2;oneofgeo{Pointpoint=4;LineStringline=5;Boundsb

go - 欺骗 grpc UnaryHandler 以在 Go 中对 gRPC 进行单元测试

我正在努力提高我的GogRPC服务器的覆盖率,但我在为服务器的拦截器功能编写测试时遇到了麻烦,因为我无法有意义地满足UnaryHandler类型。我有一个函数Interceptor具有以下签名:Interceptorfunc(ctxcontext.Context,reqinterface{},info*grpc.UnaryServerInfo,handlergrpc.UnaryHandler,//我假设任何gRPC方法都会满足UnaryHandler的签名:typeUnaryHandlerfunc(ctxcontext.Context,reqinterface{})(interface

go - 无论我使用什么 dBase (.dbf) 文件,binary.read 都会返回 "unexpected EOF"

funcmain(){file,err:=os.Open("example.dbf")//Forreadaccess.iferr!=nil{log.Fatal(err)}dBaseioReader,err:=NewReader(file)iferr!=nil{log.Fatal(err)}returnnil}typedbHeaderstruct{VersionbyteLastUpdate[3]byteNumRecordsint32NumBytesInHeaderint16NumBytesInRecordint16_[2]byte//reservedIncompatFlagbyteEnc

java - gRPC:如何使用 Go 服务器在 Java 客户端中获取多个返回值

我有一个ProtocolBuffer文件:syntax="proto3";packagev1api;optionjava_multiple_files=true;optionjava_package="myApp.v1";optionjava_outer_classname="V1";serviceAPI{rpcLogin(LoginRequest)returns(LoginResponse)}messageLoginRequest{intpin=1}messageLoginResponse{stringtoken=1}我的服务器是用Go(一种可以返回多个值的语言)编写的,我的客户端是