SpringBoot(三)springboot集成Dubbo——注解式配置

一、Dubbo

  dubbo初体验,小白级入门案例

  在SpringBoot中集成Dubbo,无需再写繁琐的xml配置文件,直接使用注解及其属性进行配置即可。

二、创建Interface、Provider、Consumer三个工程

  • interface工程只需要是一个普通的maven java工程即可,provider和consumer需要是SpringBoot工程。

在这里插入图片描述

三、在Provider、Consumer工程的pom文件中加入依赖

  • pom.xml
<dependencies>
    <dependency>
        <groupId>org.springframework.bootgroupId>
        <artifactId>spring-boot-starter-webartifactId>
    dependency>

    
    <dependency>
        <groupId>com.alibaba.spring.bootgroupId>
        <artifactId>dubbo-spring-boot-starterartifactId>
        <version>2.0.0version>
    dependency>

    
    <dependency>
        <groupId>com.101tecgroupId>
        <artifactId>zkclientartifactId>
        <version>0.11version>
    dependency>

    
    <dependency>
        <groupId>cn.krain.springbootgroupId>
        <artifactId>019-springboot-interfaceartifactId>
        <version>1.0.0version>
    dependency>
dependencies>

四、代码实现

  • 接口工程

  在接口工程中只编写每个服务的接口文件。

public interface DubboService {
         String addOneData(String str);		}
  • 服务提供者

  在provider工程中,需要实现所有接口工程中的服务接口文件。

  使用com.alibaba.dubbo.config.annotation.Service包中的注解@ServiceinterfaceClass属性用于指定接口文件类,version为版本号,timeout为时间限制。该注解的功能是代替了之前xml文件中的标签。

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。

SpringBoot(三)springboot集成Dubbo——注解式配置_第1张图片

  • 启动服务提供者
  • 启动服务消费者
  • 发送请求
    SpringBoot(三)springboot集成Dubbo——注解式配置_第2张图片

你可能感兴趣的:(Spring,Boot,java,spring,boot,spring)