springboot集成dubbo的配置(dubbo项目如何部署)

1.Dubbo框架Dubbo框架是一个高性能、重量轻、基于java的RPC框架。Dubbo提供了三个关键功能,包括基于接口的远程调用、容错和负载平衡,以及自动服务注册和发现。Dubbo可以和Spring框架无缝集成。官方的Dubbo框架如下图所示:其核心部分包含:1.远程通讯:提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。2.集群容错:提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡…

大家好,又见面了,我是你们的朋友全栈君。

1. Dubbo框架

         Dubbo框架是一个高性能、重量轻、基于java的RPC框架。Dubbo提供了三个关键功能,包括基于接口的远程调用、容错和负载平衡,以及自动服务注册和发现。Dubbo可以和Spring框架无缝集成。官方的Dubbo框架如下图所示:

springboot集成dubbo的配置(dubbo项目如何部署)

        其核心部分包含:

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

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

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

        Dubbo能做什么?

1.透明化的远程方法调用,就像调用本地方法一样调用远程方法,只需简单配置,没有任何API侵入。      

2.软负载均衡及容错机制,可在内网替代F5等硬件负载均衡器,降低成本,减少单点。

3. 服务自动注册与发现,不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的IP地址,并且能够平滑添加或删除服务提供者。

        Dubbo的存在简单来说就是要减小service层的压力。由于Dubbo使用zookeeper作为服务注册中心,所以先需要在自己本地安装好zookeeper的环境,具体安装方式参考zookeepr的官方文档:https://zookeeper.apache.org/。安装完毕后,启动zookeepr服务。zoo.cfg的配置文件如下:

tickTime=2000
initLimit=10
syncLimit=5
dataDir=D:\server\apache-zookeeper-3.6.1\data 
clientPort=2181

2.搭建SpringBoot和Dubbo项目

首先基于maven工具创建一个空的项目,pom.xml依赖文件如下:

<?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>com.chenpeng</groupId>
    <artifactId>dubbo</artifactId>
    <packaging>pom</packaging>
    <version>1.0-SNAPSHOT</version>
    <modules>
        <module>dubbo-demo-api</module>
        <module>dubbo-demo-provider</module>
        <module>dubbo-demo-customer</module>
    </modules>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.3.RELEASE</version>
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <zookeeper.version>3.4.13</zookeeper.version>
        <dubbo.starter.version>0.2.0</dubbo.starter.version>
    </properties>


    <dependencies>

        <dependency>
            <groupId>com.alibaba.boot</groupId>
            <artifactId>dubbo-spring-boot-starter</artifactId>
            <version>${dubbo.starter.version}</version>
        </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>org.apache.zookeeper</groupId>
            <artifactId>zookeeper</artifactId>
            <version>${zookeeper.version}</version>
        </dependency>


    </dependencies>

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


</project>

接着在根项目录下创建三个子maven项目模块:

  • dubbo-demo-api
  • dubbo-demo-customer
  • dubbo-demo-provider

springboot集成dubbo的配置(dubbo项目如何部署)

 在dubbo-demo-api 项目中创建测试的接口,添加sayHello方法,创建的DemoService.java文件具体内容如下:

package com.chenpeng.dubbo;

/**
 * @Author: chenpeng
 * @Datetime: 2020/7/12 15:33
 * @Version: V1.0
 */
public interface DemoService {
    String sayHello(String name);
}

 dubbo-demo-provider(提供者)项目中实现DemoService接口,创建DemoServiceImpl.java的文件内容如下:

package com.chenpeng.dubbo.provider;

import com.alibaba.dubbo.config.annotation.Service;
import com.chenpeng.dubbo.DemoService;
import org.springframework.stereotype.Component;

/**
 * @Author: chenpeng
 * @Datetime: 2020/7/12 16:24
 * @Version: V1.0
 */
@Service
@Component
public class DemoServiceImpl implements DemoService {
    public String sayHello(String name) {
        return "Hello " + name;
    }
}

在 dubbo-demo-customer(消费者)项目中调用DemoService中的sayHello接口方法,创建Controller,HelloController.java:

package com.chenpeng.dubbo.controller;

import com.alibaba.dubbo.config.annotation.Reference;
import com.chenpeng.dubbo.DemoService;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @Author: chenpeng
 * @Datetime: 2020/7/12 16:58
 * @Version: V1.0
 */
@RestController
public class HelloController {

    @Reference
    private DemoService demoService;


    @RequestMapping(value = "/hello")
    public String hello() {
        String hello = demoService.sayHello("xiaopeng");
        System.out.println(demoService.sayHello("JUST"));
        return hello;
    }
}

在 dubbo-demo-provide 中添加项目的启动类DemoApplication.java如下:

package com.chenpeng.dubbo;

import com.alibaba.dubbo.config.spring.context.annotation.EnableDubbo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
 * 服务提供者
 *
 * @Author: chenpeng
 * @Datetime: 2020/7/12 16:40
 * @Version: V1.0
 */
@EnableDubbo
@SpringBootApplication
public class DemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }
}

其次添加Dubbo服务注册的配置,resource/application.yml文件内容如下:

server:
  port: 9011


spring:
  application:
    name: spring-boot-dubbo-provider

dubbo:
  application:
    name: spring-boot-dubbo-provider
  protocol:
    name: dubbo
    port: 20880
  registry:
    address: zookeeper://127.0.0.1:2181


 同理,在 服务消费者dubbo-demo-customer 项目中添加服务的注册配置resource/application.yml:,以及消费者启动类CustomerApplication:

CustomerApplication.java文件具体内容如下:

package com.chenpeng.dubbo;

import com.alibaba.dubbo.config.spring.context.annotation.EnableDubbo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
 * 消费者
 *
 * @Author: chenpeng
 * @Datetime: 2020/7/12 17:00
 * @Version: V1.0
 */
@EnableDubbo
@SpringBootApplication
public class CustomerApplication {

    public static void main(String[] args) {
        SpringApplication.run(CustomerApplication.class, args);
    }
}

resource/application.yml配置:

server:
  port: 9021


spring:
  application:
    name: springboot-dubbo-consumer

dubbo:
  application:
    name: springboot-dubbo-consumer
  registry:
    address: zookeeper://127.0.0.1:2181
  consumer:
    timeout: 5000

在 dubbo-demo-customer服务消费者项目中创建controller接口实现对外功能的暴露,HelloController.java:

package com.chenpeng.dubbo.controller;

import com.alibaba.dubbo.config.annotation.Reference;
import com.chenpeng.dubbo.DemoService;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @Author: chenpeng
 * @Datetime: 2020/7/12 16:58
 * @Version: V1.0
 */
@RestController
public class HelloController {

    @Reference
    private DemoService demoService;


    @RequestMapping(value = "/hello")
    public String hello() {
        String hello = demoService.sayHello("xiaopeng");
        System.out.println(demoService.sayHello("JUST"));
        return hello;
    }
}

整体的项目文件结构的截图如下:

springboot集成dubbo的配置(dubbo项目如何部署)

最后一步,就是分别启动服务提供者和服务消费者两个项目(注意启动顺序),然后浏览器访问http://localhost:9021/hello

springboot集成dubbo的配置(dubbo项目如何部署)

3.使用dubbo-admin框架

        Dubbo-2.6.1之后的版本中不在集成dubbo-admin,需要单独的安装下载配置,本实验中采用了从github上下载源代码,然后通过maven打包安装成jar包,最终通过直接运行jar包来启动dubbo-admin端。与上一节的步骤的前提条件一样,需要本地配置安装好zookeepr服务。

 

dubbo-admin的安装部署具体如下:

1. 下载源代码 git clone https://github.com/apache/dubbo-admin.git

2. 然后配置zookeeper服务的地址(如果需要修改) dubbo-admin-server/src/main/resources/application.properties

3. 接着运行 mvn install -D maven.test.skip=true 进行安装,在目录 dubbo-admin-server/target 中会生成jar包。

springboot集成dubbo的配置(dubbo项目如何部署)

springboot集成dubbo的配置(dubbo项目如何部署)

 

4. cmd命令到该目录下,运行 java -jar xxxx.jar –server.port=9999 , 后面所携带的参数是为了修改默认的端口,防止默认的8080端口被占用。

5. 访问:http://localhost:9999/,页面最终的效果如下:

springboot集成dubbo的配置(dubbo项目如何部署)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/128156.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月16日 上午10:00
下一篇 2022年4月16日 上午10:00


相关推荐

  • Stream流和Lambda表达式遍历HashMap

    Stream流和Lambda表达式遍历HashMap

    2021年7月13日
    168
  • 浮点数加减法运算(对阶、尾数求和、规格化、舍入、溢出判断)

    浮点数加减法运算(对阶、尾数求和、规格化、舍入、溢出判断)浮点数的加减法运算前言 运算过程 对阶 尾数求和 规格化 舍入 溢出判断浮点加减运算在计算机中 加减法运算用补码实现 算术运算的常识 两个浮点数如果要进行加减法运算 它们的阶或者指数必须相等 一 对阶求阶差如果把阶码大的向阶码小的看齐 就要把阶码大的数的尾数部分左移 阶码减小 这个操作有可能在移位过程中把尾数的高位部分移掉 这样就引发了数据的错误 所以 尾数左移在计算机运算中不可取 如果把阶码小的向阶码大的看齐 在移位过程中如果发生数据丢失 也是最右边的数据位发生丢失 最右边的数据

    2026年3月19日
    2
  • H3C交换机配置命令大全【转载】[通俗易懂]

    H3C交换机配置命令大全【转载】[通俗易懂]杭州华三通信技术有限公司(简称H3C),致力于IP技术与产品的研究、开发、生产、销售及服务。H3C不但拥有全线路由器和以太网交换机产品,还在网络安全、IP存储、IP监控、语音视讯、WLAN、SOHO及软件管理系统等领域稳健成长。在以太网领域,H3C经历多年的耕耘和发展,积累了大量业界领先的知识产权和专利,可提供业界从核心到接入10多个系列上百款交换机产品。所有产品全部运行H3C自主知识产权的…

    2022年6月20日
    33
  • 精读5G:关于5G的NSA和SA,看完秒懂!

    精读5G:关于5G的NSA和SA,看完秒懂!关于非独立组网和独立组网 NSA 和 SA 虽然大家都听了很多次 但很少有人能真正搞懂它们到底是怎么一回事 今天 我会用最通俗易懂的语言 全面介绍一下它们俩 希望能够让大家彻底明白它们到底是怎么一回事 废话不多说 我们开始吧 在南京夫子庙 有一个做餐饮业的老板 名叫星爷 他开的店 名叫四号餐厅 餐厅的主厨 叫胖四 餐厅的生意一直很好 但是随着业务日益增加 人满为患 已经

    2026年3月18日
    3
  • matlab中的ezplot函数

    matlab中的ezplot函数随时随地阅读更多技术实战干货,获取项目源码、学习资料,请关注源代码社区公众号(ydmsq666)一个容易使用的绘图函数语法ezplot(f)ezplot(f,[min,max])ezplot(f,[xmin,xmax,ymin,ymax])ezplot(x,y)ezplot(x,y,[tmin…

    2022年6月19日
    47
  • SpringCloud 之 Zuul 网关搭建及配置

    点击上方“全栈程序员社区”,星标公众号 重磅干货,第一时间送达 作者:Anakki blog.csdn.net/qq_29519041/article/details/103654…

    2021年6月27日
    82

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号