网站首页 > 精选教程 正文
每天进步一点点,关注我们哦,每天分享测试技术文章
本文章出自【码同学软件测试】
码同学公众号:自动化软件测试
码同学抖音号:小码哥聊软件测试
01
什么是RPC
RPC(Remote Procedure Call)远程过程调用协议是一个用于建立适当框架的协议。从本质上讲,它使一台机器上的程序能够调用另一台机器上的子程序,而不会意识到它是远程的。
RPC 是一种软件通信协议,一个程序可以用来向位于网络上另一台计算机的程序请求服务,而不必了解网络的细节。RPC 被用来像本地系统一样调用远程系统上的其他进程。过程调用有时也被称为函数调用或子程序调用
02
RPC框架
RPC本身是一套协议规范,遵循这一套规范实现的框架比较流行的有以下几个:
- grpc框架
gRPC是由 google开发的一个高性能、通用的开源RPC框架,主要面向移动应用开发且基于HTTP/2协议标准而设计,同时支持大多数流行的编程语言。gRPC基于 HTTP/2协议传输
- dubbo框架
Dubbo是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的 RPC 实现服务的输出和输入功能,可以和Spring框架无缝集成。
Dubbo是一款高性能、轻量级的开源Java RPC框架,它提供了三大核心能力:
① 面向接口的远程方法调用
② 智能容错和负载均衡
③ 服务自动注册和发现
- thrift框架
Thrift是一种接口描述语言和二进制通讯协议。原由Facebook于2007年开发,2008年正式提交Apache基金会托管,成为Apache下的开源项目。
Thrift是一个RPC通讯框架,采用自定义的二进制通讯协议设计。相比于传统的HTTP协议,效率更高,传输占用带宽更小。另外,Thrift是跨语言的
- Hetty 框架
Hetty 是一款构建于 Netty 和 Hessian 基础上的高性能的 RPC 框架
Hessian 是一款基于 HTTP 协议的 RPC 框架,采用的是二进制 RPC 协议,非常轻量级 ,且速度较快。
Netty 是一款基于事件驱动的 NIO 框架,用以快速开发高性能、高可靠性的网络服务器和客户端程序。Hetty 客户端完全由 Hessian 实现,只是使用 Netty 重新实现了服务端
03
基于grpc框架服务的接口测试
01
创建一个grpc服务接口
注意在公司里你们的grpc服务可能并不是采用python去实现的,课上咱们为了测试grpc的接口,使用python先创建grpc的服务接口。
- 安装依赖库
- 创建grpc接口协议文档
- 在项目下创建一个grpc_study包,包下创建一个add.proto文件,将下述内容复制进去
- 生成服务代码
- 终端下进入proto文件所在目录,执行下述命令:
- 创建服务端
02调用grpc接口客户端
以下代码就是调用第一步中的grpc接口的
03接口框架中适配grpc封装
1、封装底层channel初始化
在config目录下创建grpc.yml,其中写上grpc接口的地址:
在common目录下的client中增加下述代码:
在conftes.py中增加下述代码:
2、封装grpc接口调用
在api包下创建一个grpcapi的包,将grpc的定义proto文件拷贝进去,然后在终端下进入grpcapi目录执行下述命令
该目录下文件如下:
修改add_pb2_grpc.py中的导入如下:
免费领取 码同学软件测试 课程笔记+超多学习资料+完整视频+最新面试题,可以转发文章 + 私信「码同学666」获取资料哦
根据上述代码封装接口调用,创建一个api_client.py,写上如下代码就是grpc提供的add接口的调用方法
3、编写grpc接口测试用例
在testcases包下创建一个grpcapi包,创建一个test_grpc_api.py,编写针对add接口的测试用例如下:
执行测试
04
基于dubbo框架服务的接口测试
dubbo服务管理地址:
http://**.***.**.***:****/dubbo-admin-2.6.0
用户名和密码都是root
01
dubbo服务管理简单使用
先设置为中文,右侧选择语言
选择服务治理-->服务
点开MarketService,再点ip和端口,打开如下:
02
实战接口说明
第1步里我们看到了两个接口,exchange和lottery,下面是这两个接口的业务说明
- exchange
业务是积分兑换,该接口的参数是一个对象,对象类型对应后台java代码中的某个类cn.testfan.dubbo.model.ExchangeRequest,这个类对象对应的属性如下,这些属性其实就是我们的参数
- lottery
业务是抽奖,参数有两个,都是数字,没有参数名称,按照顺序,第一个表示参与的活动id,第二个表示用户id
03
python调用dubbo接口
- 安装第三方库
- dubbo接口调用
04
接口框架中适配dubbo封装
1、封装底层dubbo初始化
在config目录下创建dubbo.yml文件,写上如下内容
在client.py里增加下述代码
2、封装api层
dubbo接口通常是按照服务进行划分,一个服务下有多个接口,针对该服务创建对象,然后调用各个接口。
在api包下创建dubboapi的包,针对market服务创建一个market_api.py文件,写上如下代码:
3、测试用例层
在testcases包下创建dubboapi包,在其下创建test_market_service.py,写上如下代码
执行测试
免费领取码同学软件测试课程笔记+超多学习资料+学习完整视频,可以关注我们公众号哦:自动化软件测试
本文著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。
猜你喜欢
- 2025-01-10 面试官:Spring 用了哪些设计模式?说三种即可 = =
- 2025-01-10 阿里标配鼠标垫,送100张
- 2025-01-10 记一次疑似JVM内存泄漏的排查过程
- 2025-01-10 springboot-data-redis-应用
- 2025-01-10 Redis存取架构及命令详解
- 2025-01-10 从中招到妥协——Locky电脑勒索病毒 中毒记录
- 2025-01-10 【质量保障】Playwright 使用入门
- 2025-01-10 用考完试的旧书可以换盆栽?浙大学霸们的献爱心活动启动啦!
- 2025-01-10 Redis这些知识你了解吗?
- 2025-01-10 基于Java,jfinal web框架开发出微信商城,微信分销商城源码分享
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)