热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

分布式服务治理框架dubbo

Dubbo最主要功能有两个1RPC调用2SOA服务治理方案Dubbo的架构Dubbo常见的注册中心有2中,zookeeper以及redis这篇文章讲解的是采用的zoo

 

Dubbo最主要功能有两个

 1 RPC调用  

 2 SOA服务治理方案

Dubbo的架构

Dubbo常见的注册中心有2中,zookeeper以及redis

这篇文章讲解的是采用的zookeeper,要求读者对zookeeper有一定的认识。

http://www.cnblogs.com/javabigdata/p/7491116.html zookeeper相关知识看这里

服务的提供者Provider将服务注册到Registry,

消费者Consumer需要从Registry中发现、监听到服务的变动

Provider需要运行在Container容器中

Monitor(监控中心) 主要是用来对服务的调用次数统计等。

 

以下主要是一个快速入门,怎么使用dubbo

我们需要创建多个项目

Provider (服务提供者) 包括实现类 一个项目,接口定义为一个项目

Consumer (服务消费者) 一个项目

 

这里我定义一个公用的pom项目来对maven依赖做一个统一的管理

 

整体项目采用maven构建,使用dubbox (2.8.4) ,并提供源码下载

 ======================================================================

test-parent (pom项目)主要定义jar版本信息

 

======================================================================

服务提供者接口定义(所谓的发布服务,就是将接口对外暴露,生产者和消费者都是需要引用接口的,所以在这里接口将在test-facade中提供)

 

这个项目主要是定义接口

主要代码如下

@Path("/userTestService")
@Consumes({ MediaType.APPLICATION_JSON, MediaType.TEXT_XML })
@Produces({ ContentType.APPLICATION_JSON_UTF_8, ContentType.TEXT_XML_UTF_8 })
public interface IUserTestService {@GETUser getUserTest();@GET@Path("/testGet")public void testget();
}

  

注解代码说明:

  @Path:代表服务的访问路径,如“user”,则访问路径为domain:port/context/user,在方法上注解是相对类上面的。依次展开路径即可。

  @POST:服务请求的方式,支持POST、GET等。

  @Consumes:表示将接收到的数据自动转换为什么格式的,支持json和xml。

  @Produces:表示将结果返回时候输出为什么格式的,支持json和xml。

======================================================================

服务接口实现(一般来说,服务提供者我们使用注解开发)

 

部分代码如下

@Service
@com.alibaba.dubbo.config.annotation.Service(interfaceClass = com.cc.facade.IUserTestService.class, protocol = { "rest","dubbo" })
public class UserServImpl implements IUserTestService {@Overridepublic User getUserTest() {User user = new User();user.setId(1);user.setName("cc");return user;}@Overridepublic void testGet() {System.out.println("test=get");}
}

  

解释:

@com.alibaba.dubbo.config.annotation.Service 表示将该服务注册到dubbo

 

dubbo-provider.xml 文件内容如下 ,

 

 



 

======================================================================

服务消费者(一般使用xml配置)

dubbo-provider.xml配置文件如下


  

最后,我们先运行

test-service/src/test/java/ProviderTest.java   main方法,注册服务到zookeeper

 

接着运行

test-consumer/src/test/java/ConsumerTest.java main方法

可以看到控制台打印

源码下载:https://pan.baidu.com/s/1KdUDjJZdmftsdXW4iQoGZA

注意:

1导入源码的时候注意修改zookeeper地址

 

2 dubbox并没有发布到maven中央仓库的包,目前代码在github上,需要自己down下来编译,基于maven开发的。

 

   项目GitHub地址:https://github.com/dangdangdotcom/dubbox

 

 

好了,快速入门到这里就结束了,更多细节请看 dubbo官方用户手册。

http://dubbo.io/books/dubbo-user-book/ 

 

转:https://www.cnblogs.com/javabigdata/p/7565241.html



推荐阅读
  • 单点登录原理及实现方案详解
    本文详细介绍了单点登录的原理及实现方案,其中包括共享Session的方式,以及基于Redis的Session共享方案。同时,还分享了作者在应用环境中所遇到的问题和经验,希望对读者有所帮助。 ... [详细]
  • Jquery 跨域问题
    为什么80%的码农都做不了架构师?JQuery1.2后getJSON方法支持跨域读取json数据,原理是利用一个叫做jsonp的概念。当然 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 阿,里,云,物,联网,net,core,客户端,czgl,aliiotclient, ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 本文讨论了Kotlin中扩展函数的一些惯用用法以及其合理性。作者认为在某些情况下,定义扩展函数没有意义,但官方的编码约定支持这种方式。文章还介绍了在类之外定义扩展函数的具体用法,并讨论了避免使用扩展函数的边缘情况。作者提出了对于扩展函数的合理性的质疑,并给出了自己的反驳。最后,文章强调了在编写Kotlin代码时可以自由地使用扩展函数的重要性。 ... [详细]
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
  • 本文总结了在编写JS代码时,不同浏览器间的兼容性差异,并提供了相应的解决方法。其中包括阻止默认事件的代码示例和猎取兄弟节点的函数。这些方法可以帮助开发者在不同浏览器上实现一致的功能。 ... [详细]
  • 本文总结了初学者在使用dubbo设计架构过程中遇到的问题,并提供了相应的解决方法。问题包括传输字节流限制、分布式事务、序列化、多点部署、zk端口冲突、服务失败请求3次机制以及启动时检查。通过解决这些问题,初学者能够更好地理解和应用dubbo设计架构。 ... [详细]
  • ps:写的第一个,不足之处,欢迎拍砖---只是想用自己的方法一步步去实现一些框架看似高大上的小功能(比如说模型中的toArraytoJsonsetAtt ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • Android JSON基础,音视频开发进阶指南目录
    Array里面的对象数据是有序的,json字符串最外层是方括号的,方括号:[]解析jsonArray代码try{json字符串最外层是 ... [详细]
  • Android自定义控件绘图篇之Paint函数大汇总
    本文介绍了Android自定义控件绘图篇中的Paint函数大汇总,包括重置画笔、设置颜色、设置透明度、设置样式、设置宽度、设置抗锯齿等功能。通过学习这些函数,可以更好地掌握Paint的用法。 ... [详细]
author-avatar
当即和谐
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有