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.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包中的注解@ServiceinterfaceClass属性用于指定接口文件类,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。

  • 启动服务提供者
  • 启动服务消费者
  • 发送请求
全部评论

相关推荐

过往烟沉:我说什么来着,java就业面就是广!
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务