千家信息网

dubbo及demo实例分析

发表于:2025-01-29 作者:千家信息网编辑
千家信息网最后更新 2025年01月29日,这篇文章主要介绍"dubbo及demo实例分析"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"dubbo及demo实例分析"文章能帮助大家解决问题。1. Dub
千家信息网最后更新 2025年01月29日dubbo及demo实例分析

这篇文章主要介绍"dubbo及demo实例分析"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"dubbo及demo实例分析"文章能帮助大家解决问题。

1. Dubbo是什么?

Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。简单的说,dubbo就是个服务框架,如果没有分布式的需求,其实是不需要用的,只有在分布式的时候,才有dubbo这样的分布式服务框架的需求,并且本质上是个服务调用的东东,说白了就是个远程服务调用的分布式框架(告别Web Service模式中的WSdl,以服务者与消费者的方式在dubbo上注册)
其核心部分包含:
1. 远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及"请求-响应"模式的信息交换方式。
2. 集群容错: 提供基于接口方法的透明远程过程调用,包括多协议支持,以及软负载均衡,失败容错,地址路由,动态配置等集群支持。
3. 自动发现: 基于注册中心目录服务,使服务消费方能动态的查找服务提供方,使地址透明,使服务提供方可以平滑增加或减少机器。

2. Dubbo能做什么?

1.透明化的远程方法调用,就像调用本地方法一样调用远程方法,只需简单配置,没有任何API侵入。
2.软负载均衡及容错机制,可在内网替代F5等硬件负载均衡器,降低成本,减少单点。
3. 服务自动注册与发现,不再需要写死服务提供方地址,注册中心基于接口名查询服务提供者的IP地址,并且能够平滑添加或删除服务提供者。

Dubbo采用全spring配置方式,透明化接入应用,对应用没有任何API侵入,只需用Spring加载Dubbo的配置即可,Dubbo基于Spring的Schema扩展进行加载。
之前使用Web Service,我想测试接口可以通过模拟消息的方式通过soapui或LR进行功能测试或性能测试。但现在使用Dubbo,接口之间不能直接交互,我尝试通过模拟消费者地址测试,结果不堪入目,再而使用jmeter通过junit进行测试,但还是需要往dubbo上去注册,如果再不给提供源代码的前提下,这个测试用例不好写啊….

3. dubbo的架构

dubbo架构图如下所示:

节点角色说明:

Provider: 暴露服务的服务提供方。
Consumer: 调用远程服务的服务消费方。
Registry: 服务注册与发现的注册中心。
Monitor: 统计服务的调用次调和调用时间的监控中心。
Container: 服务运行容器。

这点我觉得非常好,角色分明,可以根据每个节点角色的状态来确定该服务是否正常。

调用关系说明:

1. 服务容器负责启动,加载,运行服务提供者。
1. 服务提供者在启动时,向注册中心注册自己提供的服务。
2. 服务消费者在启动时,向注册中心订阅自己所需的服务。
3. 注册中心返回服务提供者地址列表给消费者,如果有变更,注册中心将基于长连接推送变更数据给消费者。
4. 服务消费者,从提供者地址列表中,基于软负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一台调用。
5. 服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心。

dubbo的容错性显而易见,性能方面还没有还得及测,我们系统某页面需要掉5次接口,本来想建议做个缓存,但业务关系不能采纳,还需要研究下dubbo的性能调优问题…

4. dubbo使用方法。

Dubbo采用全Spring配置方式,透明化接入应用,对应用没有任何API侵入,只需用Spring加载Dubbo的配置即可,Dubbo基于Spring的Schema扩展进行加载。如果不想使用Spring配置,而希望通过API的方式进行调用(不推荐)

下面我们就来看看spring配置方式的写法:

服务提供者:

1.下载zookeeper注册中心,下载地址:
http://www.apache.org/dyn/closer.cgi/zookeeper/ 下载后解压即可,进入D:apach-zookeeper-3.4.5in,双击zkServer.cmd启动注册中心服务。

2.定义服务接口: (该接口需单独打包,在服务提供方和消费方共享)

下面这个例子不错,写的很详细可以做个model.

package com.unj.dubbotest.provider;  import java.util.List;  public interface DemoService {      String sayHello(String name);      public List getUsers();  }

在服务提供方实现接口:(对服务消费方隐藏实现)

package com.unj.dubbotest.provider;  import java.util.ArrayList;  import java.util.LinkedList;  import java.util.List;  public class DemoServiceImpl implements DemoService{       public String sayHello(String name) {              return "Hello " + name;       }       public List getUsers() {           List list = new ArrayList();           User u1 = new User();           u1.setName("jack");           u1.setAge(20);           u1.setSex("男");           User u2 = new User();           u2.setName("tom");           u2.setAge(21);           u2.setSex("女");           User u3 = new User();           u3.setName("rose");           u3.setAge(19);           u3.setSex("女");           list.add(u1);           list.add(u2);           list.add(u3);           return list;  }

用Spring配置声明暴露服务:

                                                                       

加载Spring配置,启动服务:

package com.unj.dubbotest.provider;  import org.springframework.context.support.ClassPathXmlApplicationContext;  public class Provider {      public static void main(String[] args) throws Exception {          ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(new String[] {"applicationContext.xml"});          context.start();          System.in.read(); // 为保证服务一直开着,利用输入流的阻塞来模拟      }  }

服务消费者:

applicationContext-dubbo.xml 中注册自己需要调用的接口,我刚开始测试的时候需要的接口很多,所以把这个文件写的满满的,后来熟悉了把接口按业务类型分开,写了N多个 applicationContext-dubbo-*.xml 简练多了 。

                                              

2.加载Spring配置,并调用远程服务:

package com.alibaba.dubbo.demo.pp;  import java.util.List;  import org.springframework.context.support.ClassPathXmlApplicationContext;  import com.unj.dubbotest.provider.DemoService;  public class Consumer {      public static void main(String[] args) throws Exception {          ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext(                  new String[] { "applicationContext.xml" });          context.start();          DemoService demoService = (DemoService) context.getBean("demoService"); //          String hello = demoService.sayHello("tom"); // ?          System.out.println(hello); //           //           List list = demoService.getUsers();          if (list != null && list.size() > 0) {              for (int i = 0; i < list.size(); i++) {                  System.out.println(list.get(i));              }          }          // System.out.println(demoService.hehe());          System.in.read();      }  }

调用结果为:

dubbo管理页面:

这个管理页面还需要部署一个环境的,一开始我还以为是dubbo自带的,找了半天没有找到….

应用页面:

提供者页面:

消费者页面:

服务页面:

关于"dubbo及demo实例分析"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。

服务 消费 接口 配置 提供者 地址 消费者 方式 页面 测试 供方 方法 分布式 框架 应用 均衡 容错 实例 实例分析 分析 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 WPS文字此服务器暂时不可用 西安君悦网络技术有限公司 北京戴尔服务器维修维保哪家便宜 关于互联网和科技有什么热点 参加网络安全软件培训简报 选购服务器 知乎 网络安全性类型怎么选性 元亨服务器 公司网络安全 华为 网络安全证文350左右 mac上的数据库软件 网络安全技能价值分析 意识形态的网络安全ppt 网络安全三级难吗 数据库系统组成怎么写 阿里云服务器可以接几个域名 深圳市至京网络技术 服务器设备型号不符可否验收 网络安全宣传知识问答 河北程序软件开发价位 操作系统的上层软件开发 一年一百万能租到什么样的服务器 香肠派对的服务器为什么突然崩了 服务器日常管理做哪些 网络运营商服务器登不上 网吧服务器是什么 spyder引入数据库 数据库事务结束的方式有哪两种 奥维互动地图如何建立企业服务器 外泌体数据库大集合
0