ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Dubbo无法发布被事务代理的问题

2021-09-03 23:35:21  阅读:125  来源: 互联网

标签:Dubbo 事务 String hello 代理 class UserService public name


前言

当程序中加入事务时,生产者服务就会发布失败

修改前配置文件

<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管理中心,生产者和消费者是否都存在

我出现这种情况,是因为数据库不存在导致的,我更新了数据库之后,调用就正常了。

标签:Dubbo,事务,String,hello,代理,class,UserService,public,name
来源: https://blog.csdn.net/da_kiku/article/details/120092103

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有