SpringBoot 整合 Dubbo 进行分布式开发


 

自从Dubbo支持SpringBoot后,Dubbo与Spring的整合变得更加的简单了,下面就是完整的步骤:

 

1. 引入依赖

<dependency>
    <groupId>com.alibaba.boot</groupId>
    <artifactId>dubbo-spring-boot-starter</artifactId>
    <version>0.2.0</version>
</dependency>

 

2. 在dubbo-api中定义model和service接口,model就是普通的POJO,service接口的代码如下:

BounterService.java

package cn.bounter.dubbo.service;

import cn.bounter.dubbo.model.Bounter;

public interface BounterService {
    
    Bounter findById(long id);
}

 

3. 服务提供者实现接口并配置Dubbo

BounterServiceImpl.java

package cn.bounter.dubbo.service;


import java.util.Date;
import com.alibaba.dubbo.config.annotation.Service;
import cn.bounter.dubbo.model.Bounter;


//声明为Dubbo服务
@Service
public class BounterServiceImpl implements BounterService {

    @Override
    public Bounter findById(long id) {
        //模拟访问数据库
        return new Bounter().setId(1L).setName("simon").setCreateTime(new Date()).setCreateBy(1L);
    }

}

 

application.properties

## Application
server.port=28080

## Dubbo
dubbo.application.name=dubbo-provider
dubbo.registry.address=zookeeper://47.98.151.249:2181
dubbo.protocol.name=dubbo
dubbo.protocol.port=20880
dubbo.scan.basePackages=cn.bounter

 

4. 服务消费者配置Dubbo并调用Dubbo服务

application.properties

# Application
server.port=18080

## Dubbo
dubbo.application.name=dubbo-consumer
dubbo.registry.address=zookeeper://127.0.0.1:2181
dubbo.scan=cn.bounter

 

BounterController.java

package cn.bounter.dubbo.controller;


import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.alibaba.dubbo.config.annotation.Reference;

import cn.bounter.dubbo.model.ResponseData;
import cn.bounter.dubbo.service.BounterService;

@RestController
@CrossOrigin
@RequestMapping("/api/bounter")
public class BounterController {
    
    @Reference
    private BounterService bounterService;


    @GetMapping("/{id}")
    public ResponseData<?> get(@PathVariable Long id) {
        return new ResponseData<>().success().data(bounterService.findById(id));
    }

}

 

这样当你依次启动dubbo-provider和dubbo-consumer之后,浏览器访问http://localhost:18080/api/bounter/1就可以看到效果了

需要完整代码的请移步我的Github: 
https://github.com/13babybear/bounter-springboot-dubbo

转载于:https://www.cnblogs.com/gdufs/p/9414331.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值