草庐IT

grpc-precompiled-binaries

全部标签

go - 如何在grpc服务器端使用从客户端传递过来的上下文

我已经在grpc服务中定义了一个端点。现在,当客户端使用某些上下文调用端点时,我应该如何处理该上下文、它的到期/截止日期等?我的意思是在服务端,我要执行一系列的步骤来完成请求。它包括一些处理、写入数据存储等。现在我应该如何尊重上下文。是不是在流程的每一步之后,我都需要检查上下文是否完成?如果完成了,我就直接返回而不进行下一步?但这感觉不对。在GRPC/Go中正确的做法是什么? 最佳答案 服务处理程序获取的上下文中设置了截止日期(客户端设置的截止日期)。Go的方式是在您的每一步中传递该上下文,如果这些步骤中的任何一个阻塞,您也会在该上

go - 为 golang 运行 GRPC 示例

这里是新手。目前正在学习grpc的工作原理,并且正在阅读此链接中的教程https://grpc.io/docs/quickstart/go.html#update-and-run-the-application当我使用提供的helloworld.pb.go文件运行该示例时,它有效。但是,当我删除该文件并运行protoc--go_out=plugins=grpc:时。*.proto再次生成那个文件,我发现我不能再运行欢迎服务器了。我得到的错误是google.golang.org/grpc/examples/helloworld/helloworldhelloworld/helloworl

go - 将 protobuf 枚举消息发送到 grpc 服务器

给定一个messageFoo{enumState{STATE1=0;STATE2=1;STATE3=2;}}和一个grpc服务定义rpcMethod(streamFoo)returns(Empty){}将此发送到grpc服务器的gogrpc客户端代码是什么样的?澄清一下,假设我有一个streamClient.Send()。我将什么传递给Send()?我如何构建枚举? 最佳答案 您定义了State但Foo中没有State字段。试试这个syntax="proto3";optiongo_package="enumpb";messageFo

go - 如何在 Golang gRPC 中获取客户端 IP 地址和用户代理?

我设置了一系列gRPC请求和响应,一切正常,但当我尝试获取调用我的gRPCAPI的客户端IP地址和用户代理时,我卡住了。我阅读了GogRPC文档和其他资源,但没有找到太多有值(value)的信息。他们中很少有人在谈论Golang中的gRPC。在设置gRPCAPI时,我是否应该设置一个键值对来存储上下文中的IP地址? 最佳答案 在GolangGRPC中,你可以使用func(UserServicesServer)Login(ctxcontext.Context,request*sso.LoginRequest)(*sso.LoginRe

testing - Go gRPC 服务器使集成测试失败

我最近又开始玩go,我现在的任务是实现一个服务(将运行在k8s上),它应该充当gRPC服务器。根据要求,目前,为了满足k8s上的readinessProbe,我需要为我的服务实现一个健康检查端点,并且应该对其进行测试:我所做的是:funcmain(){server:=startHTTPServer()deferserver.Close()c:=make(chanos.Signal,1)signal.Notify(c,os.Interrupt,syscall.SIGTERM,syscall.SIGINT)我按照thisarticle这样测试的:funcTestMain(m*testing

c++ - gRPC 客户端流

客户端流的官方gRPC文档指出:Theserversendsbackasingleresponse,typicallybutnotnecessarilyafterithasreceivedalltheclient’srequests...我正在尝试做的是在流中间捕获服务器响应以停止发送更多数据。在Go中,我可以使用RecvMsg启动一个新的goroutine监听来自服务器的消息,但我找不到在C++中执行相同操作的方法。看起来像ClientWriter不提供这种功能。一个解决方案是拥有一个双向流,但想知道是否有任何其他方法可以在C++中实现这一点。 最佳答案

go - 如何在 grpc go 中实现非阻塞客户端?

我想在不同的服务器上运行不同的远程程序而不等待服务器的回复。当服务器完成程序时,我想在客户端回复。可以用grpcgolang做吗?我想实现一个区block链网络,我想要求不同的节点执行交易,但我不想等到一个节点提供执行输出,然后我才转移到另一个节点。换句话说,我想广播程序的执行过程,然后在执行过程中得到所有答案。我尝试了连接客户端和服务器的常用方法,但它等待服务器的响应。这会增加需要在更多节点上执行的时间。 最佳答案 你可以使用gofunc(){}()做异步任务,你可以使用同步内置包轻松控制异步任务或使用channel来控制或同步任

go - 如何将 row.Scan() int32 转换为 Golang gRPC protobuf Enum 字段?

//agent.protomessageAgent{Permissionpermission=1;google.protobuf.Timestampborn_time=2;messagePermission{Typetype=1;enumType{KILLNONE=0;KILLALL=1;DANCE=2;}}}然后将SQL行扫描到代理protobuf结构中://main.govaraproto.Agent........row.Scan(&a.Permission.Type,...)对于默认类型,该权限类型存储为简单的MariaDBINT()value=0。所以,我不能直接扫描它。因此

go - 使用入口部署 Rest + gRPC 服务器部署到 k8s

我使用了示例gRPCHelloWorld应用程序https://github.com/grpc/grpc-go/tree/master/examples/helloworld.本示例在本地系统运行流畅。我想使用Ingress将它部署到kubernetes。下面是我的配置文件。service.yaml-作为NodePortapiVersion:v1kind:Servicemetadata:name:grpc-scratchlabels:run:grpc-scratchannotations:service.alpha.kubernetes.io/app-protocols:'{"grpc

go - 如何在 Go 中创建一个通用的 GRPC 服务器启动函数

我正在尝试抽象GRPC服务器的启动原主函数如下:funcmain(){lis,err:=net.Listen("tcp",port)iferr!=nil{log.Fatalf("failedtolisten:%v",err)}s:=grpc.NewServer()pb.RegisterCollectionServer(s,&server.Server{})//RegisterreflectionserviceongRPCserver.reflection.Register(s)iferr:=s.Serve(lis);err!=nil{log.Fatalf("failedtoserve: