二、Dubbo+SpringBoot+zookeerper整合(注解方式)

2023-11-12

Git地址:https://github.com/boorZ/demo-dubbo.git

注意:Git地址上的项目与本文章有差同,请参照文章与Git。

Git地址:https://github.com/boorZ/demo-dubbo-xml

注意:Git地址上的项目与本文章有差同,请参照文章与Git。

 

项目结构(这是个父子项目)

还是解析下:

  • demo-dubbo-xml是父项目
  • dubbo-api是Service接口(如果您们要问:为什么我要把Service接口与Service实现类分开。对不起,个人喜好)
  • dubbo-provider 是服务提供者
  • dubbo-consumer 是服务消费者

父项目(demo-dubbo-xml)

pom.xml 添加如下依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-devtools</artifactId>
    <scope>runtime</scope>
</dependency>

<!-- https://mvnrepository.com/artifact/com.alibaba.boot/dubbo-spring-boot-starter -->
<dependency>
    <groupId>com.alibaba.boot</groupId>
    <artifactId>dubbo-spring-boot-starter</artifactId>
    <version>0.2.0</version>
</dependency>

<!-- https://mvnrepository.com/artifact/org.apache.curator/curator-framework -->
<dependency>
    <groupId>org.apache.curator</groupId>
    <artifactId>curator-framework</artifactId>
    <version>4.2.0</version>
</dependency>

<!-- https://mvnrepository.com/artifact/org.apache.zookeeper/zookeeper -->
<dependency>
    <groupId>org.apache.zookeeper</groupId>
    <artifactId>zookeeper</artifactId>
    <version>3.5.5</version>
    <type>pom</type>
</dependency>

<!-- 出现service为null:根本原因是导包错误,导致dubbo和springboot没有集成成功-->
<dependency>
    <groupId>io.dubbo.springboot</groupId>
    <artifactId>spring-boot-starter-dubbo</artifactId>
    <version>1.0.0</version>
</dependency>

dubbo-api所需更改:

DemoUser
public class DemoUser implements Serializable {

    private Long id;

    private String name;

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public DemoUser() {
    }

    public DemoUser(Long id, String name) {
        this.id = id;
        this.name = name;
    }
}
DemoService
public interface DemoService {

    List<DemoUser> listUser();
}

dubbo-provider所需更改:

pom.xml
<parent>
    <groupId>com.ving</groupId>
    <artifactId>demo-dubbo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
</parent>

<dependencies>
    <dependency>
        <groupId>com.example</groupId>
        <artifactId>dubbo-api</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <scope>compile</scope>
    </dependency>
</dependencies>
DemoServiceImpl
import com.alibaba.dubbo.config.annotation.Service;
import com.example.dubboapi.DemoService;
import com.example.dubboapi.DemoUser;

import java.util.ArrayList;
import java.util.List;

@Service
public class DemoServiceImpl implements DemoService {
    @Override
    public List<DemoUser> listUser() {
        List<DemoUser> list = new ArrayList<>();
        list.add(new DemoUser(1L, "One - A"));
        return list;
    }
}
application.properties
spring.application.name=dubbo-provider
server.port=9091

# Dubbo 注册中心配置类

# 指定当前服务/应用的名字(同样的服务名字相同,不要和别的服务同名)
dubbo.application.name=dubbo-provider

# 指定注册中心的位置
dubbo.registry.address=zookeeper://127.0.0.1:2181

# 模块版本
dubbo.server=1.0.0

# 传输协议的名称(常见的传输协议:Dubbo、RMI、Hessain、WebService、Http)
dubbo.protocol.name=dubbo

# 用dubbo协议在20880端口暴露服务
dubbo.protocol.port=20881

# 这是你的接口和实现类的父级接口,确保springboot可以扫描到这俩就行
spring.dubbo.scan=com.example.dubboprovider
Application 就是SpringBoot的启动类 添加注解让SpringBoot启动时读取Dubbo配置文件
import com.alibaba.dubbo.config.spring.context.annotation.EnableDubbo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@EnableDubbo
@SpringBootApplication
public class DubboProviderApplication {

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

}

dubbo-consumer所需更改:

pom.xml
<parent>
    <groupId>com.ving</groupId>
    <artifactId>demo-dubbo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
</parent>

<dependencies>
    <dependency>
        <groupId>com.example</groupId>
        <artifactId>dubbo-api</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <scope>compile</scope>
    </dependency>
</dependencies>
DemoController

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

import java.util.List;

@RestController
public class DemoController {

    @Reference
    private DemoService service;

    @RequestMapping("/hello")
    public List<DemoUser> hello() {
        return service.listUser();
    }
}
application.properties
spring.application.name=dubbo-consumer
server.port=9001

# Dubbo 注册中心配置类

# 指定当前服务/应用的名字(同样的服务名字相同,不要和别的服务同名)
dubbo.application.name=dubbo-consumer

# 指定注册中心的位置
dubbo.registry.address=zookeeper://127.0.0.1:2181

# 模块版本
dubbo.server=1.0.0

# 传输协议的名称(常见的传输协议:Dubbo、RMI、Hessain、WebService、Http)
dubbo.protocol.name = dubbo

# 用dubbo协议在20880端口暴露服务
#dubbo.protocol.port = 20880

Application 就是SpringBoot的启动类 添加注解让SpringBoot启动时读取Dubbo配置文件
import com.alibaba.dubbo.config.spring.context.annotation.EnableDubbo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@EnableDubbo
@SpringBootApplication
public class DubboConsumerApplication {

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

}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

二、Dubbo+SpringBoot+zookeerper整合(注解方式) 的相关文章

随机推荐

  • 如何管理软件开发项目中,需求频繁的变更。

    在开发项目过程中 用户随时会提出一些新的需求 要求开发人员解决 这些需求的提出 有时在开发阶段中有时在开发阶段后 这种在需求分析的两个相邻子阶段中 或者在迭代周期的需求分析中 后一段或周期的需求分析结果与前一次不一致 我们把这种不一致称为需
  • 【项目经验】:项目中下拉框数据太多造成页面卡顿(二)

    一 项目需求 下拉框下拉列表数据是由后端返回的 而且他会变化 所以数据不是写死的而且数据量大 上一篇博客http t csdn cn sSNTa我们是用的数据懒加载的方式 这次我们使用远程搜索的方式解决这个问题 二 用到的组件方法介绍 fi
  • 思维导图使用技巧:手把手教你怎么画思维导图 #CSDN博文精选# #系统化学习# #IT技术# #知识图谱#

    大家好 我是小C 又见面啦 文章过滤器 精选大咖干货 助力学习之路 5天20篇CSDN精选博文带你掌握系统化学习方法 专栏将挑选有关 系统化学习方法 的20篇优质文章 帮助大家掌握更加科学的学习方法 在这里 你将收获 快速掌握系统化学习的理
  • C++打印日期

    题目描述 给出年分m和一年中的第n天 算出第n天是几月几号 输入描述 输入包括两个整数y 1 lt y lt 3000 n 1 lt n lt 366 输出描述 可能有多组测试数据 对于每组数据 按 yyyy mm dd的格式将输入中对应的
  • 【数据结构】二叉搜索树

    二叉搜索树的概念 二叉搜索树又称为二叉排序树 它或者是一棵空树 或者是具有以下性质的二叉树 若它的左子树不为空 则左子树上所有结点的值都小于根结点的值 若它的右子树不为空 则右子树上所有结点的值都大于根结点的值 它的左右子树也分别是二叉搜索
  • windows-cmd下添加、删除和修改静态路由

    1 添加一条路由表 route add 192 168 20 0 mask 255 255 255 0 192 168 4 1 metric 2 if 2 命令说明 添加一条路由记录 所有到192 168 20 0 24网段的数据包 都通过
  • 【计算机网络系列】数据链路层①:数据链路层的三个基本问题(封装成帧、透明传输和差错检测)

    数据链路层最重要的内容是 数据链路层的点对点信道和广播信道的特点 以及这两种信道所使用的协议 PPP协议以及CSMA CD协议 的特点 数据链路层的三个基本问题 封装成帧 透明传输和差错检测 以太网MAC层的硬件地址 适配器 转发器 集线器
  • oracle无法减小列长度,中国港湾扩展表单分配时调整字段后保存时报错,无法正常维护表单定义...

    版本号 7 0 4 业务场景 如下 中国港湾扩展表单分配时调整字段后保存时报错 无法正常维护表单定义 异常提示 异常信息 添加业务实体的时候出错 导致错误的应用程序或对象的名称 Genersoft Platform RuntimeADP C
  • NodeJS使用JWT

    JWT jsonwebtoken 目前最流行的跨域身份验证解决方案 在nodejs中使用 安装 npm install jsonwebtoken save 使用 1 在路由中引入 var jwt require jsonwebtoken 2
  • UML 类图

    参考地址 UML类图 简书 一 类图的属性 1 写法格式 属性 方法名 类型 2 权限符号 表示private 表示protected 表示default 也就是包权限 下划线表示static 斜体表示抽象 二 类的关系 1 泛化 Gene
  • 华为OD机试真题- 喊7的次数重排-2023年OD统一考试(B卷)

    题目描述 喊7是一个传统的聚会游戏 N个人围成一圈 按顺时针从1到N编号 编号为1的人从1开始喊数 下一个人喊的数字为上一个人的数字加1 但是当将要喊出来的数字是7的倍数或者数字本身含有7的话 不能把这个数字直接喊出来 而是要喊 过 假定玩
  • Nowcoder专项练习:操作系统(二)

    1 动态重定位分区分配算法 虽然动态分区法比固定分区法的内存利用率高 但它还是有零头 碎片 的问题 动态重定位分区分配算法与动态分区分配算法基本上相同 差别仅在于 在这种分配算法中 添加了紧凑功能 通常 在找不到足够大的空闲分区来满足用户需
  • 高频测试面试题

    测试面试题 1 软件测试的目的与原则是什么 答 目的 A 通过测试工作可以发现并修复软件当中存在的缺陷 B 可以降低同产品开发遇到的风险 C 记录软件运行过程中的一些数据 从而为决策者提供技术支持 原则 A 2 8定律 核心功能占20 非核
  • Unity3d 相机平滑的跟随角色

    C 脚本 代码如下 示例 using System Collections using System Collections Generic using UnityEngine public class CameraFollow MonoB
  • Oracle中Clob字段类型修改为Varchar2类型实例

    新建一个字段 alter table KQSERVER add temp VARCHAR2 2000 将原来字段数据赋值到新字段 update KQSERVER set temp SERVER IMG 删除原来字段 alter table
  • 【华为OD机试】按身高和体重排队【2023 B卷

    华为OD机试 真题 点这里 华为OD机试 真题考点分类 点这里 题目描述 某学校举行运动会 学生们按编号 1 2 3 n 进行标识 现需要按照身高由低到高排列 对身高相同的人 按体重由轻到重排列 对于身高体重都相同的人 维持原有的编号顺序关
  • Unity shader 笔记之迷雾效果

    先看效果图 Shader Unlit FogOfWar Properties MainTex Texture 2D white CGINCLUDE include UnityCG cginc struct appdata float4 ve
  • 各国搜索引擎大全

    找客户做seo都要用到搜索引擎 全球除了谷歌 每个国家都有自己的百度 用翻译软件翻译成当地的语言搜索可能会有惊喜 中国百度 http www baidu com等 菲律宾 Philippine http www yehey com 韩国 K
  • 【08】Nginx之负载均衡

    负载均衡的作用 1 解决服务器的高并发压力 提高应用程序的处理性能 2 提供故障转移 实现高可用 3 通过添加或减少服务器数量 增强网站的可扩展性 4 在负载均衡器上进行过滤 可以提高系统的安全性 实现方式 方式一 DNS轮询方式 域名系统
  • 二、Dubbo+SpringBoot+zookeerper整合(注解方式)

    Git地址 https github com boorZ demo dubbo git 注意 Git地址上的项目与本文章有差同 请参照文章与Git Git地址 https github com boorZ demo dubbo xml 注意