SpringBoot(三)springboot集成Dubbo——注解式配置
一、Dubbo
在SpringBoot中集成Dubbo,无需再写繁琐的xml配置文件,直接使用注解及其属性进行配置即可。
二、创建Interface、Provider、Consumer三个工程
- interface工程只需要是一个普通的maven java工程即可,provider和consumer需要是SpringBoot工程。
三、在Provider、Consumer工程的pom文件中加入依赖
- pom.xml
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--dubbo集成SpringBoot框架依赖-->
<dependency>
<groupId>com.alibaba.spring.boot</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>2.0.0</version>
</dependency>
<!--注册中心-->
<dependency>
<groupId>com.101tec</groupId>
<artifactId>zkclient</artifactId>
<version>0.11</version>
</dependency>
<!--接口工程-->
<dependency>
<groupId>cn.krain.springboot</groupId>
<artifactId>019-springboot-interface</artifactId>
<version>1.0.0</version>
</dependency>
</dependencies>
四、代码实现
- 接口工程
在接口工程中只编写每个服务的接口文件。
public interface DubboService {
String addOneData(String str); }
- 服务提供者
在provider工程中,需要实现所有接口工程中的服务接口文件。
使用com.alibaba.dubbo.config.annotation.Service
包中的注解@Service
,interfaceClass
属性用于指定接口文件类,version
为版本号,timeout
为时间限制。该注解的功能是代替了之前xml文件中的<dubbo:service interface="" version="" ref="" timeout="">
标签。
package cn.krain.springboot.service.impl;
import cn.krain.springboot.service.DubboService;
import com.alibaba.dubbo.config.annotation.Service;
import org.springframework.stereotype.Component;
@Component
@Service(interfaceClass = DubboService.class, version = "1.0.0", timeout = 15000)
//dubbo:servie interface="" version="" ref="" timeout=""
public class DubboServiceImpl implements DubboService {
@Override
public String addOneData(String str) {
return "插入成功";
}
}
- 服务消费者
消费者工程需要编写控制层类。
package cn.krain.springboot.web;
import cn.krain.springboot.service.DubboService;
import com.alibaba.dubbo.config.annotation.Reference;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class DubboController {
//dubbo:service interface="" version="" check=false
@Reference(interfaceClass = DubboService.class, version = "1.0.0", check=false)
private DubboService dubboService;
@RequestMapping(value = "/addStudent")
public @ResponseBody String add(String str){
String res = dubboService.addOneData(str);
return str+res;
}
}
- 在SpringBoot主程序Application.java中,使用@EnableDubboConfiguration注解开启Dubbo配置。
package cn.krain.springboot;
import com.alibaba.dubbo.spring.boot.annotation.EnableDubboConfiguration;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication //开启spring配置
@EnableDubboConfiguration //开启dubbo配置
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
五、启动程序
- 首先启动zookeeper。
- 启动服务提供者
- 启动服务消费者
- 发送请求