Apace dubbo学习笔记(一)

共 4520字,需浏览 10分钟

 ·

2021-10-16 21:28



Dubbo是阿里巴巴开发的一个开源的高性能、高可用、可扩展的分布式RPC调用框架,致力于提供高性能和透明化的 RPC 远程调用服务解决方案。作为阿里巴巴 SOA 服务化治理方案的核心框架,目前已进入 Apache 孵化器项目。在单体应用时,不同业务模块部署在同一个JVM 进程内,这时通过本地调用就可以解决不同业务模块之间的相互引用;但在多体应用时,不同业务模块大多部署到不同的机器上,这时一个高效、稳定的RPC框架就显得特别重要了。Apache Dubbo 作为阿里巴巴开源的分布式RPC 框架,在进入Apache 孵化器项目后现已毕业。就目前来说Dubbo是java这块做分布式服务的流行方式。加之dubbo在云原生方面的探索都是我们作为java开发者应该且必须掌握的一门编程技术。就目前来说java的rpc框架包括hession都没有像dubbo这样支持负载均衡的功能。我们知道rpc调用其实相比http这种的各种json转化方便很多,而且不用关注类似鉴权等一些操作,个人觉得或许不是最好的解决方案。诸如此,作者计划学习一下dubbo,而本次学习本着深入了解的思路,尽量发掘dubbo的的设计方式,作为学习的开始,我们还是从demo开始吧。

1.创建父工程,其pom.xml为


 <properties>        <maven.compiler.source>8maven.compiler.source>        <maven.compiler.target>8maven.compiler.target>        <my.version>2.7.6my.version>        <api.version>1.0api.version>        <web.version>2.3.3.RELEASEweb.version>        <project.build.sourceEncoding>UTF-8project.build.sourceEncoding>    properties>
<dependencyManagement> <dependencies>
<dependency> <groupId>org.springframework.bootgroupId> <artifactId>spring-boot-starter-webartifactId> <version>${web.version}version> dependency>
<dependency> <groupId>org.apache.dubbogroupId> <artifactId>dubbo-spring-boot-starterartifactId> <version>${my.version}version> dependency>
<dependency> <groupId>org.apache.dubbogroupId> <artifactId>dubbo-dependencies-zookeeperartifactId> <type>pomtype> <version>${my.version}version> dependency>
<dependency> <groupId>com.scaffold.learngroupId> <artifactId>my-apiartifactId> <version>${api.version}version> dependency>

dependencies> dependencyManagement>

               

2.创建my-api项目。


public class Entity implements Serializable {

private String name;

private int age;

public String getName() { return name; }

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

public int getAge() { return age; }

public void setAge(int age) { this.age = age; }

@Override public String toString() { return "Entity{" + "name='" + name + '\'' + ", age=" + age + '}'; }}

创建rpc接口


public interface ShowApi {

Entity show(String name, int age);}


创建服务提供者

主要的pom.xml

                        org.springframework.boot            spring-boot-starter-web            2.3.3.RELEASE        
org.apache.dubbo dubbo-spring-boot-starter
org.apache.dubbo dubbo-dependencies-zookeeper pom
com.scaffold.learn my-api

服务提供者实现接口



import com.scaffold.learn.api.ShowApi;import com.scaffold.learn.api.entity.Entity;import org.apache.dubbo.config.annotation.Service;

@Servicepublic class ShowProvider implements ShowApi { @Override public Entity show(String name, int age) { System.out.println("request\tname="+name+"\tage="+age); Entity entity=new Entity(); entity.setName("dubbo-"+name); entity.setAge(age+1); return entity; }}

启动函数


@SpringBootApplicationpublic class ProviderService {

public static void main(String[] args) {

SpringApplication.run(ProviderService.class,args); }}

相关配置文件


server.port=8333dubbo.scan.base-packages=com.scaffold.learn.providerdubbo.application.name=dubbo-providerdubbo.protocol.name=dubbo## Random portdubbo.protocol.port=-1## Dubbo Registrydubbo.registry.address=zookeeper://127.0.0.1:2181


3.服务消费者pom.xml文件       

                        org.springframework.boot            spring-boot-starter-web            2.3.3.RELEASE        
org.apache.dubbo dubbo-spring-boot-starter
org.apache.dubbo dubbo-dependencies-zookeeper pom
com.scaffold.learn my-api

对外接口:


@RestControllerpublic class Api {

@Reference private ShowApi showApi;

@GetMapping(value = "/test") public String testDubbo(){ Entity entity = showApi.show("tianjingle",1); System.out.println(entity.toString()); return entity.toString(); }}


启动函数


@SpringBootApplicationpublic class ConsumerService {

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

配置文件


server.port=8334

spring.application.name=consumer#dubbo.scan.base-packages=com.scaffold.learn.consumerembedded.zookeeper.port=2181## Dubbo Registrydubbo.registry.address= zookeeper://127.0.0.1:${embedded.zookeeper.port}


4.启动zookeeper

5.启动服务提供者和消费者

在浏览器访问服务消费者接口

http://localhost:8334/test


以上demo我们采用apache dubbo来整合springboot,整个过程比较简单,要注意的是我们仅仅在配置文件中配置了dubbo的相关配置,项目就成功启动了。而在spirngboot中类似这种的自动化的配置,其实依靠的spring.factories这个文件,我们大概找一下就在这里,也就是说dubbo-spring-boot这个包自动的将我们需要暴露的rpc接口和rpc接口的依赖暴露或者注入进来,同时dubbo对于自动化配置解析也是这块做的。

我们学习dubbo本质上是为了更好的工作,了解dubbo中的一些特点和预留接口或许能够让解决很多未来潜在的业务难题,本次文章分享到这里。
午安~

浏览 34
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报