草庐IT

RPC和GRPC

全部标签

JSON-RPC, "cannot unmarshal object"

我正在尝试了解JSON-RPC的工作原理,并正在使用Go语言(golang)对其进行测试。Go程序运行良好。它做了它应该做的。但是当我尝试通过telnet发出原始请求时,它给出了一个错误。这里描述了工作和super简单的JSON-RPC服务器://rpc_json_server.gopackagemainimport("log""net""net/http""net/rpc""net/rpc/jsonrpc")//------------------------------------------------------------------------------//Types//

go - 带有 gRPC 的 golang protocol buffers 可以在不同的 OS 平台上交叉编译和使用吗?

这个问题专门关于在不同的操作系统平台上编译和使用golangProtocolBuffer(使用gRPC),我还没有看到类似的问题。是否可以在Windows上编译一个.proto文件,然后在Linux上使用生成的文件?还是相反?我在Windows和Linux上编译了相同的.proto文件,diff显示了不同的结果。一个区别是Windows编译版本有时会在请求结构的字段中重复json,如下所示:Field1Name*type`protobuf,bytes,1,opt,name=my_name,json=myName"json:"my_name,omitempty"`而Linux版本是:Fi

Golang GRPC 返回 EOF 错误

我正在使用http通过以下代码调用RPCfunc(c*CallClient)Wallet(methodstring,req,repinterface{})error{client:=&http.Client{}data,_:=EncodeClientRequest(method,req)reqest,_:=http.NewRequest("POST",c.endpoint,bytes.NewBuffer(data))resp,err:=client.Do(reqest)iferr!=nil{returnerr}deferresp.Body.Close()io.Copy(ioutil.D

go - 如何从客户端发送 grpc 元数据

我在golang中使用grpc.Dial(server)来设置与我的服务器的grpc连接。如何通过此拨号连接(从客户端)发送元数据或自定义header? 最佳答案 我假设grpc是您的客户端连接对象。您使用来自map[string]string(提供的一些其他方法)的元数据子包创建元数据,然后通过上下文传递它,例如md:=metadata.New(map[string]string{"key1":"val1","key2":"val2"})ctx:=metadata.NewOutgoingContext(context.Backgr

python - 无法使用python客户端连接到go grpc服务器

我有一个在Go中运行的grpc服务器。我无法使用python客户端调用方法。不知道出了什么问题。我收到以下错误_RPC的会合以(StatusCode.UNIMPLEMENTED,method:/com.test/myMethod)>结束知道哪里出了问题吗?Go客户端能够正常通信。我还按照说明生成了stubhttps://grpc.io/docs/tutorials/basic/python.htmlpython-mgrpc_tools.protoc-I../../protos--python_out=.--grpc_python_out=.../../protos/route_guid

go - 使用 JSON-RPC 调用传递身份验证详细信息

我没能找到任何关于此的文档。我需要对需要传递(基本)身份验证详细信息的API进行JSON-RPC调用,但找不到使用标准net/rpc/jsonrpc包执行此操作的任何方法。下面是我的非身份验证代码的剪辑版本。varreplystringnetClient,_=net.Dial("tcp","localhost:1234")jsonClient=jsonrpc.NewClient(netClient)jsonClient.Call("someMethod",someArgs,&reply) 最佳答案 Basic-Auth是一个HTTP

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)时我仍然收到错误消息”不确定是什么覆盖了大小

go - 如何将结构作为参数传递给 xml-rpc

我有点新手,一直在尝试使用我的goAPI中的XML-RPC方法,为此我选择了https://github.com/mattn/go-xmlrpc一切正常,直到我不得不将结构作为参数传递。在我得到的结构的示例中,格式为python字典{string:string}或空字典。如果我为结构提供我在python示例中使用的值,我将得到panicserving。我试图创建映射或空结构,但它会说给定的参数是错误的(错误是由xml-rpc引起的)。如果我尝试将其转换为json并使用编码/json解码器将其解析回来,它会说我使用了错误的结构。typeDatastruct{serial_numberst

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