分布式Spring boot+Dubbo+Zookeeper(分布式入门之篇)

文章中心思想概括:

模拟两个Springboot程序,当其中一个程序(消费者)需要使用到另一个程序(服务提供者)得相关接口该如何解决?此处Dubbo和Zookeeper起到得作用时注册中心(注册容器的作用)!服务提供者只需要将自己提供的服务在注册中心注册就可以了,当消费者需要时,只需要在注册中心取就可以了。(案例操作实例见下文)

RPC

什么叫RPC呢?RPC是分布式服务框架,【Remote Procedure Call】是指远程过程调用,是一种进程间通信方式,他是一种技术的思想,而不是规范。它允许程序调用另一个地址空间(通常是共享网络的另一台机器上)的过程或函数,而不用程序员显式编码这个远程调用的细节。即程序员无论是调用本地的还是远程的函数,本质上编写的调用代码基本相同。
也就是说两台服务器A,B,一个应用部署在A服务器上,想要调用B服务器上应用提供的函数/方法,由于不在一个内存空间,不能直接调用,需要通过网络来表达调用的语义和传达调用的数据。为什么要用RPC呢?就是无法在一个进程内,甚至一个计算机内通过本地调用的方式完成的需求,比如不同的系统间的通讯,甚至不同的组织间的通讯,由于计算能力需要横向扩展,需要在多台机器组成的集群上部署应用。RPC就是要像调用本地的函数一样去调远程函数;

Dubbo与Zookeeper的介绍

认识Dubbo
Dubbo官网链接:http://dubbo.apache.org/zh-cn/
Dubbo学习文档链接:http://dubbo.apache.org/zh-cn/docs/user/quick-start.html
Dubbo是一款高性能、轻量级的开源Java RPC框架,它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现。
Dubbo官网有一个很经典的图,让我们进一步了解Dubbo的架构
分布式Spring boot+Dubbo+Zookeeper(分布式入门之篇)_第1张图片
这个简单的案例也只是集成了Springboot实现了一个生产者注册与消费者拿取得功能。
Zookeeper :ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务
,我们主要是使用Zookeeper注册中心。
什么是zookeeper呢?可以查看官方文档
相关概念都不是最重要,我们直接看它的使用吧!

  1. 下载zookeeper,地址:http://mirror.bit.edu.cn/apache/zookeeper/zookeeper-3.4.14/,然后解压。
  2. 解压后在配置zoo.cfg文件,将conf文件夹下面的zoo_sample.cfg复制一份改名为zoo.cfg即可。其他的一些配置介绍:dataDir=./ 临时数据存储的目录(可写相对路径), clientPort=2181 zookeeper的端口号
  3. 运行/bin/zkServer.cmd ,

Dubbo-admin应用 [这个可有可无]

Dubbo-admin只是一个用Springboot写的监控服务程序,这个仅是官方提供了一个可视化的监控程序dubbo-admin,不过这个监控即使不装也不影响使用。
相关使用

  1. 下载dubbo-admin,地址:https://github.com/apache/dubbo-admin/tree/master
  2. 修改 dubbo-admin\src\main\resources \application.properties 指定zookeeper地址
server.port=7001
spring.velocity.cache=false
spring.velocity.charset=UTF-8
spring.velocity.layout-url=/templates/default.vm
spring.messages.fallback-to-system-locale=false
spring.messages.basename=i18n/message
spring.root.password=root
spring.guest.password=guest

dubbo.registry.address=zookeeper://127.0.0.1:2181
  1. 在项目目录下打包dubbo-admin
mvn clean package -Dmaven.test.skip=true
  1. 执行 dubbo-admin\target 下的dubbo-admin-0.0.1-SNAPSHOT.jar
java -jar dubbo-admin-0.0.1-SNAPSHOT.jar
  1. 打开zookeeper服务。再执行jar包,然后可以访问:http://localhost:7001/,输入账号root,密码root,登录成功后即可查看到相关界面。

服务注册与发现(项目案例)

  1. 创建两个Springboot项目,一个为服务提供者,一个为服务消费者:
    分布式Spring boot+Dubbo+Zookeeper(分布式入门之篇)_第2张图片

服务提供者

  1. pom文件相关依赖(版本所有都和下面一样的话,不太容易出错)
<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.2.1.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.kuang</groupId>
    <artifactId>provider-server</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>provider-server</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

        <!--导入dubbo和Zookeeper-->
        <!-- Dubbo Spring Boot Starter -->
        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo-spring-boot-starter</artifactId>
            <version>2.7.3</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.github.sgroschupf/zkclient -->
        <dependency>
            <groupId>com.github.sgroschupf</groupId>
            <artifactId>zkclient</artifactId>
            <version>0.1</version>
        </dependency>
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-framework</artifactId>
            <version>2.12.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-recipes</artifactId>
            <version>2.12.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.4.14</version>
            <!--排除这个slf4j-log4j12-->
            <exclusions>
                <exclusion>
                    <groupId>org.slf4j</groupId>
                    <artifactId>slf4j-log4j12</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

  1. application.properties配置文件
server.port=8001
#当前应用名字
dubbo.application.name=provider-server
#注册中心地址
dubbo.registry.address=zookeeper://127.0.0.1:2181
#扫描指定包下服务
dubbo.scan.base-packages=com.kuang.service
  1. 定义一个服务接口
package com.kuang.service;
//包名也需要留意
public interface TicketService {
    String getTicket();
}

  1. 定义一个服务接口实现类
package com.kuang.service;
//包名也需要留意
import org.apache.dubbo.config.annotation.Service;
import org.springframework.stereotype.Component;

@Service   //这个注解是dubbo包下的,并不是Spring包下
// 可以被扫描到,在项目一启动就自动注册到注册中心
@Component    //这个注解是Spring包下的
public class TicketServiceImpl implements TicketService {
    @Override
    public String getTicket() {
        return "买到了一张票";
    }
}

服务消费者

  1. pom文件相关依赖(版本所有都和下面一样的话,不太容易出错)
<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.2.1.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.kuang</groupId>
    <artifactId>comsumer-server</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>comsumer-server</name>
    <description>Demo project for Spring Boot</description>

    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <!--导入dubbo和Zookeeper-->
        <!-- Dubbo Spring Boot Starter -->
        <dependency>
            <groupId>org.apache.dubbo</groupId>
            <artifactId>dubbo-spring-boot-starter</artifactId>
            <version>2.7.3</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.github.sgroschupf/zkclient -->
        <dependency>
            <groupId>com.github.sgroschupf</groupId>
            <artifactId>zkclient</artifactId>
            <version>0.1</version>
        </dependency>
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-framework</artifactId>
            <version>2.12.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-recipes</artifactId>
            <version>2.12.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.4.14</version>
            <!--排除这个slf4j-log4j12-->
            <exclusions>
                <exclusion>
                    <groupId>org.slf4j</groupId>
                    <artifactId>slf4j-log4j12</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

  1. application.properties配置文件
server.port=8002
#当前应用名字
dubbo.application.name=consumer-server
#注册中心地址
dubbo.registry.address=zookeeper://127.0.0.1:2181
  1. 定义消费接口
package com.kuang.service;

import org.apache.dubbo.config.annotation.Reference;
import org.springframework.stereotype.Service;

@Service //这个只是放到容器中,供测试使用
public class UserService {

    //想拿到provider-service提供的票,需要取注册中心拿
    @Reference //dubbo的注解,引用,
    //下面的接口都没有定义怎么样在本项目中拿到呢?1.引入pom坐标。2.可以定义路径相同的接口名
    TicketService ticketService;
    public void buyTicket(){
        String ticket = ticketService.getTicket();
        System.out.println(ticket);
    }
}
  1. 定义相同的接口名(只需要接口相同,服务(即实现类不需要相同),这是因为它往注册中心注册时注册的就是接口。
package com.kuang.service;

public interface TicketService {
    String getTicket();
}

  1. 书写测试类
package com.kuang;

import com.kuang.service.UserService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

@SpringBootTest
class ComsumerServerApplicationTests {
    @Autowired
    UserService userService;

    @Test
    void contextLoads() {
        userService.buyTicket();
    }
}

运行

  1. 首先需要跑zookeeper的客户端(不然容器都没有开,往哪里注册呢),即:运行/bin/zkServer.cmd
  2. 启动两个springboot项目。
  3. 运行测试类得到结果。

博客总结于:狂神说Java视频。B站地址:https://space.bilibili.com/95256449

你可能感兴趣的:(微服务架构与分布式,java,spring,分布式,spring,boot,zookeeper)