Dubbo使用invoke指令来调用dubbo接口

时间:2020-8-27 作者:admin


Dubbo使用invoke指令来调用dubbo接口

前言

最近被分配了一个任务,是通过dubbo的方式对外提供服务,dubbo没有我们一般的web项目中的Controller层,所以没有办法通过http的方式进行调用调试。作为萌新的我,确实有点一筹莫展,直到被老司机提醒使用dubbo invoke的方式进行接口测试,我才有方向。

关于dubbo的搭建可参考我的博客:SpringBoot使用dubbo实现RPC调用

正文

首先我们要知道Dubbo不同于传统的web项目需要运行在类似于tomcat、jboss等WEB容器中,Dubbo的运行机制我们可以参考下面Dubbo的组件来进行探究。

Dubbo 核心组件:

  • Provider: 暴露服务的提供方,可以通过jar或者容器的方式启动服务
  • Consumer:调用远程服务的服务消费方。
  • Registry: 服务注册中心和发现中心。
  • Monitor: 统计服务和调用次数,调用时间监控中心。
  • Container:服务运行的容器。

Dubbo使用invoke指令来调用dubbo接口
Dubbo的Container模块,是一个独立的容器,它就可以为dubbo提供服务发现机制。并且这个Container容器默认是采用dubbo协议在20880端口号暴露服务,所以我们要通过这个接口来调用dubbo接口。

使用invoke调用dubbo接口服务

使用telnet命令进入控制台
命令:telnet ip 端口

telnet 127.0.0.1 20880

Dubbo使用invoke指令来调用dubbo接口

使用invoke命令注入

如果注入的是json,可参考以下格式进行dubbo服务调用

invoke XxxService.xxxMethod({“name”: “luo”}, 18, “男”)

如果注入的是对象,可参考以下格式进行dubbo服务调用:

invoke XxxService.xxxMethod([{“name”:“luo”,“age”:18,“sex”:“男”,class:“com.luo.entity.User”}])

Dubbo使用invoke指令来调用dubbo接口

Dubbo使用invoke指令来调用dubbo接口

声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。