spring boot dubbo分布式案例教程(附源码)

springBoot | 2020-03-06 16:25:47

dubbo用了很多年了,整理个教程文档出来,方便自己和大家学习。

源码地址:https://github.com/houyong2011/dubboSpringBoot

一 dubbo简介

Dubbo是阿里开发的一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。简单的说,dubbo就是个服务框架,如果没有分布式的需求,其实是不需要用的,只有在分布式的时候,才有dubbo这样的分布式服务框架的需求,并且本质上是个服务调用的东东,说白了就是个远程服务调用的分布式框架(告别Web Service模式中的WSdl,以服务者与消费者的方式在dubbo上注册)

其核心部分包含:

1. 远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。

2. 集群容错: 提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。

3. 自动发现: 基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑增加或减少机器。

dubbo官网地址:http://dubbo.apache.org


二 搭建zookeeper

zookeeper的安装参考教程:linux安装zookeeper集群模式 以及单机版 linux centos安装zookeeper


三 搭建监控中心dubbo monitor sample

dubbo monitor监控中心搭建:linux dubbo monitor监控中心安装


四 服务提供方项目代码

    1 pom.xml 除了引入dubbo还有log4j-over-slf4j,因为dubbo和spring boot默认使用不同的日志系统。

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>net.itxw</groupId>
    <artifactId>dubboProvider</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>
    <name>dubboProvider</name>
    <description>Demo project for Spring Boot</description>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.4.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- dubbo -->
        <dependency>
            <groupId>io.dubbo.springboot</groupId>
            <artifactId>spring-boot-starter-dubbo</artifactId>
            <version>1.0.0</version>
        </dependency>
        <!-- log -->
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>log4j-over-slf4j</artifactId>
            <version>1.7.25</version>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

    2 application.properties 服务提供方 dubbo配置,注意zookeeper对应你安装好的zookeeper地址就好了

spring.dubbo.registry.address=zookeeper://192.168.1.10:2181
spring.dubbo.application.name=dubboProvider
spring.dubbo.scan=net.itxw.dubboProvider.service
spring.dubbo.protocol.name=dubbo
spring.dubbo.protocol.port=20881
spring.dubbo.monitor.protocol=registry


     3 service代码 服务提供方提供要给别人调用的service

        接口

/**
 * 一般API层最好单独建一个子模块,其他项目引入子模块的这个包就可以了
 */
public interface ProviderService {
    String sayHello(String message);
}

        实现(这里就要注意应用的是dubbo提供的注解了)

import com.alibaba.dubbo.config.annotation.Service;
import net.itxw.dubboProvider.api.ProviderService;
@Service(version="1.0.0")
public class ProviderServiceImpl implements ProviderService {
    @Override
    public String sayHello(String message) {
        message="你好我是服务提供方,你的消息是:"+message;
        System.out.println(message);
        return message;
    }
}


五 服务消费方项目代码

    1.pom.xml需要引入dubbo以及服务提供方的jar

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>net.itxw</groupId>
    <artifactId>dubboConsumer</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>
    <name>dubboConsumer</name>
    <description>Demo project for Spring Boot</description>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.4.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>io.dubbo.springboot</groupId>
            <artifactId>spring-boot-starter-dubbo</artifactId>
            <version>1.0.0</version>
        </dependency>
        <!-- 引入服务提供方 -->
        <dependency>
            <groupId>net.itxw</groupId>
            <artifactId>dubboProvider</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

    2.application.properties 消费方dubbo配置

server.port=8088
spring.dubbo.registry.address=zookeeper://192.168.1.10:2181
spring.dubbo.application.name=dubboConsumer
spring.dubbo.scan=net.itxw.dubboConsumer.service

    3.消费方调用代码

        接口

public interface ConsumerService {
    String sayHello(String message);
}

        实现(注意用到的dubbo的注解)

import com.alibaba.dubbo.config.annotation.Reference;
import net.itxw.dubboConsumer.api.ConsumerService;
import net.itxw.dubboProvider.api.ProviderService;
import org.springframework.stereotype.Service;
@Service
public class ConsumerServiceImpl implements ConsumerService {
    @Reference(version = "1.0.0")
    private ProviderService providerService;
    @Override
    public String sayHello(String message) {
        return providerService.sayHello(message);
    }
}

    4.写个controller测试一下效果

@RestController
@RequestMapping("/say")
public class IndexController {
    @Resource
    private ConsumerService consumerService;
    @RequestMapping("/hello")
    public String sayHello(){
        return consumerService.sayHello("我是消费者");
    }
}


六 最后测试

    分别启动服务方和消费方的项目

    1.访问下dubbo monitor 监控中心,可以看到新增的消费方和服务方

1.jpg

    2.访问下消费方项目的controller

2.jpg

ok,没问题,很成功!


登录后即可回复 登录 | 注册
    
关注编程学问公众号