上一篇我们介绍《构建dubbo分布式平台-maven代码结构》,从今天开始,我们将对代码的每一个构建做详细的记录,能够帮助大家如何快速构建dubbo分布式企业架构。
导语:在dubbo分布式架构构建之前,请大家务必掌握maven的相关技能,因为架构中大量使用maven技术进行项目构建,有不熟的朋友可以在网上找一些资料学习。
1. 准备技能
开发语言:JAVA/J2EE
项目构建管理:Maven
持续集成方案:Jenkins
SOA服务: Dubbo、zookeeper、Restful
SSO单点登录:Redis、JWT、Restful
分布式缓存:Redis
分布式消息中间件:zookeeper+kafka
分布式文件:FastDFS
数据库连接池:Alibaba Druid
核心框架:Spring framework、Spring MVC、Apache Shiro、MyBatis
前端框架:Bootstrap + html5 + CSS3
2. 创建maven基础项目,其中只需要配置pom.xml文件和打包的文件即可,代码如下:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.sml.sz</groupId>
<artifactId>ant-project</artifactId>
<version>1.0.0</version>
<packaging>pom</packaging>
<name>ant-project</name>
<url>http://maven.apache.org</url>
<inceptionYear>2015-2016</inceptionYear>
<properties>
<!-- 框架通用包版本设置 -->
<spring.version>4.2.2.RELEASE</spring.version>
<validator.version>5.1.1.Final</validator.version>
<mybatis.version>3.2.8</mybatis.version>
<mybatis-spring.version>1.2.2</mybatis-spring.version>
<shiro.version>1.2.3</shiro.version>
<druid.version>1.0.11</druid.version>
<ehcache.version>2.6.9</ehcache.version>
<ehcache-web.version>2.0.4</ehcache-web.version>
<sitemesh.version>2.4.2</sitemesh.version>
<activiti.version>5.15.1</activiti.version>
<wink.version>1.4</wink.version>
<sso.client.version>3.2.1</sso.client.version>
<!-- 通用工具包版本设置 -->
<slf4j.version>1.7.7</slf4j.version>
<commons-lang3.version>3.3.2</commons-lang3.version>
<commons-io.version>2.4</commons-io.version>
<commons-codec.version>1.9</commons-codec.version>
<commons-fileupload.version>1.3.1</commons-fileupload.version>
<commons-beanutils.version>1.9.1</commons-beanutils.version>
<jackson.version>2.2.3</jackson.version>
<fastjson.version>1.1.40</fastjson.version>
<xstream.version>1.4.7</xstream.version>
<guava.version>17.0</guava.version>
<dozer.version>5.5.1</dozer.version>
<email.version>1.4.7</email.version>
<poi.version>3.9</poi.version>
<freemarker.version>2.3.20</freemarker.version>
<!-- 基础环境设置 -->
<jdk.version>1.6</jdk.version>
<tomcat.version>2.2</tomcat.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<downloadSources>true</downloadSources>
<!-- jdbc驱动版本设置 -->
<mysql.driver.version>5.1.30</mysql.driver.version>
</properties>
<dependencies>
<!-- 单元测试 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
<!-- Tomcat 如果存在就不需要将servlet-api.jar、jsp-api.jar一起打包 -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.1</version>
<scope>provided</scope>
</dependency>
</dependencies>
<dependencyManagement>
<dependencies>
<!-- ant 工具jar -->
<dependency>
<groupId>com.sml.sz</groupId>
<artifactId>ant-utils</artifactId>
<version>${project.version}</version>
</dependency>
<!-- ant 公共配置jar -->
<dependency>
<groupId>com.sml.sz</groupId>
<artifactId>ant-config</artifactId>
<version>${project.version}</version>
</dependency>
<!-- ant 核心框架jar -->
<dependency>
<groupId>com.sml.sz</groupId>
<artifactId>ant-framework</artifactId>
<version>${project.version}</version>
</dependency>
<!-- ant 代码自动生成业务jar -->
<dependency>
<groupId>com.sml.sz</groupId>
<artifactId>ant-core-gen</artifactId>
<version>${project.version}</version>
</dependency>
<!-- ant 会员业务jar -->
<dependency>
<groupId>com.sml.sz</groupId>
<artifactId>ant-core-member</artifactId>
<version>${project.version}</version>
</dependency>
<!-- ant RestFul服务系統 -->
<dependency>
<groupId>com.sml.sz</groupId>
<artifactId>ant-web-service</artifactId>
<version>${project.version}</version>
</dependency>
<!-- ant admin后台管理系統 -->
<dependency>
<groupId>com.sml.sz</groupId>
<artifactId>ant-web-admin</artifactId>
<version>${project.version}</version>
</dependency>
<!-- dubbo begin -->
<dependency>
<groupId>com.sml.sz</groupId>
<artifactId>ant-member-facade</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>com.sml.sz</groupId>
<artifactId>ant-member-service</artifactId>
<version>${project.version}</version>
</dependency>
<!-- dubbo end -->
</dependencies>
</dependencyManagement>
<build>
<pluginManagement>
<plugins>
<!-- maven -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-antrun-plugin</artifactId>
<version>1.7</version>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.3.2</version>
<configuration>
<source>1.5</source>
<target>1.5</target>
<!-- 去除临时文件 -->
<excludes>
<exclude>**/*.keep</exclude>
<exclude>**/*.keep.*</exclude>
<exclude>*.bak</exclude>
<exclude>*.contrib</exclude>
</excludes>
<showDeprecation>true</showDeprecation>
<compilerArgument>-Xlint:unchecked,deprecation,fallthrough,finally</compilerArgument>
<fork>true</fork>
<encoding>${project.build.sourceEncoding}</encoding>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<version>2.3.1</version>
<executions>
<execution>
<goals>
<goal>test-jar</goal>
</goals>
</execution>
</executions>
<configuration>
<archive>
<manifest>
<addDefaultSpecificationEntries>true</addDefaultSpecificationEntries>
<addDefaultImplementationEntries>true</addDefaultImplementationEntries>
</manifest>
</archive>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-release-plugin</artifactId>
<version>2.1</version>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-resources-plugin</artifactId>
<version>2.4.3</version>
<configuration>
<!-- 去除临时文件 -->
<excludes>
<exclude>**/*.keep</exclude>
<exclude>**/*.keep.*</exclude>
<exclude>*.bak</exclude>
<exclude>*.contrib</exclude>
</excludes>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-site-plugin</artifactId>
<version>2.1.1</version>
<configuration>
<inputEncoding>${project.build.sourceEncoding}</inputEncoding>
<outputEncoding>${project.build.sourceEncoding}</outputEncoding>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-source-plugin</artifactId>
<version>2.1.2</version>
<executions>
<execution>
<id>attach-sources</id>
<goals>
<goal>jar</goal>
<goal>test-jar</goal>
</goals>
</execution>
</executions>
<configuration>
<excludeResources>false</excludeResources>
<attach>true</attach>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-war-plugin</artifactId>
<version>2.4</version>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-ear-plugin</artifactId>
<version>2.9</version>
<configuration>
<version>5</version>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.6</version>
<configuration>
<testFailureIgnore>true</testFailureIgnore>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-report-plugin</artifactId>
<version>2.6</version>
<configuration>
<parallel>both</parallel>
</configuration>
</plugin>
<plugin>
<groupId>com.google.code.maven-replacer-plugin</groupId>
<artifactId>replacer</artifactId>
<version>1.5.1</version>
<executions>
<execution>
<phase>prepare-package</phase>
<goals>
<goal>replace</goal>
</goals>
</execution>
</executions>
</plugin>
<!-- 读取系统配置的properties文件,避免写入profile中,各自模块使用的时候注意修改路径 -->
<plugin>
<groupId>org.kuali.maven.plugins</groupId>
<artifactId>properties-maven-plugin</artifactId>
<version>2.0.1</version>
<configuration>
<locations>
<location>${basedir}/../project_${profile}.properties</location>
</locations>
</configuration>
<executions>
<execution>
<phase>prepare-package</phase>
<goals>
<goal>read-project-properties</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</pluginManagement>
</build>
<profiles>
<profile>
<id>dev</id>
<activation>
<activeByDefault>true</activeByDefault>
</activation>
<properties>
<project>
dev
</project>
</properties>
</profile>
<profile>
<id>sit</id>
<activation>
<property>
<name>environment.type</name>
<value>sit</value>
</property>
</activation>
<properties>
<project>
sit
</project>
</properties>
</profile>
<profile>
<id>uat</id>
<activation>
<property>
<name>environment.type</name>
<value>uat</value>
</property>
</activation>
<properties>
<project>
uat
</project>
</properties>
</profile>
<profile>
<id>performance</id>
<activation>
<property>
<name>environment.type</name>
<value>performance</value>
</property>
</activation>
<properties>
<project>
performance
</project>
</properties>
</profile>
<profile>
<id>production</id>
<activation>
<property>
<name>environment.type</name>
<value>production</value>
</property>
</activation>
<properties>
<project>
production
</project>
</properties>
</profile>
</profiles>
<modules>
<!-- ant 工具jar -->
<module>ant-utils</module>
<!-- ant 公共配置jar -->
<module>ant-config</module>
<!-- ant 核心框架jar -->
<module>ant-framework</module>
<!-- ant 代码自动生成业务jar -->
<module>ant-core-gen</module>
<!-- ant 会员业务jar -->
<module>ant-core-member</module>
<!-- ant admin后台管理系統 -->
<module>ant-web-admin</module>
<!-- ant Restful服务管理系統 -->
<module>ant-web-service</module>
<!-- ant member Dubbo服务接口 -->
<module>ant-member-facade</module>
<!-- ant member Dubbo服务提供者 -->
<module>ant-member-service</module>
</modules>
<description>ant平台的super工程,定义了整合ant项目群的基本信息,以及依赖项和插件信息、maven的自定义信息</description>
</project>
2. 创建打包脚本:测试、生成等
build_SIT-no-test.bat
set MAVEN_OPTS= -Xms128 -Xmx256m
mvn clean package --define maven.test.skip=true --define environment.type=sit
build_UAT-no-test.bat
set MAVEN_OPTS= -Xms128 -Xmx256m
mvn clean package --define maven.test.skip=true --define environment.type=uat
build_PROD-no-test.bat
set MAVEN_OPTS= -Xms128 -Xmx256m
mvn clean package --define maven.test.skip=true --define environment.type=pro
3. 创建打包的properties文件:
project_sit.properties
解释: 里面可以配置打包的信息,比如:ip、域名、包名等
4. 代码结构如下:
欢迎大家跟我一起学习《构建dubbo分布式平台》,希望大家持续关注后面的文章!
相关推荐
在本文中,我们将深入探讨如何利用Maven构建Dubbo项目,以及Dubbo的主要特性和应用场景。 首先,Maven是Java项目管理的重要工具,它通过POM(Project Object Model)文件统一管理项目的依赖、构建过程和配置信息。...
【Maven构建的分布式demo】 在现代软件开发中,分布式系统已经成为主流,它能提高系统的可扩展性、容错性和性能。Maven作为Java项目管理工具,为构建分布式应用程序提供了强大的支持。本篇将深入探讨如何利用Maven...
4. **pom.xml**:Maven构建文件,定义了项目的依赖库、版本信息以及构建过程。 Dubbo Admin的主要功能模块包括: - **服务注册与发现**:通过Zookeeper作为注册中心,服务提供者(Provider)和服务消费者...
要运行此项目,你需要先安装Zookeeper、MySQL(或其他支持的数据库)、Java运行环境以及确保你有正确的Maven或Gradle环境来构建项目。然后,根据项目的文档指导,配置相关服务和环境变量,最后启动Seata Server,...
3. **构建脚本**:可能包括`pom.xml`文件,表明该项目使用Maven作为构建工具,定义了依赖库、插件和构建过程。 4. **测试代码**:在`src/test/java`目录下,包含单元测试和集成测试,用于验证代码的功能和正确性。 ...
【标题】"dubbo-admin-master.zip" 是一个包含 Dubbo 管理服务源码的压缩包,主要用于管理和监控基于 Dubbo 构建的服务。Dubbo 是阿里巴巴开源的一款高性能、轻量级的 Java RPC 框架,它提供了服务治理、负载均衡、...
总结来说,搭建Dubbo分布式项目环境需要对Java环境、Maven、Zookeeper有基本的了解和配置经验,同时熟悉Dubbo的配置和使用。通过以上步骤,开发者可以成功地创建一个基础的Dubbo服务提供者和消费者环境,为后续的...
在项目根目录下执行`mvn clean install`命令,Maven会自动下载依赖并构建出可运行的JAR文件。 3. **运行Dubbo-admin**:构建完成后,会在target目录下生成一个名为`dubbo-admin-2.5.9-SNAPSHOT.jar`的文件。你可以...
总结来说,这个案例旨在展示如何利用Dubbo和Zookeeper构建一个分布式系统,同时结合Maven的父项目管理依赖,以及Swagger来生成API文档,实现服务的高效管理和便捷开发。理解并掌握这些知识点,对于提升大型系统的可...
Dubbo-admin基于Maven构建,通过pom.xml文件管理项目依赖。Maven是Java项目管理工具,负责下载库、构建项目和执行测试。源码中的pom.xml文件列出了所有必要的依赖库,包括Dubbo核心库、Spring Boot、Zookeeper...
1. **添加依赖**:在项目的Maven或Gradle配置文件中,引入dubbo-spring-boot-starter的相关依赖,确保项目能够识别并加载这个启动器。 2. **配置服务**:通过Spring Boot的配置文件(如application.properties或...
2. `dubbo-admin-2.5.10.pom`:这是Maven项目对象模型(Project Object Model)文件,记录了项目的依赖关系、构建配置等信息。如果你熟悉Maven,可以通过这个POM文件快速地在本地构建和运行该项目。POM文件在Java...
这个工具旨在提供对Dubbo分布式系统资源使用的实时监控能力,确保系统的稳定运行。 【描述】中提到,这个版本是开发者之前学习时使用的,尽管如此,它的稳定性得到了保证,意味着它可以有效地在生产环境中应用,...
【SpringBoot-Dubbo-Zookeeper-Maven】项目是一个整合了SpringBoot、Dubbo和Zookeeper的示例工程,它展示了如何在Java环境中利用这些技术构建分布式服务。SpringBoot简化了Spring应用的初始搭建以及开发过程,而...
在IT行业中,构建大型分布式系统时,我们常常会用到Spring Boot、Dubbo以及MyBatis等技术。本文将详细讲解如何使用Spring Boot整合Dubbo,并在Maven多模块项目中集成MyBatis,帮助开发者构建高效、可扩展的微服务...
maven构建的spring分布式服务,使用dubbo分布式部署,压缩包包含两个eclipse工程(spring-client和spring-server),解压后在eclipse中直接运行(注意:是maven工程),压缩包也包含dubbo-admin和zookeeper,本工程...
在分布式系统开发中,尤其是采用Dubbo框架构建的应用程序,合理的构建管理和版本控制系统对于提高开发效率和保证代码质量至关重要。其中,Maven作为Java项目中最常用的构建工具之一,在项目构建、依赖管理和版本控制...
首先,第07节"使用Maven构建Dubbo服务的可执行jar包"讲解了如何利用Maven这一强大的构建工具来管理项目依赖并打包Dubbo服务。Maven的pom.xml配置文件是关键,其中包含了项目的依赖信息、构建目标等。通过配置Maven...