草庐IT

RPC和GRPC

全部标签

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:

go - gRPC 到远程服务器的带宽较慢

我有一个gRPC服务,可以将文件从本地机器传输到远程服务器,我注意到一些严重的带宽问题。平均而言,它的下载速度约为1mb/s,一个连接共享多个流(通常约为8个)。服务器使用TLS加密,但这似乎不是瓶颈,因为关闭TLS对性能的影响可以忽略不计。我还尝试使用iperf3直接测试客户端和服务器之间的带宽,结果是10mb/s。Connectingtohost,port[7]local10.0.0.112port59651connectedtoport[ID]IntervalTransferBitrate[7]0.00-1.00sec1.28MBytes10.7Mbits/sec[7]1.00-

go - grpc protobuf 使用字符串创建新结构

我正在使用微框架开发我的新项目,并且我已经完成了GRPC工作。但是现在,我需要编写与前端交互的网关。实在不想写重复的代码,在pb.go文件中找了一些代码。代码定义了一些结构和初始化函数。如下所示:typeAuthLoginReqstruct{Usernamestring`protobuf:"bytes,1,opt,name=username,proto3"json:"username,omitempty"`Passwordstring`protobuf:"bytes,2,opt,name=password,proto3"json:"password,omitempty"`XXX_NoU

go - 在 Go 中关闭 grpc 服务器时如何检测错误?

我正在尝试在GogRPC客户端代码中检测gRPC服务器关闭import(pb"mysample.com/api/rpc""google.golang.org/grpc")varstreampb.SearchProductService_MarketStreamClientfor{r,err:=stream.Recv()iferr==io.EOF{log.Println("Info:serverclose")break}elseiferr!=nil{log.Println("Err:grpccode:",grpc.Code(err))iferr!=nil{log.Fatal(err)}}

使用 JSON-RPC 编码数据时出错 - 我是不是很笨?

所以我正在使用类似于以下的代码,但无法让RPC在FooHolder中工作,在FooHolder中它保存满足接口(interface)的对象。我可能遗漏了一些东西,但它看起来应该可以工作——使用反射包它可以正确识别类型,但是当函数返回时出现了一些问题....packagemainimport("log""net""net/rpc""net/rpc/jsonrpc""reflect")typeFooInterfaceinterface{DoTheBartman(in*string,out*string)errorDoThis(in*[]string,out*[]string)errorNo

go - rpc Call 方法是否在与服务器相同的 go routine 中运行?

我的服务器:func(t*Arith)Multiply(args*Args,reply*int)error{*reply=args.A*args.Breturnnil}funcmain(){arith:=new(Arith)rpc.Register(arith)rpc.HandleHTTP()l,e:=net.Listen("tcp",":1234")ife!=nil{log.Fatal("listenerror:",e)}gohttp.Serve(l,nil)}客户:client.Call("Arith.Multiply",args,&reply)我认为Multiply在另一个gor

go - rpc.ServerCodec 还在服务吗?

我正在执行一些RPC测试,偶然发现了一个我似乎无法解决的问题。在我的测试中,我创建了三个独立的RPC服务器,我尝试关闭所有这些服务器。然而,在执行我的最后一个测试(TestRpcCodecServerClientComm)时,我的客户端连接似乎正在连接到我启动的第一个RPC服务器(我知道这一点是因为我在某些时候将ID附加到RPCHandlers),即使我尝试了一切我可以确保它被关闭了。虽然代码不在那里,但我已尝试检查每一个错误,但这并没有带来任何结果。rpc.gopackagerbotimport("io""net""net/rpc""net/rpc/jsonrpc")funcRpcC

c++ - C++ GRPC客户端与golang服务器连接错误

我正在尝试编写一个与C++和golang客户端通信的GRPC服务器。由于这都是我们系统内部的,因此会有一个自签名证书签署服务器证书,服务器将签署客户端证书。我能够从golang客户端连接到服务器。但是,C++客户端没有连接,我从ssl层看到了一堆错误。我在配置C++grpc客户端时做错了什么?(我的证书目前都使用2048位的RSAkey)以下是我认为等效的客户端代码(省略了错误处理):戈兰:import("crypto/tls""io/ioutil""google.golang.org/grpc""google.golang.org/grpc/credentials")funcgetC