自己去看dubbo源码
编译Dubbo源码并测试
2014.09.24 | Comments
转http://blog.javachen.com/2014/09/24/compile-and-test-dubbo.html
Dubbo是阿里巴巴内部的SOA服务化治理方案的核心框架,每天为2000+ 个服务提供3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。Dubbo自2011年开源后,已被许多非阿里系公司使用。
1. 安装
首先从 github 下载源代码并阅读 readme.md ,参考该文档,首先下载 opensesame,并编译:
$ git clone git@github.com:alibaba/opensesame.git $ cd opensesame $ mvn install
然后,下载 dubbo 并编译:
$ git clone git@github.com:alibaba/dubbo.git $ cd dubbo $ mvn clean install -Dmaven.test.skip
编译成功之后,生成 idea 相关配置文件:
$ mvn idea:idea
接下来,将代码通过 maven 的方式导入到 idea ide 中。
2. 测试
安装之后,现在来搭一个测试环境。搭建一个测试环境,需要下面三个角色:
- 消息提供者,示例工程见:dubbo-demo-provider
- 消息注册中心,有四种类型:multicast、zookeeper、redis、dubbo
- 消息消费者,示例工程见:dubbo-demo-consumer
作为测试,这里消息注册中心使用 Multicast 注册中心,以下操作是在 idea 中运行。
首先,修改 Dubbo/dubbo-demo/dubbo-demo-provider/src/test/resources/dubbo.properties 文件如下:
dubbo.container=log4j,spring dubbo.application.name=demo-provider dubbo.application.owner= dubbo.registry.address=multicast://224.5.6.7:1234?unicast=false #dubbo.registry.address=zookeeper://127.0.0.1:2181 #dubbo.registry.address=redis://127.0.0.1:6379 #dubbo.registry.address=dubbo://10.1.19.41:20880 #dubbo.monitor.protocol=registry dubbo.protocol.name=dubbo dubbo.protocol.port=20880 dubbo.service.loadbalance=roundrobin #dubbo.log4j.file=logs/dubbo-demo-consumer.log #dubbo.log4j.level=WARN
注意:
消息提供者和消息消费者建议在不同机器上运行,如果在同一机器上,需设置 unicast=false:即:
multicast://224.5.6.7:1234?unicast=false
,否则发给消费者的单播消息可能被提供者抢占,两个消费者在同一台机器也一样,只有 multicast 注册中心有此问题。
然后,修改 Dubbo/dubbo-demo/dubbo-demo-consumer/src/test/resources/dubbo.properties 文件如下:
dubbo.container=log4j,spring dubbo.application.name=demo-consumer dubbo.application.owner= dubbo.registry.address=multicast://224.5.6.7:1234?unicast=false #dubbo.registry.address=zookeeper://127.0.0.1:2181 #dubbo.registry.address=redis://127.0.0.1:6379 #dubbo.registry.address=dubbo://10.1.19.41:20880 dubbo.monitor.protocol=registry #dubbo.log4j.file=logs/dubbo-demo-consumer.log #dubbo.log4j.level=WARN
接下来,就可以运行 dubbo-demo-provider 和 dubbo-demo-consumer 了。
在 idea 中右键运行 Dubbo/dubbo-demo/dubbo-demo-provider/src/test/java/com/alibaba/dubbo/demo/provider/DemoProvider.java 类,以启动 dubbo-demo-provider 。
在 idea 中右键运行 Dubbo/dubbo-demo/dubbo-demo-consumer/src/test/java/com/alibaba/dubbo/demo/consumer/DemoConsumer.java 类,以启动 dubbo-demo-consumer 。
最后,观察终端输出的日志,dubbo-demo-provider 中输出如下内容:
[17:13:19] Hello world458, request from consumer: /10.1.19.41:57319, cookie:iamsorry [17:13:21] Hello world459, request from consumer: /10.1.19.41:57319, cookie:iamsorry [17:13:23] Hello world460, request from consumer: /10.1.19.41:57319, cookie:iamsorry [17:13:25] Hello world461, request from consumer: /10.1.19.41:57319, cookie:iamsorry
而 dubbo-demo-consumer 中输出如下内容
[17:13:17] Hello world458, response form provider: 10.1.19.41:20880 cookie->iamsorry abc->17:13:19 Key 1->1 Key 2->2 codec->neg output->135 [17:13:20] Hello world459, response form provider: 10.1.19.41:20880 cookie->iamsorry abc->17:13:21 Key 1->1 Key 2->2 codec->neg output->135
接下来,你可以试试使用其他的消息注册方式。
使用类似的方式,你也可以启动 dubbo-admin 和 dubbo-monitor-simple,需要注意的是,如果你是在一台机器上启动这两个服务,则需要修改 dubbo.properties 中的端口以避免端口冲突。
3. 其他
简单谈谈个人对 dubbo 项目的看法:
- 项目导入到 IDE 之后,使用的是 jdk 1.5 进行编译,需要手动一个一个地修改为 1.6。
- 项目没有使用统一的 code-template ,代码风格不统一。
- 文档不够规范,缺少一些能够快速上手的用户文档。
- dubbo 是获取第一个网卡的 ip 地址,当有多个网卡或者使用 VPN 时候会存在问题。
- dubbo 依赖的 Spring 和 Netty 版本都较低
- 有些类和注解中的属性过多,显得比较臃肿,当然,这是强迫性症了。
以上仅仅代表个人意见。
自己去看dubbo源码的更多相关文章
- dubbo面试题,会这些说明你真正看懂了dubbo源码
整理了一些dubbo可能会被面试的面试题,感觉非常不错.如果你基本能回答说明你看懂了dubbo源码,对dubbo了解的足够全面.你可以尝试看能不能回答下.我们一起看下有哪些问题吧? 1.dubbo中& ...
- dubbo源码学习(四):暴露服务的过程
dubbo采用的nio异步的通信,通信协议默认为 netty,当然也可以选择 mina,grizzy.在服务端(provider)在启动时主要是开启netty监听,在zookeeper上注册服务节点, ...
- 【2020-03-28】Dubbo源码杂谈
前言 本周空闲时间利用了百分之六七十的样子.主要将Dubbo官网文档和本地代码debug结合起来学习,基本看完了服务导出.服务引入以及服务调用的过程,暂未涉及路由.字典等功能.下面对这一周的收获进行一 ...
- 从一段 Dubbo 源码到 CPU 分支预测的一次探险之旅
每个时代,都不会亏待会学习的人. 大家好,我是 yes. 这次本来是打算写一篇 RocketMQ 相关文章的,但是被插队了,我也是没想到的. 说来也是巧最近在看 Dubbo 源码,然后发现了一处很奇怪 ...
- 渣渣菜鸡为什么要看 ElasticSearch 源码?
前提 人工智能.大数据快速发展的今天,对于 TB 甚至 PB 级大数据的快速检索已然成为刚需,大型企业早已淹没在系统生成的浩瀚数据流当中.大数据技术业已集中在如何存储和处理这些海量的数据上.Elast ...
- 基于dubbo源码包通过Maven构建dubbo的详细步骤
通过Maven构建dubbo 既然可以下载得到源码以及发布包,那么为什么要去构建dubbo呢?,我们先来看下dubbo的主要模块: 我们不仅要使用dubbo的核心框架,还要使用它的一些服务,比如管理控 ...
- 深度解剖dubbo源码
-----------学习dubbo源码,能给你带来什么好处?----------- 1.提升SOA的微服务架构设计能力 通过读dubbo源码是一条非常不错的通往SOA架构设计之路,毕竟SOA的服 ...
- Dubbo源码-Dubbo是如何随心所欲自定义XML标签的
叨叨 今天考虑了很久要不要写这篇文章. 距离<Dubbo源码>系列的开篇到现在已经快两个月时间了.当时是想着工作上的RPC框架使用存在一些让人头疼的问题,就来看看Dubbo给出了一套什么样 ...
- Dubbo 源码分析 - 服务调用过程
注: 本系列文章已捐赠给 Dubbo 社区,你也可以在 Dubbo 官方文档中阅读本系列文章. 1. 简介 在前面的文章中,我们分析了 Dubbo SPI.服务导出与引入.以及集群容错方面的代码.经过 ...
随机推荐
- NSString NSCFString区别
NSString 是 NSCFString的父类 在于NSString是个class cluster,一个类簇.什么是一个类簇?简单的来说,NSString是个“工厂类”,然后它在外层提供了很多方法接 ...
- c# web 删除时弹出提示框
方法1: 在控件中增加属性 <asp:Button ID="btnSub" runat="server" Text="提交" oncl ...
- cocos2dx JAVA,C++互相调用函数
C++调用JAVA 例子 #if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID) #include "platform/android/jni/Jni ...
- SGU 220.Little Bishops(DP)
题意: 给一个n*n(n<=10)的棋盘,放上k个主教(斜走),求能放置的种类总数. Solution: 一眼看上去感觉是状压DP,发现状态太多,没办法存下来... 下面是一个十分巧妙的处理: ...
- confluence5.8.10的使用
之前在windows上安装了confluence5.8.10,结果有一天知什么缘故,数据库数据损坏,知识库彻底打不开了,所有的文档都付之东流,真的不是一般心痛.因此考虑将其装到linux机器上,因为t ...
- 『重构--改善既有代码的设计』读书笔记----Move Field
在类与类之间搬移状态和行为,是重构过程中必不可少的步骤.很有可能在你现在觉得正常的类,等你到了下个礼拜你就会觉得不合适.或者你在下个礼拜创建了一个新的类并且你需要讲现在类的部分字段和行为移动到这个新类 ...
- 利用set实现去重
最近读了一些有关于ES6的文章,觉得真是一个超级大的进步,就是不知道兼容性怎么样,鉴于我还在初学,先写个小例子练手,顺便时刻提醒自己要坚持学下去.未来的趋势肯定是替代es5没跑了. var arr=[ ...
- js 的其它运算符和优先级
三元运算符: 语法为 exp1? exp2:exp3 判断 exp1是true 和 false 如果true,则返回exp2 ,如果false ,则返回exp3 <script> if ...
- Tomcat虚拟主机配置
3.1.配置虚拟主机 配置虚似主机就是配置一个网站. 在Tomcat服务器配置一个虚拟主机(网站),需要修改conf文件夹下的server.xml这个配置文件,使用Host元素进行配置,打开serve ...
- 开发DZ插件教程
插件制作的基本思路是:(初学者适用)1.形成插件思路2.制作插件界面3.构架程序模块4.搭建存储数据5.填充功能语句6.检查应用错误7.完善插件功能 前言:为方便互联网数万Discuz!爱好者,更加深 ...