文档章节

dubbo2.4.11源码编译

penngo
 penngo
发布于 2015/08/20 00:23
字数 878
阅读 6747
收藏 67

本文以dubbo2.4.11源码编译和打包例

dubbo官网:http://dubbo.io/

源码:https://github.com/alibaba/dubbo

用户指南:http://dubbo.io/User+Guide-zh.htm

开发指南:http://dubbo.io/Developer+Guide-zh.htm


按官方说明2.4.X是GA稳定版本,去https://github.com/alibaba/dubbo/releases下载最新的2.4.11

解压到D:\project\dubbo\dubbo-dubbo-2.4.11

在编译dubbo前,先执行下面操作

1、opensesame依赖问题,可能会报Non-resolvable parent POM: Could not transfer artifact com.alibaba:opensesame:pom:2.0 from/to opensesame.releases (http://code.alibabatech.com/mvn/releases)

的错误。

打开https://github.com/alibaba/opensesame,下载opensesame(主要是pom.xml文件),解压在D:\project\dubbo\opensesame-master目录

在D:\project\dubbo\opensesame-master目录下,cmd命令行执行

mvn clean install -Dmaven.test.skip

编译完成后,修改D:\project\dubbo\opensesame-master\pom.xml,把版本2.0修改为1.0,

<groupId>com.alibaba</groupId>
    <artifactId>opensesame</artifactId>
	<!-- 2.0修改为1.0 -->
    <version>1.0</version> 
    <packaging>pom</packaging>

相同目录再编译一次opensesame

mvn clean install -Dmaven.test.skip


2、fastjson依赖包,可能报[ERROR] Failed to execute goal on project dubbo-common: Could not resolve dependencies for project com.alibaba:dubbo-common:jar:2.5.4-SNAPSHOT: Could not find artifact com.alibaba:fastjson:jar:1.1.8 in ibiblio.org (http://mirrors.ibiblio.org/pub/mirrors/maven2) -> [Help 1]错误

修改D:\project\dubbo\dubbo-dubbo-2.4.11\pom.xml,找到 <fastjson_version>1.1.8</fastjson_version>,将1.1.8修改为1.1.39,参考https://github.com/alibaba/dubbo/issues/22


3、注释D:\project\dubbo\dubbo-dubbo-2.4.11\pom.xml下边的内容

        <repositories>
		<repository>
			<id>opensesame.releases</id>
			<url>http://code.alibabatech.com/mvn/releases</url>
			<releases>
				<enabled>true</enabled>
			</releases>
			<snapshots>
				<enabled>false</enabled>
			</snapshots>
		</repository>
	</repositories>


4、hessian-lite依赖包,Unable to find resource 'com.alibaba:hessian-lite:jar:3.2.1-fixed-2' in repository central.repo (http://repo1.maven.org/maven2)

从github的dubbo主库中下载hessian-lite,当前最新的dubbo源码中已带有hessian-lite源码,可以直接取出来加到dubbo 2.4.11中编译(https://github.com/alibaba/dubbo,https://github.com/alibaba/dubbo/tree/master/hessian-lite)

把hessian-lite拷贝到D:\project\dubbo\dubbo-dubbo-2.4.11,

修改D:\project\dubbo\dubbo-dubbo-2.4.11\pom.xml,增加<module>hessian-lite</module>编译

<modules>
	    <!-- 增加 hessian-lite-->
	    <module>hessian-lite</module>
		
		<module>dubbo-common</module>
		<module>dubbo-container</module>
		<module>dubbo-remoting</module>
		<module>dubbo-rpc</module>
		<module>dubbo-filter</module>
		<module>dubbo-cluster</module>
		<module>dubbo-registry</module>
		<module>dubbo-monitor</module>
		<module>dubbo-config</module>
		<module>dubbo</module>
	</modules>

修改D:\project\dubbo\dubbo-2.4.11\hessian-lite\pom.xml

<parent>
        <groupId>com.alibaba</groupId>
        <artifactId>dubbo-parent</artifactId>
        <!--<version>2.5.4-SNAPSHOT</version> 把版本号改为2.4.11,需要与当前dubbo版本号一致-->
		<version>2.4.11</version>
    </parent>


5、增加编译dubbo管理控制台,这一步不是必须的,主要是官方的dubbo管理控制台下载不了,直接自己编译一个,默认下不编译打包dubbo-admin,需要自己增加。

修改D:\project\dubbo\dubbo-2.4.11\dubbo-admin\pom.xml文件,把版本号改为2.4.11

<parent>
		<groupId>com.alibaba</groupId>
		<artifactId>dubbo-parent</artifactId>
		<!-- <version>2.4.10</version> 版本号修改为2.4.11 -->
		<version>2.4.11</version>
	</parent>

修改D:\project\dubbo\dubbo-dubbo-2.4.11\pom.xml,增加<module>dubbo-admin</module>编译

<modules>
	    <module>hessian-lite</module>
		<module>dubbo-common</module>
		<module>dubbo-container</module>
		<module>dubbo-remoting</module>
		<module>dubbo-rpc</module>
		<module>dubbo-filter</module>
		<module>dubbo-cluster</module>
		<module>dubbo-registry</module>
		<module>dubbo-monitor</module>
		<module>dubbo-config</module>
		<module>dubbo</module>
		<!-- 增加编译dubbo-admin管理控制台,dubbo-simple、dubbo-demo可自行决定是否编译 -->
		<module>dubbo-admin</module>
	</modules>


6、正式编译dubbo

1)cmd命令行,在D:\project\dubbo\dubbo-dubbo-2.4.11目录下执行命令:

先设置maven内存,否则编译时会报内存不足错误

set MAVEN_OPTS=-Xmx1024m -XX:MaxPermSize=512m
mvn clean install -Dmaven.test.skip


7、添加eclipse支持

在D:\project\dubbo\dubbo-dubbo-2.4.11目录下执行命令:

mvn eclipse:eclipse

可以直接在eclipse运行下边几个程序

dubbo-demo-provider/src/test/java/com.alibaba.dubbo.demo.provider.DemoProvider

dubbo-demo-consumer/src/test/java/com.alibaba.dubbo.demo.consumer.DemoConsumer

dubbo-monitor-simple/src/test/java/com.alibaba.dubbo.monitor.simple.SimpleMonitor

dubbo-registry-simple/src/test/java/com.alibaba.dubbo.registry.simple.SimpleRegistry


8、dubbo-admin管理控制台安装

第6步执行完成后,D:\project\dubbo\dubbo-2.4.11\dubbo-admin\target目录会生成dubbo-admin-2.4.11.war,

war包解压到webapps/ROOT目录下,修改WEB-INF\dubbo.properties,

dubbo.registry.address=zookeeper://127.0.0.1:2181
dubbo.admin.root.password=root
dubbo.admin.guest.password=guest

dubbo.properties配置zookeeper的注册中心地址(zookeeper的安装配置忽略)

注意:确定zookeeper启动后再去启动tomcat。



© 著作权归作者所有

共有 人打赏支持
上一篇: dubbo使用例子
下一篇: spring与thrift集成
penngo
粉丝 79
博文 103
码字总数 59408
作品 2
广州
高级程序员
私信 提问
dubbo源码编译

本文以dubbo2.4.11源码编译和打包例 dubbo官网:http://dubbo.io/ 源码:https://github.com/alibaba/dubbo 用户指南:http://dubbo.io/User+Guide-zh.htm 开发指南:http://dubbo.io/Devel......

x163麦芽糖
2016/06/16
170
0
阿里巴巴分布式服务框架Dubbo使用简易教程

Dubbo是什么? Dubbo[]是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。 其核心部分包含: 远程通讯: 提供对多种基于长连接的NIO框架抽象封装,...

最爱肉肉
2016/10/07
1K
0
Ubuntu11.10下编译android内核源码

在之前的文章中,为读者介绍了《Ubuntu Linux下android源码下载方法》、《Ubuntu11.10下配置android的Eclipse开发环境》、配置过程中遇到的一些问题,以及《Ubuntu11.10下android源码4.0.3的...

Taskiller
2012/01/11
0
0
【菜鸟嵌入式学习分享】4412开发板Android4.4.4环境的搭建和编译

刚刚到手的板子,按手册步骤成功烧写了系统,o( ̄▽ ̄)d,分享一下。 Android4.4.4 的编译环境,是在迅为的网盘或者 github中下载 Android4.4 的源码压缩包。解压后可以得到Android4.4.4 和 ...

歌之王子殿下
2015/10/14
1K
0
Android源码阅读-编译8.0源码

前面的话 搞Android的人不编译一下Android的源码感觉人生好像不大完整似的。早就想编译Android源码,但是前前后后经历好长时间都没有把它搞出来,就这样拖着,直到昨天晚上才真正的把Android...

ostracod
2017/11/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

深入理解JVM—JVM内存模型

深入理解JVM—JVM内存模型 我们知道,计算机CPU和内存的交互是最频繁的,内存是我们的高速缓存区,用户磁盘和CPU的交互,而CPU运转速度越来越快,磁盘远远跟不上CPU的读写速度,才设计了内存...

onedotdot
32分钟前
1
0
MVC、MVCS、MVVM、MVP、VIPER等这么多架构模式哪一个好呢?

在项目开启阶段,其中一个很重要的环节就是选架构。 那么面对目前已知的这么多架构模式我们该怎么选择呢?这确实是个很让人头疼的问题! 下面我就在这里梳理一下目前常见的一些架构模式。 先...

Java干货分享
今天
4
0
简单模仿配置文件的反射机制

//Student类 public class Student { public void love() { System.out.println("python"); } } //Tesy类 public class Tesy { public static void main(String[] args) throws Exceptio......

南桥北木
今天
2
0
你真的需要了解一下CSS变量 var()的用法

当Web项目变得越来越大时,他的CSS会变得像天文数字那么大而且还变得混乱。为了帮助我们解决这个问题,新的CSS变量很快就会出现在主流浏览器中,它让开发人员能够重用并轻松编辑重复出现的C...

前端小攻略
今天
1
0
嵌入式应用选择合适的微控制器

为嵌入式应用选择微控制器有几个原因,即低成本,高集成度,增加可靠性,节省空间等。 准备所需硬件接口列表使用微控制器的基本硬件框图,准备一份微控制器需要支持的所有外设接口的列表。微...

linux-tao
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部