被事务代理的spring service 不能使用注解方式发布dubbo服务

 背景:

在做一个级联删除的时候,考虑到万一一个表的数据删除了,与之关联的表因异常未完成删除,这个时候就需要加上一个事务进行回滚操作。索性我就在暴露服务的facade层加上了事务注解。于是问题来了,写了事务注解的这个facade注册不到dubbo上去。原来是因为spring与dubbo这块糅合的不是很好,dubbo还不支持带事务注解的spring service服务注册。细心的老铁们可能会发现service服务虽然没有注册到dubbo上面,但是上面多了一个springProxy的服务。

分析:

我们通过@Transactional标注过的service产生一个代理类,这个代理类有两种生成方式。一种是jdk的动态代理,一种是cglib动态代理。jdk动态代理生成的代理类与当前类共同实现相同的接口。cglib生成的代理类为当前service的子类,可以集成到当前service的注解。但是在dubbo的service中并没有Inherited元注解,所以导致类不能被子类继承。所以在dubbo-admin上看到会是springproxy被注册上去了。

解决方案:

如果确实有需要的话就需要修改dubbo的源码了。即在dubbo的service上面加上@Inherited注解,使这个service变成可继承的。

或者是像小编的项目这样,加了一个facade层(当然也有考虑其他方面),facade层暴露接口到dubbo。service层只是业务逻辑。


你可能感兴趣的:(被事务代理的spring service 不能使用注解方式发布dubbo服务)