SpringBoot 整合 Dubbo&Zookeeper 实现分布式

1. 安装 Zookeeper 环境

Zookeeper 环境搭建&zk命令详解

2. 服务提供者

因为用了父工程的版本管理,所以这里没有显示版本,我把用到的版本给大家分享下。

  1. jdk 1.8
  2. springboot 1.5.8
  3. spring-boot-starter-dubbo 1.0.0

闲余之际我会把demo源码分享。

2.1 pom依赖
    <dependencies>
        
        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-webartifactId>
        dependency>

        
        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-testartifactId>
            <scope>testscope>
        dependency>
        
        <dependency>
            <groupId>org.springframework.bootgroupId>
            <artifactId>spring-boot-starter-data-jpaartifactId>
        dependency>
        
        <dependency>
            <groupId>mysqlgroupId>
            <artifactId>mysql-connector-javaartifactId>
            <version>8.0.8-dmrversion>
            <scope>compilescope>
        dependency>
        
        <dependency>
            <groupId>io.dubbo.springbootgroupId>
            <artifactId>spring-boot-starter-dubboartifactId>
        dependency>
        
        <dependency>
            <groupId>junitgroupId>
            <artifactId>junitartifactId>
            <version>4.12version>
        dependency>
        <dependency>
            <groupId>org.projectlombokgroupId>
            <artifactId>lombokartifactId>
        dependency>
    dependencies>
2.2. Service填写

大概给下项目架构:
SpringBoot 整合 Dubbo&Zookeeper 实现分布式_第1张图片
为了方便,我用的springboot data jpa做持久性框架。如果不会jpa,请先看我springboot jpa整合。
1. SchoolRepository .java

/**
 * Created by Fant.J.
 */
@Repository
public interface SchoolRepository extends JpaRepository<School,Integer> {

}
  1. SchoolService.java 略(一个正常的借口)
  2. 实现类SchoolServiceImpl .java核心代码
@Service(version = "2.0.1")
public class SchoolServiceImpl implements SchoolService {
    @Autowired
    private SchoolRepository schoolRepository;

这里的@Service注解是dubbo的注解,不是springframework下的注解。该注解就是向zk注册服务。

2.3. application.properties
server.port=9002

## Dubbo 服务提供者配置

spring.dubbo.application.name=school-server
spring.dubbo.registry.address=zookeeper://xxx.xxx.xxx.xxx:2181
spring.dubbo.protocol.name=dubbo
spring.dubbo.protocol.port=20882
spring.dubbo.scan=com.xxx.school.service

spring.datasource.url=jdbc:mysql://xxxxxxxxxx
spring.datasource.username=xxxx
spring.datasource.password=xxxx
spring.datasource.driver-class-name=com.mysql.jdbc.Driver

注意: 每一个服务都需要一个未被使用的dubbo端口 。

3. 服务消费

为了和服务提供者解耦,我们需要把Service接口类单独拿出来放到client模块里,这里不贴详细代码了。
SpringBoot 整合 Dubbo&Zookeeper 实现分布式_第2张图片

3.1 pom.xml
这里略,根据controller类里的需要来填充相关依赖
3.2 SchoolController
@RestController
@RequestMapping("/sch")
public class SchoolController {

    @Reference(version = "2.0.1")
    private SchoolService schoolService;

    @RequestMapping("/all")
    public ServerResponse getAll(){
        return schoolService.selectAll();
    }
}

注意与@Service注解的version属性值一一对应。

3.3 application.properties
## Dubbo 服务消费者配置
spring.dubbo.application.name=xxx
spring.dubbo.registry.address=zookeeper://xxxx.xxx.xxx.xxx
spring.dubbo.scan=com.xxx.web.controller

成功截图:

SpringBoot 整合 Dubbo&Zookeeper 实现分布式_第3张图片

有疑问请在下面留言。

你可能感兴趣的:(SpringBoot)