构建dubbo分布式平台-maven构建根项目

导语:在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

  1. 创建maven基础项目,其中只需要配置pom.xml文件和打包的文件即可,代码如下:

    
    <span style="font-size: 16px;"><?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></span>

2. 创建打包脚本:测试、生成等

<span style="font-size: 16px;">set MAVEN_OPTS= -Xms128 -Xmx256m
mvn clean package --define maven.test.skip=true --define environment.type=sit</span>

<span style="font-size: 16px;">set MAVEN_OPTS= -Xms128 -Xmx256m
mvn clean package --define maven.test.skip=true --define environment.type=pro</span>



3. 创建打包的properties文件:

解释: 里面可以配置打包的信息,比如:ip、域名、包名等

4. 代码结构如下:

![](http://i2.51cto.com/images/blog/201807/25/6d45aef63ab724cc31e2134b1d45796c.png?x-oss-process=image/watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=)
分布式的一些解决方案,有愿意了解的朋友可以找我们团队探讨。

原文地址:http://blog.51cto.com/13777880/2149775

时间: 2024-10-11 03:54:33

构建dubbo分布式平台-maven构建根项目的相关文章

(十) 构建dubbo分布式平台-maven构建ant-utils工具项目

上一篇我们介绍<构建dubbo分布式平台-maven构建ant-framework核心代码Base封装>,今天重点讲解的是ant-utils工具包的构建过程. 导语:ant-utils是核心工具包,提供整个架构通用工具类库 创建ant-utils工具包子项目,继承ant-parent根项目,其中pom.xml配置如下:`<span style="font-size: 14px;"><?xml version="1.0"?><

(六) 构建dubbo分布式平台-maven构建config配置项目

上一篇我们介绍<构建dubbo分布式平台-maven构建ant-parent项目>,框架使用maven进行构建,根据我们的规划,要将子项目全部构建出来,今天重点讲解的是ant-config配置文件项目的构建过程. 导语: 将ant-config项目独立出来的目的是将所有的配置文件进行统一项目管理,其中包括:spring相关文件配置.mybatis相关文件配置.数据源相关文件配置.基础环境文件配置(短信.消息.oss存储.第三方登陆.邮件等).redis或者ehcache缓存相关配置.log4j

(八) 构建dubbo分布式平台-maven构建ant-framework核心代码annotation

上一篇我们介绍<构建dubbo分布式平台-maven构建ant-framework框架的pom.xml文件配置>,子项目的基础框架已经构建完成,今天重点讲解的是ant-framework核心代码的编写过程. 其中ant-framework是ant分布式框架的基础核心框架,其中包括CRUD,MVC等一系列基类和模板.另外定义了spring,mybatis,wink等底层框架扩展项目,具体内容包括: 1. annotation相关注解:数据签名注解.用户是否走sso登录注解等,今天我们着重讲解一下

(七) 构建dubbo分布式平台-maven构建ant-framework框架的pom.xml文件配置

上一篇我们介绍<构建dubbo分布式平台-maven构建ant-config项目>,框架使用maven进行构建,根据我们的规划,要将子项目全部构建出来,今天重点讲解的是ant-framework可信项目的构建过程. 其中ant-framework是ant分布式框架的基础核心框架,其中包括CRUD,MVC等一系列基类和模板.另外定义了spring,mybatis,wink等底层框架扩展项目,具体内容包括: 1. annotation相关注解:数据签名注解.用户是否走sso登录注解等: 2. Be

(八) 构建dubbo分布式平台-maven构建ant-framework核心代码annotatio

上一篇我们介绍<构建dubbo分布式平台-maven构建ant-framework框架的pom.xml文件配置>,子项目的基础框架已经构建完成,今天重点讲解的是ant-framework核心代码的编写过程. 其中ant-framework是ant分布式框架的基础核心框架,其中包括CRUD,MVC等一系列基类和模板.另外定义了spring,mybatis,wink等底层框架扩展项目,具体内容包括: annotation相关注解:数据签名注解.用户是否走sso登录注解等,今天我们着重讲解一下ann

(七) 构建dubbo分布式平台-maven构建ant-framework框架的pom.xml文件配

上一篇我们介绍<构建dubbo分布式平台-maven构建ant-config项目>,框架使用maven进行构建,根据我们的规划,要将子项目全部构建出来,今天重点讲解的是ant-framework可信项目的构建过程. 其中ant-framework是ant分布式框架的基础核心框架,其中包括CRUD,MVC等一系列基类和模板.另外定义了spring,mybatis,wink等底层框架扩展项目,具体内容包括: annotation相关注解:数据签名注解.用户是否走sso登录注解等: Bean的相关认

(九) 构建dubbo分布式平台-maven构建ant-framework核心代码Base封装

上一篇我们介绍<构建dubbo分布式平台-maven构建ant-framework核心代码annotation>,今天重点讲解的是ant-framework核心代码Base封装过程. 因为涉及到springmvc.mybatis的集成,为了使项目编码更简洁易用,这边将基础的BASE进行封装,其中包括:BaseBean.BaseDao.BaseService.CRUD的基础封装.分页组件的封装.mybatis的mapper的基础封装,各种数据源支持的封装等. BaseEntity基础封装,代码如

(五)构建dubbo分布式平台-maven构建根项目

上一篇我们介绍<构建dubbo分布式平台-maven代码结构>,从今天开始,我们将对代码的每一个构建做详细的记录,能够帮助大家如何快速构建dubbo分布式企业架构. 导语:在dubbo分布式架构构建之前,请大家务必掌握maven的相关技能,因为架构中大量使用maven技术进行项目构建,有不熟的朋友可以在网上找一些资料学习. 准备技能 开发语言:JAVA/J2EE 项目构建管理:Maven 持续集成方案:Jenkins SOA服务: Dubbo.zookeeper.Restful SSO单点登录

构建dubbo分布式平台-maven构建config配置项目

创建ant-config子项目,继承ant-parent项目,eclipse的创建过程我这边省略了.pom.xml文件配置如下: <span style="font-size: 16px;"><?xml version="1.0"?> <project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-