java定义dubbo接口_java反射调用dubbo接口

为了实现幂等性,项目A在处理请求时设置流水ID并存入Redis,当B项目调用A超时,请求被放入Redis队列,由C项目异步处理。C项目启动两个任务,task1从Redis获取信息并入库,task2负责重试。重试过程中,通过反射调用Dubbo接口,注意接口应为实现类而非接口本身,且调用时需使用newInstance()创建实例。此外,提供了一个解析接口名获取beanName的方法,使得调用配置可存储在数据库中,实现动态调用。
摘要由CSDN通过智能技术生成

需求:项目增加幂等

场景:

1.三个项目:a 、b、c

2.a项目加幂等

3.b项目dubbo调用项目a的时候超时没有获取返回结果,增加重试机制(非立即重试,3min or 5min 后重试)

4.c项目是一个异步的job项目,用来接收mq,异步处理,管理task等。

方案:

1.a项目设置请求流水id,将请求先存入redis缓存,处理完成之后更新redis中的状态,同一个流水id认为是重复提交,不进行业务处理,直接返回redis中的状态

2.b项目捕获调用a项目的超时异常,存入redis队列

3.c项目启动两个task,task1用来获取redis队列里面的信息,落库。task2用来扫库,及重试。

重点:

1.c项目只是异步接口消息没有业务处理逻辑

2.task2重试的时候需要通过dubbo接口调用b来进行重新发起请求,及后续处理。

这里重点分享一下通过反射机制调用dubbo接口(map为请求参数)

String inter = "com.xxx.xxx.xxx.xxx.xxx.xxx";

Class> mClass = Class.forName(inter);

Method method = mClass.getMethod("methodNamexxx",new Class[]{String.class});

Object object = method.invoke(mClass.newInstance(),JSON.toJSONString(map));

圈重点:

1.inter需要是serviceImpl实现类,如果是interface的话,会报

Caused by: java.lang.NoSuchMethodException: com.xxx.xxx.xxx.xxx.xxx.()

2.invoke(Object obj,Object... args) 这里的obj需要newInstance()一下,否则会报

java.lang.IllegalArgumentException: object is not an instance of declaring class

调用dubbo接口的写法:(map为请求参数)

String inter = "com.xxx.xxx.xxx.IxxxService";

String methodName = "xxxxx";

Class> mClass = Class.forName(inter);

Map map = new HashMap<>();

AbstractApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");

Object obj = context.getBean(this.getBeanName(inter));

Method method = mClass.getMethod(methodName,new Class[]{Object.class});

Object object = method.invoke(obj,JSON.toJSON(map));

publicString getBeanName(String str){

String name= str.substring(str.lastIndexOf(".")+2,str.length());

name= name.substring(0,1).toLowerCase() + name.substring(1,name.length());returnname;

}

通过解析inter获取beanName,通过spring获取bean的方式获取对象进行反射调用。

将interface及method配置到数据库中,就能实现不用改动代码进行调用的操作了。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值