当程序中加入事务时,生产者服务就会发布失败
修改前配置文件
<dubbo:application name="dubbo-provider"/> <dubbo:registry address="zookeeper://192.168.211.131:2181"/> <dubbo:protocol name="dubbo" port="20880"/> <dubbo:annotation package="com.kkb.dubbo.service.impl"/> <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"> <property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/> <property name="url" value="jdbc:mysql:///school"/> <property name="username" value="root"/> <property name="password" value="root"/> </bean> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"/> </bean> <tx:annotation-driven/>
修改前接口实现类
@Service @Transactional(rollbackFor = Exception.class) public class UserServiceImpl implements UserService { @Override public String hello(String name) { return "hello :" +name; } }
1、在事务注解支持里加入:proxy-target-class=true
<tx:annotation-driven proxy-target-class="true"/>
作用:基于cglib代理,默认是基于jdk代理
此时发布的服务接口为Spring默认的SpringProxy代理类
完整配置文件:
<dubbo:application name="dubbo-provider"/> <dubbo:registry address="zookeeper://192.168.211.131:2181"/> <dubbo:protocol name="dubbo" port="20880"/> <dubbo:annotation package="com.kkb.dubbo.service.impl"/> <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"> <property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/> <property name="url" value="jdbc:mysql:///school"/> <property name="username" value="root"/> <property name="password" value="root"/> </bean> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"/> </bean> <!--默认使用jdk动态代理,proxy-target-class:使用cglib代理--> <tx:annotation-driven proxy-target-class="true"/>
2、在实现类上添加:
@Service(interfaceClass = UserService.class)
作用:指定发布的服务接口
完整实现类:
@Service(interfaceClass = UserService.class) @Transactional(rollbackFor = Exception.class) public class UserServiceImpl implements UserService { @Override public String hello(String name) { return "hello :" +name; } }
至此,配置完成。
下图是我在操作过程中碰到的问题:消费方调用超时
解决方法可以参考如下:
1、数据源的配置是否有误
2、检查实体类,是否实现了序列化接口
3、检查zookeeper管理中心,生产者和消费者是否都存在
我出现这种情况,是因为数据库不存在导致的,我更新了数据库之后,调用就正常了。