当前位置: 首页 > news >正文

【Go<—>Java】gRPC测试注意事项

在做go和Java之间gRPC调用之前需要完成以下两项工作:

  1. go语言版本的gRPC调用,实现server端和client端
  2. Java语言版本的gRPC调用,实现server端和client端

由于gRPC是跨语言的通信协议,所以我们可以相互调用,有以下2种调用方式:

  1. go程序作为server端,Java程序作为client端
  2. Java程序作为server端,go程序作为client端

还是拿之前写的一个student.proto文件为例

step1.student.proto文件定义

syntax="proto3";
option go_package="./;student"; //关于最后生成的go文件是处在哪个目录哪个包中,.代表在当前目录生成,student代表了生成的go文件的包名是studentoption java_multiple_files = true; //表示下面的message需要编译成多个java文件
option java_package = "grpc.student"; //指定该proto文件编译成的java源文件的包名
option java_outer_classname = "StudentProto"; // 表示下面的message编译成的java类文件的名字package student; // 定义作用域service DemoService {rpc Sender(StudentRequest) returns (StudentResponse){}
}message StudentRequest {string Id = 1;
}message StudentResponse {bytes result =1;
}message Student {int64 Id = 1;string Name =2;string No =3;
}

step2.生成各自的代码程序

这里不详细写生成过程了,之前写了两篇文章可参考:

1.Java生成gRPC程序:【JAVA】Maven构建java-grpc-protobuf代码生成测试-CSDN博客

2.Go生成gRPC程序:【GO】protobuf在golang中的测试用例-CSDN博客

step3.接口调用测试

选择以下两种方式都可以测试

  1. go程序作为server端,Java程序作为client端
  2. Java程序作为server端,go程序作为client端

根据接口定义调用Sender方法时发现一个问题

UNIMPLEMENTED: unknown service student.DemoService

经过排查发现go程序里的student.proto没有定义package ,而Java程序里的student.proto有package定义。修改保持student.proto文件一致,即我文章开始贴的proto文件即可,测试通过。

测试过程简单描述如下:

  1. go程序作为server端,Java程序作为client端

        启动go rpc server,运行Java rpc client 调用Sender接口测试

  1. Java程序作为server端,go程序作为client端

        启动Java rpc server,运行go rpc client 调用Sender接口测试

通过查阅资料proto文件定义需要满足以下要求:

1.package 必须一致,package限制说明你所定义的接口属于那个作用域下的。

例如student.proto文件定义package student,也就是DemoService Sender接口属于student作用域下,如果go或者java或者其他语言定义的package不相同是无法相互调用的,就是报错类似:UNIMPLEMENTED: unknown service student.DemoService

package student; // 定义作用域

生成go程序和Java程序会发现程序里有所对应代码指定

go程序:student_grpc.pb.go文件里定义常量如下

const (DemoService_Sender_FullMethodName = "/student.DemoService/Sender"
)

Java程序:

public class DemoServiceGrpc {private DemoServiceGrpc() {}public static final String SERVICE_NAME = "student.DemoService";.....}

 2.接口名称和方法名称定义签名必须一致,需要维护一套proto文件即可解决此类问题。

3.proto文件编写注意事项,可参考

protobuf一些注意事项_proto [packed = true]-CSDN博客

.proto 文件中 import 其他 .proto 文件时的注意事项_proto可以import远程proto-CSDN博客

 

http://www.lryc.cn/news/259147.html

相关文章:

  • java面试题整合
  • 2023年12月7日:QT实现登陆界面
  • 常用的测试用例大全
  • 《python每天一小段》--12 数据可视化《1》
  • 分类预测 | Matlab实现HPO-GRU【23年新算法】基于猎食者优化算法优化门控循环单元的数据分类预测
  • 【Pytorch】学习记录分享2——Tensor基础,数据类型,及其多种创建方式
  • 实验7:索引和视图定义
  • Source Tree回滚 重置 贮藏操作
  • Android13 不能静态注册的几个广播
  • 吴恩达深度学习L2W1作业1
  • uniapp原生插件之安卓app添加到其他应用打开原生插件
  • scala编码
  • 智慧路灯杆如何实现雪天道路安全监测
  • C语言指针基础题(二)
  • 物奇平台MIC配置与音频通路关系
  • 外包干了3年,技术退步太明显了。。。。。
  • 阶段十-java新特性
  • win10重装系统历程
  • 【知识积累】深度度量学习综述
  • webrtc网之sip转webrtc
  • 【Spring】依赖注入之属性注入详解
  • 6-tornado配置文件的使用(命令行解析、文件设置)
  • k8s ingress service endpoints 解决微信服务器验证问题(内网穿透)
  • postgresql-effective_cache_size参数详解
  • CUDA锁页内存的使用
  • python常见代码用法
  • MTU TCP-MSS(转载)
  • 【ARM Trace32(劳特巴赫) 高级篇 20 -- SNOOPer 使用介绍】
  • MySQL笔记-第11章_数据处理之增删改
  • ANSYS常见error解答(转)