rpc error: code = Unimplemented desc =
生活随笔
收集整理的這篇文章主要介紹了
rpc error: code = Unimplemented desc =
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
grpc 版本
在 go 語言場(chǎng)景下使用 grpc,編譯 ok,運(yùn)行的時(shí)候報(bào)錯(cuò)。
grpc 版本:1.40.0
go version: go1.16.10 linux/amd64
運(yùn)行報(bào)錯(cuò)提示
"rpc error: code = Unimplemented desc ="運(yùn)行錯(cuò)誤截圖如下:
結(jié)論先行
引起上述錯(cuò)誤的主要原因是自定義的 proto 文件中 package 的名字和代碼中的 import 中的 package 名稱不一致才導(dǎo)致的問題。
因此檢查自定義的 proto 文件以及代碼中引用(import)的文件名稱,將二者改為一致即可。
后續(xù)的內(nèi)容只是簡(jiǎn)單記錄下發(fā)現(xiàn)錯(cuò)誤過程而已。感興趣的可以繼續(xù)閱讀。
錯(cuò)誤調(diào)查
查看 proto 文件
package mypai; option go_package = "./;mypai";service mygrpc{rpc MyTestGrpcFunction(EmptyReq) returns (MyActiveTable) {} }message EmptyReq{} message MyActiveTable {repeated string idList = 1; }grpcClient 部分代碼
報(bào)錯(cuò)的位置是第 27 行處,其他部分代碼截圖如下:
3 import (4 "fmt"5 myapi "mycodes/egrpcProtoc/test"6 "time"7 "errors"8 )...........25 func TestMyTestGrpcFunction(req *myapi.EmptyReq) (resp *myapi.MyActiveTable) {26 if resp, err = grpcClient.MyTestGrpcFunction(req); err != nil {27 log.Logger.Error(err)28 }29 } else {30 log.Logger.Error(err)31 }32 return resp33 }使用 grpc 工具生成的 *.pb.go 部分代碼
3 package mypai...........72 type GrpcClient interface {73 MyTestGrpcFunction(in *EmptyRequest, opts ...grpc.CallOption) (*MyActiveTable, error)74 }...........78 func (c *grpcClient ) MyTestGrpcFunction(in *EmptyRequest, opts ...grpc.CallOption) (*MyActiveTable, error) {79 out := new(MyActiveTable)80 err := c.cc.Invoke(ctx, "/mypai_communication.myapi/MyTestGrpcFunction", in, out, opts...)81 if err != nil {82 return nil, err83 }84 return out, nil85 }...........112 type GrpcClient interface { 113 MyTestGrpcFunction(*EmptyRequest) (*MyActiveTable, error) 114 }...........123 func (*UnimplementedMypaiServer) MyTestGrpcFunction(*EmptyRequest) (*MyActiveTable, error) { 124 return nil, status.Errorf(codes.Unimplemented, "method MyTestGrpcFunctionnot implemented") 125 }發(fā)現(xiàn)問題
截至此處,基本可以上可以確定代碼問題所在,因?yàn)槊黠@在自定義的 proto 中是定義有 MyTestGrpcFunction 接口方法的,但是運(yùn)行卻報(bào)錯(cuò) Unimplemented ,再次 check 代碼發(fā)現(xiàn)是 package 名稱,在自定義的 proto 中是 mypai ,但是在代碼使用中卻用的是 myapi ,可以很明顯的看出是不一樣的。
參考
Error handling
總結(jié)
以上是生活随笔為你收集整理的rpc error: code = Unimplemented desc =的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: redis解决(DENIED Redis
- 下一篇: 什么是项目管理?范围、时间、成本、质量