微服务就是将一个完整的系统,按照不同的业务功能,拆系统分成一个个独立的子系统,在微服务结构中,每个子系统就被称为“服务”。这些子系统能够独立运行在web容器中,它们之间通过RPC方式通信。例如我们开发一个管理系统,按照微服务的思想,我们需要拆分为人事服务、办公事务服务、进销存服务等等。这一个个服务都是一个个独立的项目,可以独立运行。如果服务之间有依赖关系,那么通过RPC方式调用,RPC方式调用,我们可以采用阿里的dubbo框架。

采用RPC的优点:

1、降低系统间的耦合度,可独立开发业务模板,开发时只需启动必要的服务,其他业务服务无需启动。

2、增加代码复用性。

本项目的目录结构:生产者+消费者+公共接口

框架:springboot+dubbo+zk

第一步:创建父子结构的项目

最后的目录:comom为公共接口与实体类,myprovide为服务提供者,mycustomer为服务消费者。

dubbo微服务网关 dubbo实现微服务_spring

第二步:导入所需的公共jar,这可以在父的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.1.6.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.janion</groupId>
    <artifactId>demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>demo</name>
    <description>Demo project for Spring Boot</description>

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

    <modules>
        <!-- 服务消费者工程 -->
        <module>mycustomer</module>
        <!--  服务提供者工程-->
        <module>myprovide</module>
        <!-- 主要放实体、接口、也可以放一些公用的工具类工程-->
        <module>comom</module>
    </modules>


    <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>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <!-- MyBatis -->
        <!--<dependency>-->
            <!--<groupId>org.mybatis.spring.boot</groupId>-->
            <!--<artifactId>mybatis-spring-boot-starter</artifactId>-->
            <!--<version>1.3.1</version>-->
        <!--</dependency>-->

        <!-- Mysql -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>

        <!-- Spring Boot Dubbo 依赖 -->
        <dependency>
            <groupId>io.dubbo.springboot</groupId>
            <artifactId>spring-boot-starter-dubbo</artifactId>
            <version>1.0.0</version>
            <exclusions>
                <exclusion>     <!--此处排除掉低版本的dubbo依赖-->
                    <groupId>com.alibaba</groupId>
                    <artifactId>dubbo</artifactId>
                </exclusion>
                <exclusion>     <!--排除低版本zookeeper依赖-->
                    <groupId>com.101tec</groupId>
                    <artifactId>zkclient</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <!--dubbo-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>dubbo</artifactId>
            <version>2.6.0</version>
            <!--排除javassist防止与spring data jpa中冲突-->
            <exclusions>
                <exclusion>
                    <groupId>org.javassist</groupId>
                    <artifactId>javassist</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

        <!--zookeeper-->
        <dependency>
            <groupId>com.github.sgroschupf</groupId>
            <artifactId>zkclient</artifactId>
            <version>0.1</version>
            <exclusions>
                <exclusion>
                    <artifactId>zookeeper</artifactId>
                    <groupId>org.apache.zookeeper</groupId>
                </exclusion>
            </exclusions>
        </dependency>

        <dependency>
            <groupId>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>3.4.9</version>
            <exclusions>
                <exclusion>
                    <artifactId>slf4j-log4j12</artifactId>
                    <groupId>org.slf4j</groupId>
                </exclusion>
                <exclusion>
                    <artifactId>log4j</artifactId>
                    <groupId>log4j</groupId>
                </exclusion>
            </exclusions>
        </dependency>
        <!-- AOP -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
        </dependency>
    </dependencies>


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

</project>

第三步:配置生产者的依赖。其中dubbo启动未找到bean,需导入javasisit,否则dubbo启动会报错,未找到dubbo的相关bean文件。

<?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>
    <groupId>com.myprovide</groupId>
    <artifactId>myprovide</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>myprovide</name>
    <description>Demo project for Spring Boot</description>
    <parent>
        <groupId>com.janion</groupId>
        <artifactId>demo</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <relativePath>../pom.xml</relativePath>
    </parent>
    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>com.comom</groupId>
            <artifactId>demo</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!--dubbo啟動类未找到-->
        <dependency>
            <groupId>org.javassist</groupId>
            <artifactId>javassist</artifactId>
            <version>3.20.0-GA</version>
        </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>
    </dependencies>

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

</project>

这里的zk采用的集群的方式,可自行百度集群的搭建方式。


server:
  port : 8080
spring:
  #发布应用程序配置
  application:
    name: myprovide


  dubbo:
    application:
      name: myprovide   #提供方应用信息
    registry:
      address: zookeeper://127.0.0.1:2181?backup=127.0.0.1:2182,127.0.0.1:2183 #使用zookeeper注册中心暴露服务地址
    protocol:
      name: dubbo
      port: -1    #配置暴露服务端口 -1为随机端口
    scan: com.myprovide.myprovide.service.impl   #扫描需要暴露的服务

生产者的代码块,其中service,需引入dubbo的方法。

dubbo微服务网关 dubbo实现微服务_maven_02

好了,到目前为止dubbo生产者已经搭建完成,我们可以启动生成zk和服务检测生成者是否搭建注册成功。

服务开始注册zk

dubbo微服务网关 dubbo实现微服务_spring_03

然后我们可以进去zk去查看生产者是否注册成功,可通过cmd进行查看,进入zk的安装目录下的bin文件中,打开zkCli.cmd。

输入:ls /dubbo/com.comom.demo.service.UserService/providers,若显示一下信息,则表示注册成功,可以进行暴露服务给消费者使用了。

dubbo微服务网关 dubbo实现微服务_spring_04

第四步:配置消费者

配置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>
    <groupId>com.mycustomer</groupId>
    <artifactId>demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>demo</name>
    <description>Demo project for Spring Boot</description>
    <parent>
    <groupId>com.janion</groupId>
    <artifactId>demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <relativePath>../pom.xml</relativePath>
</parent>
    <properties>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>com.comom</groupId>
            <artifactId>demo</artifactId>
            <version>0.0.1-SNAPSHOT</version>
        </dependency>

        <dependency>
            <groupId>com.alibaba.spring</groupId>
            <artifactId>spring-context-support</artifactId>
            <version>1.0.2</version>
        </dependency>

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

        <!--dubbo啟動类未找到-->
        <dependency>
            <groupId>org.javassist</groupId>
            <artifactId>javassist</artifactId>
            <version>3.20.0-GA</version>
        </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>
    </dependencies>

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

</project>

配置yml文件

server:
  port : 8081
spring:
  application:
    name: mycustomer
  dubbo:
    application:
      name: mycustomer
    registry:
      address: zookeeper://127.0.0.1:2181?backup=127.0.0.1:2182,127.0.0.1:2183 #使用zookeeper注册中心暴露服务地址
    scan: com.mycustomer.demo.controller

好了,现在可以开始测试dubbo提供的服务了。

dubbo微服务网关 dubbo实现微服务_负载均衡_05

1、调用服务需使用@Reference,对应好服务的版本号。

对于引入服务为空指针有两种解决方式

(1)将check检测需置为false,dubbo默认为true,为true(为无提供者时检测),若为true,则消费者启动是,引入的服务无法注入显示为空指针。

 (2)在启动类上,先扫描dubbo的引用,再启动配置类

 

dubbo微服务网关 dubbo实现微服务_maven_06

到目前,代码块已全部编辑完,开始测试消费者调用生产者的功能,启动消费者,若显示一下信息,则注册成功。

dubbo微服务网关 dubbo实现微服务_其他_07

同时我们也可以通过命令查看zk:ls /dubbo/com.comom.demo.service.UserService/consumers,若显示以下信息则表示成功。

dubbo微服务网关 dubbo实现微服务_其他_08

最后接口测试:

dubbo微服务网关 dubbo实现微服务_spring_09