SpringBoot~ dubbo + zookeeper实现分布式开发的应用

  1. 配置服务名字, 注册中心地址, 扫描被注册的包

server.port=8081

#当前应用名字

dubbo.application.name=provider-server

#注册中心地址

dubbo.registry.address=zookeeper://127.0.0.1:2181

#扫描指定包下服务

dubbo.scan.base-packages=com.demo.service

  1. 实现一个接口,在接口中完成需求

public interface Translate {

String translate(String str);

}

package com.demo.service;

import org.apache.dubbo.config.annotation.Service;

import org.springframework.stereotype.Component;

@Service //使用Dubbo的Service注解,告诉Dubbo这是一个服务

@Component //使用component告诉SpringBoot这是一个组件, 不使用@Service是因为zookeeper避免和zookeeper混淆

public class TranslateImpl implements Translate {

@Override

public String translate(String str) {

if (str == null) return null;

if (“pig”.equalsIgnoreCase(str)) return “猪”;

if (“dog”.equalsIgnoreCase(str)) return “狗”;

return “找不到”;

}

}

实现一个消费者


  1. 导入依赖, 和生产者的依赖是相同的

  2. 配置服务名字,注册中心地址

server.port=8082

配置zookeeper

配置服务名字

dubbo.application.name=consumer.server

配置注册中心地址

dubbo.registry.address=zookeeper://127.0.0.1:2181

  1. 本来正常步骤是需要将服务提供者的接口打包,然后用pom文件导入,我们这里使用简单的方式,直接将服务的接口拿过来,路径必须保证正确,即和服务提供者相同

在这里插入图片描述

  1. 实现获取翻译服务

package com.demo.service;

import org.apache.dubbo.config.annotation.Reference;

import org.springframework.stereotype.Service;

@Service //使用Spring的Service添加组件

public class Translation {

@Reference //远程引用指定的服务,他会按照全类名进行匹配,看谁给注册中心注册了这个全类名

private Translate translate;

public String getTranslation(String str) {

return translate.translate(str);

}

}

  1. 实现controller

@RestController

public class TranslateController {

@Autowired

Translation translation;

@RequestMapping(“/tran/{str}”)

public String tran(@PathVariable(“str”)String str) {

return translation.getTranslation(str);

}

}
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后:学习总结——MyBtis知识脑图(纯手绘xmind文档)

学完之后,若是想验收效果如何,其实最好的方法就是可自己去总结一下。比如我就会在学习完一个东西之后自己去手绘一份xmind文件的知识梳理大纲脑图,这样也可方便后续的复习,且都是自己的理解,相信随便瞟几眼就能迅速过完整个知识,脑补回来。下方即为我手绘的MyBtis知识脑图,由于是xmind文件,不好上传,所以小编将其以图片形式导出来传在此处,细节方面不是特别清晰。但可给感兴趣的朋友提供完整的MyBtis知识脑图原件(包括上方的面试解析xmind文档)

image

除此之外,前文所提及的Alibaba珍藏版mybatis手写文档以及一本小小的MyBatis源码分析文档——《MyBatis源码分析》等等相关的学习笔记文档,也皆可分享给认可的朋友!

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!
转存中…(img-OLo2aaNb-1712203612175)]

除此之外,前文所提及的Alibaba珍藏版mybatis手写文档以及一本小小的MyBatis源码分析文档——《MyBatis源码分析》等等相关的学习笔记文档,也皆可分享给认可的朋友!

《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》点击传送门即可获取!

  • 33
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot是一个开源的Java框架,用于快速构建独立的、基于Spring应用程序。它简化了Spring应用程序的配置和部署过程,并提供了许多嵌入式服务器,如Tomcat、Jetty等。Spring Boot还提供了自动配置的特性,可以根据类路径中的依赖自动配置Spring应用程序。 Dubbo是一款高性能的分布式服务框架,也是阿里巴巴开源的项目。它提供了服务治理、远程通讯和分布式调用等功能,帮助开发人员轻松构建分布式服务化的应用Zookeeper是一个开源的分布式协调服务,可以用于实现分布式应用程序的一致性和可靠性。它提供了一个类似于文件系统的层次化的命名空间,并允许开发人员注册、协调和共享各种资源,如配置信息、服务注册和发现等。 当使用Spring Boot结合DubboZookeeper时,可以构建一个高性能、可扩展和可靠的微服务架构。Spring Boot提供了便利的开发和部署方式,Dubbo提供了分布式服务框架的支持,而Zookeeper则提供了分布式协调服务。开发人员可以使用Spring Boot快速构建独立的微服务应用程序,使用Dubbo进行服务间的通信和管理,同时通过Zookeeper进行服务的注册和发现。这样的架构可以方便地实现微服务架构中的资源共享和服务治理等功能,大大简化了开发人员的负担。 综上所述,Spring Boot结合DubboZookeeper可以构建高效、可靠的微服务架构,并提供了便利的开发和部署方式,帮助开发人员构建高性能的分布式应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值