前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >springboot 集成dubbo

springboot 集成dubbo

作者头像
跟着飞哥学编程
发布2022-11-30 21:18:34
2030
发布2022-11-30 21:18:34
举报

1.pom引入dubbo依赖

代码语言:javascript
复制
<dependency>
            <groupId>io.dubbo.springboot</groupId>
            <artifactId>spring-boot-starter-dubbo</artifactId>
            <version>1.0.0</version>
</dependency

2.application.properties中引入dubbo 配置信息

代码语言:javascript
复制
# Dubbo provider server config
spring.dubbo.application.name=provider
spring.dubbo.registry.address=zookeeper://ip:2181
spring.dubbo.protocol.name=dubbo
spring.dubbo.protocol.port=20880
spring.dubbo.scan=com

3.封装接口service,接口实现类加dubbo的service注解 import com.alibaba.dubbo.config.annotation.Service;

以上是服务提供,服务消费和提供引入类似

4.消费者引用dubbo服务 首先把服务提供者的service接口打成jar包,service接口一定要有注释,此处最好打包时带源码,方便别人调用时查看调用的方法。

代码语言:javascript
复制
import com.alibaba.dubbo.config.annotation.Reference;
@Reference(timeout=6000)
    private IRedisService redisService;

引入即可。 5.dubbo提供服务时的注意点: 若服务内有被事务代理的bean注入,或是方法有

代码语言:javascript
复制
import javax.transaction.Transactional;

被事务管理的,则服务注册zookeeper时会失败。 解决方案: 将有事务管理的方法写到另外的service类内。比如:

代码语言:javascript
复制
@Service
public class UserServiceImpl implements IUserService{

    private Logger logger = LoggerFactory.getLogger(UserServiceImpl.class);
    @Autowired
    private MemberRepository memberRepository;

    @Autowired
    private VoiceprintRepository voiceprintRepository;

    @Autowired
    private TranscationService transcationService;

    private Member insertMember(String contract, YHTUserVO yhtUserVO) {
    transcationService.save(member);
    }

UserServiceImpl是我要注册的dubbo服务,TranscationService为放置事务管理的方法类

代码语言:javascript
复制
import javax.transaction.Transactional;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class TranscationService {

    @Autowired
    private MemberRepository memberRepository;
    @Transactional
    public void save(Member member){
        memberRepository.save(member);
    }
    @Transactional
    public void saveAndFlush(Member member){
        memberRepository.save(member);
    }
}

至此,基本就简单实现了注册服务与调用服务了。 查看dubbo服务是否注册和发布成功:

6.若是服务既是提供者又是消费者,发现服务发现不了,可以把扫描包路径设置成一致的即可。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-09-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档