zoukankan      html  css  js  c++  java
  • Spring Boot+Dubbo 入门

    Dubbo 架构

    Dubbo 架构

    一:zookeeper 环境安装搭建

    1、搭建 zookeeper 之前要确保当前的机器已经有 JDK 环境。

    2、将 conf 目录下 zoo_sample.cfg 文件重命名为 zoo.cfg

    二 :实现服务接口 dubbo-interface

    主要分为下面几步:

    1. 创建 Maven 项目;
    2. 创建接口类
    3. 将项目打成 jar 包供其他项目使用

    项目结构:

    dubbo-interface项目结构

    dubbo-interface 后面被打成 jar 包,它的作用只是提供接口。

    1. dubbo-interface 项目创建

    File->New->Module... ,然后选择 Maven类型的项目,其他的按照提示一步一步走就好。

    第一步

    第二步

    2. 创建接口类

    package com.fengx.service;
    
    /**
     * @author: Fengx
     * @date: 2021-07-21
     * @description: 服务接口
     **/
    public interface HelloService {
    
        String sayHello(String name);
    }
    

    3. 将项目打成 jar 包供其他项目使用

    点击右边的 Maven Projects 然后选择 install ,这样 jar 包就打好了。

    三 :实现服务提供者 dubbo-provider

    主要分为下面几步:

    1. 创建 springboot 项目;
    2. 加入 dubbo 、zookeeper以及接口的相关依赖 jar 包;
    3. 在 application.properties 配置文件中配置 dubbo 相关信息;
    4. 实现接口类;
    5. 服务提供者启动类编写

    项目结构:

    dubbo-provider 项目结构

    1. dubbo-provider 项目创建

    创建一个 SpringBoot 项目,注意勾选上 web 模块。

    注意勾选上 web 模块

    2. pom 文件引入相关依赖

    需要引入 dubbo 、zookeeper以及接口的相关依赖 jar 包。注意将本项目和 dubbo-interface 项目的 dependency 依赖的 groupId 和 artifactId 改成自己的。dubbo 整合spring boot 的 jar 包在这里找dubbo-spring-boot-starter。zookeeper 的 jar包在 Maven 仓库 搜索 zkclient 即可找到。

    <?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.5.2</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
        <groupId>com.fengx</groupId>
        <artifactId>dubbo-provider</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <name>dubbo-provider</name>
        <description>Demo project for Spring Boot</description>
        <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>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
            </dependency>
            <dependency>
                <groupId>com.fengx</groupId>
                <artifactId>dubbo-interface</artifactId>
                <version>1.0-SNAPSHOT</version>
            </dependency>
            <!--引入dubbo的依赖-->
            <dependency>
                <groupId>com.alibaba.spring.boot</groupId>
                <artifactId>dubbo-spring-boot-starter</artifactId>
                <version>2.0.0</version>
            </dependency>
            <!-- 引入zookeeper的依赖 -->
            <dependency>
                <groupId>com.101tec</groupId>
                <artifactId>zkclient</artifactId>
                <version>0.10</version>
            </dependency>
        </dependencies>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
        </build>
    
    </project>
    

    3. 在 application.properties 配置文件中配置 dubbo 相关信息

    配置很简单,这主要得益于 springboot 整合 dubbo 专属的@EnableDubboConfiguration 注解提供的 Dubbo 自动配置。

    # 配置端口
    server.port=8333
    
    spring.dubbo.application.name=dubbo-provider
    spring.dubbo.application.registry=zookeeper://127.0.0.1:2181
    

    4. 实现接口

    注意: @Service 注解使用的时 Dubbo 提供的而不是 Spring 提供的。另外,加了Dubbo 提供的 @Service 注解之后还需要加入

    package com.fengx.dubboprovider.service.impl;
    
    import com.alibaba.dubbo.config.annotation.Service;
    import com.fengx.service.HelloService;
    import org.springframework.stereotype.Component;
    
    /**
     * @author: Fengx
     * @date: 2021-07-21
     * @description: 服务接口实现
     **/
    @Component
    @Service
    public class HelloServiceImpl implements HelloService {
    
        @Override
        public String sayHello(String name) {
            return "Hello " + name;
        }
    }
    

    5. 服务提供者启动类编写

    注意:不要忘记加上 @EnableDubboConfiguration 注解开启Dubbo 的自动配置。

    package com.fengx.dubboprovider;
    
    import com.alibaba.dubbo.spring.boot.annotation.EnableDubboConfiguration;
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    
    /**
     * 服务提供者
     */
    @SpringBootApplication
    // 开启dubbo的自动配置
    @EnableDubboConfiguration
    public class DubboProviderApplication {
        
        public static void main(String[] args) {
            SpringApplication.run(DubboProviderApplication.class, args);
        }
    }
    

    四:实现服务消费者 dubbo-consumer

    主要分为下面几步:

    1. 创建 springboot 项目;
    2. 加入 dubbo 、zookeeper以及接口的相关依赖 jar 包;
    3. 在 application.properties 配置文件中配置 dubbo 相关信息;
    4. 编写测试类;
    5. 服务消费者启动类编写
    6. 测试效果

    项目结构:

    dubbo-consumer 项目结构

    1. dubbo-consumer 项目创建

    创建一个 SpringBoot 项目,注意勾选上 web 模块。

    注意勾选上 web 模块

    2. 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.5.2</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
        <groupId>com.fengx</groupId>
        <artifactId>dubbo-consumer</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <name>dubbo-consumer</name>
        <description>Demo project for Spring Boot</description>
        <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>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
            </dependency>
            <!--引入接口项目jar包-->
            <dependency>
                <groupId>com.fengx</groupId>
                <artifactId>dubbo-interface</artifactId>
                <version>1.0-SNAPSHOT</version>
            </dependency>
            <!--引入dubbo的依赖-->
            <dependency>
                <groupId>com.alibaba.spring.boot</groupId>
                <artifactId>dubbo-spring-boot-starter</artifactId>
                <version>2.0.0</version>
            </dependency>
            <!-- 引入zookeeper的依赖 -->
            <dependency>
                <groupId>com.101tec</groupId>
                <artifactId>zkclient</artifactId>
                <version>0.10</version>
            </dependency>
        </dependencies>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
        </build>
    
    </project>
    

    3. 在 application.properties 配置文件中配置 dubbo 相关信息

    配置很简单,这主要得益于 springboot 整合 dubbo 专属的@EnableDubboConfiguration 注解提供的 Dubbo 自动配置。

    # 配置端口
    server.port=8330
    
    spring.dubbo.application.name=dubbo-consumer
    spring.dubbo.application.registry=zookeeper://127.0.0.1:2181
    

    4. 编写一个简单 Controller 调用远程服务

    package com.fengx.dubboconsumer.controller;
    
    import com.alibaba.dubbo.config.annotation.Reference;
    import com.fengx.service.HelloService;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    /**
     * @author: Fengx
     * @date: 2021-07-21
     * @description: 调用远程服务
     **/
    @RestController
    public class HelloController {
    
        @Reference
        private HelloService helloService;
    
        @RequestMapping("/hello")
        public String hello() {
            String hello = helloService.sayHello("world");
            System.out.println(helloService.sayHello("fengx"));
            return hello;
        }
    }
    

    5. 服务消费者启动类编写

    package com.fengx.dubboconsumer;
    
    import com.alibaba.dubbo.spring.boot.annotation.EnableDubboConfiguration;
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    
    @SpringBootApplication
    @EnableDubboConfiguration
    public class DubboConsumerApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(DubboConsumerApplication.class, args);
        }
    }
    

    6. 测试效果

    浏览器访问 http://localhost:8330/hello 页面返回 Hello world,控制台输出 Hello fengx,和预期一致,使用SpringBoot+Dubbo 搭建第一个简单的分布式服务实验成功!

    参考:https://github.com/CodingDocs/springboot-guide/blob/master/docs/advanced/springboot-dubbo.md

  • 相关阅读:
    【BZOJ】1827: [Usaco2010 Mar]gather 奶牛大集会
    【BZOJ】1708: [Usaco2007 Oct]Money奶牛的硬币
    【BZOJ】1690: [Usaco2007 Dec]奶牛的旅行
    【BZOJ】1725: [Usaco2006 Nov]Corn Fields牧场的安排
    【BZOJ】1711: [Usaco2007 Open]Dining吃饭
    【BZOJ】1579: [Usaco2009 Feb]Revamping Trails 道路升级
    【BZOJ】1572: [Usaco2009 Open]工作安排Job
    【51NOD】1717 好数
    【POJ】3233 Matrix Power Series
    【BZOJ】1717: [Usaco2006 Dec]Milk Patterns 产奶的模式
  • 原文地址:https://www.cnblogs.com/fengda1/p/15191958.html
Copyright © 2011-2022 走看看