構建dubbo分散式平臺-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檔案和打包的檔案即可,程式碼如下:
<span style="font-size: 16px;"><?xml version="1.0" encoding="UTF-8"?> <project xmlns=" <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> <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. 建立打包指令碼:測試、生成等
build_SIT-no
<span style="font-size: 16px;">set MAVEN_OPTS= -Xms128 -Xmx256m mvn clean package --define maven.test.skip=true --define environment.type=sit</span>
build_UAT-no-test.bat
<span style="font-size: 16px;">set MAVEN_OPTS= -Xms128 -Xmx256m mvn clean package --define maven.test.skip=true --define environment.type=uat</span>
build_PROD-no-test.bat
<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檔案:
project_sit.properties
解釋: 裡面可以配置打包的資訊,比如:ip、域名、包名等
4. 程式碼結構如下:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31539957/viewspace-2213071/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 構建dubbo分散式平臺-dubbo簡介分散式
- 構建dubbo分散式平臺-maven構建ant-framework框架的pom.xml檔案配置分散式MavenFramework框架XML
- 構建dubbo分散式平臺-maven構建ant-framework核心程式碼Base封裝分散式MavenFramework封裝
- 構建dubbo分散式平臺-maven模組規劃和平臺功能導圖分散式Maven
- 構建springmvc+dubbo分散式平臺-dubbo管控檯安裝SpringMVC分散式
- 構建dubbo分散式平臺-window安裝zookeeper註冊中心分散式
- Maven 構建 Java 專案MavenJava
- 構建springmvc+myabtis+dubbo分散式平臺-zookeeper註冊中心安裝SpringMVC分散式
- 使用Maven構建Java專案MavenJava
- 你竟然沒用 Maven 構建專案?Maven
- 首次使用ideal構建maven專案webIdeaMavenWeb
- Maven配置阿里雲代理加速構建專案Maven阿里
- Jenkins 2.32.3引數化構建maven專案-java專案JenkinsMavenJava
- 根檔案系統構建
- kubernetes下jenkins實戰maven專案編譯構建JenkinsMaven編譯
- IDEA + maven 零基礎構建 java agent 專案IdeaMavenJava
- eclipse中基於maven構建多模組專案EclipseMaven
- 使用Eclipse 安裝 構建Maven專案 (step-by-step)EclipseMaven
- 微服務分散式雲架構spring cloud - commonservice-eureka 專案構建過程微服務分散式架構SpringCloud
- 分散式微服務雲架構構建電子商務平臺分散式微服務架構
- Docker 構建多平臺映象Docker
- Docker構建多平臺映象Docker
- CMAKE 《window構建專案》
- JAVA專案映象構建Java
- Gradle構建SpringBoot專案GradleSpring Boot
- webpack快速構建專案Web
- Gradle之多專案構建Gradle
- spring cloud構建網際網路分散式微服務雲平臺-docker部署spring cloud專案SpringCloud分散式微服務Docker
- spring cloud構建網際網路分散式微服務雲平臺-SpringCloud整合專案簡介SpringCloud分散式微服務GC
- 從零構建Java專案(Maven+SpringBoot+Git) #02 奧斯丁專案JavaMavenSpring BootGit
- Maven 自動化構建Maven
- Maven 構建生命週期Maven
- Maven 高階篇之構建多模組專案的方法Maven
- Spring Cloud構建分散式電子商務平臺:服務消費(基礎)SpringCloud分散式
- AI雲平臺怎麼構建AI
- 2. vite 構建專案Vite
- 使用Dockerfile構建django專案DockerDjango
- SpringBoot淺析——專案構建Spring Boot