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

上一篇我们介绍《构建dubbo分布式平台-maven构建ant-parent项目》,框架使用maven进行构建,根据我们的规划,要将子项目全部构建出来,今天重点讲解的是ant-config配置文件项目的构建过程。

导语: 将ant-config项目独立出来的目的是将所有的配置文件进行统一项目管理,其中包括:spring相关文件配置、mybatis相关文件配置、数据源相关文件配置、基础环境文件配置(短信、消息、oss存储、第三方登陆、邮件等)、redis或者ehcache缓存相关配置、log4j日志文件相关配置、统一error异常配置、spring-shiro权限的相关配置、spring和redis缓存集成相关配置等。

1. 创建ant-config子项目,继承ant-parent项目,eclipse的创建过程我这边省略了。pom.xml文件配置如下:

Xml代码  

  1. <span style="font-size: 16px;"><?xml version="1.0"?>
  2. <project
  3. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
  4. xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  5. <modelVersion>4.0.0</modelVersion>
  6. <parent>
  7. <groupId>com.sml.sz</groupId>
  8. <artifactId>ant-project</artifactId>
  9. <version>1.0.0</version>
  10. </parent>
  11. <artifactId>ant-config</artifactId>
  12. <name>ant-config</name>
  13. <url>http://maven.apache.org</url>
  14. <packaging>jar</packaging>
  15. <properties>
  16. <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  17. </properties>
  18. <build>
  19. <!-- maven 打包后的包名 -->
  20. <finalName>ant-config</finalName>
  21. <resources>
  22. <!-- 指定 src/main/resources下所有文件及文件夹为资源文件 -->
  23. <resource>
  24. <directory>src/main/resources</directory>
  25. <targetPath>${project.build.directory}/classes</targetPath>
  26. <includes>
  27. <include>**/*</include>
  28. </includes>
  29. <filtering>true</filtering>
  30. </resource>
  31. <!-- 根据env部署环境值,把对应环境的配置文件拷贝到classes目录 -->
  32. <resource>
  33. <directory>deployEnv/${env}</directory>
  34. <targetPath>${project.build.directory}/classes</targetPath>
  35. <filtering>true</filtering>
  36. </resource>
  37. </resources>
  38. </build>
  39. </project>
  40. </span>

2. 创建log4j.properties文件,配置如下:

Xml代码  

  1. <span style="font-size: 16px;"># Output pattern : date [thread] priority category - message   FATAL 0  ERROR 3  WARN 4  INFO 6  DEBUG 7
  2. log4j.rootLogger=WARN, Console, RollingFile
  3. #Console
  4. log4j.appender.Console=org.apache.log4j.ConsoleAppender
  5. log4j.appender.Console.layout=org.apache.log4j.PatternLayout
  6. log4j.appender.Console.layout.ConversionPattern=%d %-5p [%c{5}] - %m%n
  7. #RollingFile
  8. log4j.appender.RollingFile=org.apache.log4j.DailyRollingFileAppender
  9. log4j.appender.RollingFile.File=/logs/ant/ant.log
  10. log4j.appender.RollingFile.layout=org.apache.log4j.PatternLayout
  11. log4j.appender.RollingFile.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n
  12. #log4j.logger.java.sql=DEBUG
  13. #Project defalult level
  14. log4j.logger.com.sml.sz=DEBUG
  15. log4j.logger.com.sml.sz.common.security.shiro=WARN
  16. log4j.logger.com.sml.sz.JedisUtils=WARN</span>

3. 创建ant.properties文件,内容如下:

Java代码  

  1. <span style="font-size: 16px;">#--------------Database sttings--------------
  2. #mysql database setting
  3. jdbc.type=mysql
  4. jdbc.driver=com.mysql.jdbc.Driver
  5. jdbc.url=jdbc:mysql://127.0.0.1:3306/ant-dubbo?useUnicode=true&characterEncoding=utf-8
  6. jdbc.username=root
  7. jdbc.password=root
  8. #pool settings
  9. jdbc.pool.init=10
  10. jdbc.pool.minIdle=30
  11. jdbc.pool.maxActive=60
  12. #--------------redis settings--------------
  13. redis.keyPrefix=ant
  14. redis.host=127.0.0.1
  15. redis.port=6379
  16. #-------------- System settings --------------
  17. #\u4ea7\u54c1\u4fe1\u606f\u8bbe\u7f6e
  18. logoName=ant
  19. productName=ant \u5206\u5E03\u5F0F\u4F01\u4E1A\u67B6\u6784
  20. copyrightYear=2017
  21. version=V1.0.0
  22. #\u662f\u5426\u5141\u8bb8\u591a\u8d26\u53f7\u540c\u65f6\u767b\u5f55
  23. user.multiAccountLogin=true
  24. #\u5206\u9875\u914d\u7f6e
  25. page.pageSize=10
  26. #-------------- Framework settings --------------
  27. #\u4f1a\u8bdd\u8d85\u65f6\uff0c \u5355\u4f4d\uff1a\u6beb\u79d2\uff0c 20m=1200000ms, 30m=1800000ms, 60m=3600000ms
  28. session.sessionTimeout=1800000
  29. #\u4f1a\u8bdd\u6e05\u7406\u95f4\u9694\u65f6\u95f4\uff0c \u5355\u4f4d\uff1a\u6beb\u79d2\uff0c2m=120000ms\u3002
  30. session.sessionTimeoutClean=120000
  31. #\u89c6\u56fe\u6587\u4ef6\u5b58\u653e\u8def\u5f84
  32. web.view.prefix=/WEB-INF/views/
  33. web.view.suffix=.jsp
  34. web.maxUploadSize=10485760
  35. #\u9759\u6001\u6587\u4ef6\u540e\u7f00
  36. web.staticFile=.css,.js,.png,.jpg,.gif,.jpeg,.bmp,.ico,.swf,.psd,.htc,.htm,.html,.crx,.xpi,.exe,.ipa,.apk
  37. #--------------Email SMTP --------------
  38. mail.host=smtp.163.com
  39. mail.port=25
  40. mail.username=test@163.com
  41. mail.password=test
  42. mail.smtp.auth=true
  43. mail.smtp.timeout=30000
  44. mail.default.from=test@163.com
  45. #-------------- JMS --------------
  46. mq.brokerURL=failover\:(tcp\://127.0.0.1\:61616)?randomize\=false&initialReconnectDelay\=1000&maxReconnectDelay\=30000
  47. mq.userName=ant
  48. mq.password=ant
  49. mq.pool.maxConnections=20
  50. #queueName
  51. queueName.task=task_queue_1
  52. </span>

4. 创建mybatis-config.xml配置文件,配置如下:

Java代码  

  1. <span style="font-size: 16px;"><?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
  3. <configuration>
  4. <!-- 全局参数 -->
  5. <settings>
  6. <!-- 使全局的映射器启用或禁用缓存。 -->
  7. <setting name="cacheEnabled" value="true"/>
  8. <!-- 全局启用或禁用延迟加载。当禁用时,所有关联对象都会即时加载。 -->
  9. <setting name="lazyLoadingEnabled" value="true"/>
  10. <!-- 当启用时,有延迟加载属性的对象在被调用时将会完全加载任意属性。否则,每种属性将会按需要加载。 -->
  11. <setting name="aggressiveLazyLoading" value="true"/>
  12. <!-- 是否允许单条sql 返回多个数据集 -->
  13. <setting name="multipleResultSetsEnabled" value="true"/>
  14. <!-- 是否可以使用列的别名 (取决于驱动的兼容性) default:true -->
  15. <setting name="useColumnLabel" value="true"/>
  16. <!-- 允许JDBC 生成主键。  -->
  17. <setting name="useGeneratedKeys" value="false"/>
  18. <!-- 指定 MyBatis 如何自动映射  -->
  19. <setting name="autoMappingBehavior" value="PARTIAL"/>
  20. <!-- 这是默认的执行类型  -->
  21. <setting name="defaultExecutorType" value="SIMPLE"/>
  22. <!-- 使用驼峰命名法转换字段。 -->
  23. <setting name="mapUnderscoreToCamelCase" value="true"/>
  24. <!-- 设置本地缓存范围 session:就会有数据的共享 -->
  25. <setting name="localCacheScope" value="SESSION"/>
  26. <!-- 设置但JDBC类型为空时,某些驱动程序 要指定值-->
  27. <setting name="jdbcTypeForNull" value="NULL"/>
  28. </settings>
  29. <!-- 类型别名 -->
  30. <!--分页  -->
  31. <typeAliases>
  32. <typeAlias alias="Page" type="com.sml.sz.common.persistence.Page" />
  33. </typeAliases>
  34. <!-- 插件配置 -->
  35. <plugins>
  36. <plugin interceptor="com.sml.sz.common.persistence.interceptor.PaginationInterceptor" />
  37. </plugins>
  38. </configuration>
  39. </span>

5. 创建spring-context.xml配置文件,配置如下:

Java代码  

  1. <span style="font-size: 16px;"><?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xmlns:context="http://www.springframework.org/schema/context" xmlns:jdbc="http://www.springframework.org/schema/jdbc"
  4. xmlns:jee="http://www.springframework.org/schema/jee" xmlns:tx="http://www.springframework.org/schema/tx"
  5. xmlns:util="http://www.springframework.org/schema/util" xmlns:task="http://www.springframework.org/schema/task" xsi:schemaLocation="
  6. http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
  7. http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
  8. http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-4.0.xsd
  9. http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-4.0.xsd
  10. http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
  11. http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-4.0.xsd
  12. http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-4.0.xsd"
  13. default-lazy-init="true">
  14. <description>Spring Configuration</description>
  15. <!-- 加载配置属性文件 -->
  16. <context:property-placeholder ignore-unresolvable="true" location="classpath:ant.properties" />
  17. <!-- 加载应用属性实例-->
  18. <util:properties id="APP_PROP" location="classpath:ant.properties" local-override="true"/>
  19. <!-- 使用Annotation自动注册Bean,解决事物失效问题:在主容器中不扫描@Controller注解,在SpringMvc中只扫描@Controller注解。  -->
  20. <context:component-scan base-package="com.sml.sz"><!-- base-package 如果多个,用“,”分隔 -->
  21. <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
  22. </context:component-scan>
  23. <!-- MyBatis begin -->
  24. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  25. <property name="dataSource" ref="dataSource"/>
  26. <property name="typeAliasesPackage" value="com.sml.sz"/>
  27. <property name="typeAliasesSuperType" value="com.sml.sz.common.persistence.BaseEntity"/>
  28. <property name="mapperLocations" value="classpath*:mappings/**/*.xml"/>
  29. <property name="configLocation" value="classpath:/mybatis-config.xml"></property>
  30. </bean>
  31. <!-- 扫描basePackage下所有以@MyBatisDao注解的接口 -->
  32. <bean id="mapperScannerConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
  33. <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
  34. <property name="basePackage" value="com.sml.sz.*"/>
  35. <property name="annotationClass" value="com.sml.sz.common.persistence.annotation.MyBatisDao"/>
  36. </bean>
  37. <!-- 定义事务 -->
  38. <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
  39. <property name="dataSource" ref="dataSource" />
  40. </bean>
  41. <!-- 配置 Annotation 驱动,扫描@Transactional注解的类定义事务  -->
  42. <tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true"/>
  43. <!-- MyBatis end -->
  44. <!-- 配置 JSR303 Bean Validator 定义 -->
  45. <bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean" />
  46. <!-- 缓存配置 -->
  47. <bean id="cacheManager" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean">
  48. <property name="configLocation" value="classpath:${ehcache.configFile}" />
  49. </bean>
  50. <!-- 数据源配置, 使用 BoneCP 数据库连接池 -->
  51. <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
  52. <!-- 数据源驱动类可不写,Druid默认会自动根据URL识别DriverClass -->
  53. <property name="driverClassName" value="${jdbc.driver}" />
  54. <!-- 基本属性 url、user、password -->
  55. <property name="url" value="${jdbc.url}" />
  56. <property name="username" value="${jdbc.username}" />
  57. <property name="password" value="${jdbc.password}" />
  58. <!-- 配置初始化大小、最小、最大 -->
  59. <property name="initialSize" value="${jdbc.pool.init}" />
  60. <property name="minIdle" value="${jdbc.pool.minIdle}" />
  61. <property name="maxActive" value="${jdbc.pool.maxActive}" />
  62. <!-- 配置获取连接等待超时的时间 -->
  63. <property name="maxWait" value="60000" />
  64. <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
  65. <property name="timeBetweenEvictionRunsMillis" value="60000" />
  66. <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
  67. <property name="minEvictableIdleTimeMillis" value="300000" />
  68. <property name="validationQuery" value="${jdbc.testSql}" />
  69. <property name="testWhileIdle" value="true" />
  70. <property name="testOnBorrow" value="false" />
  71. <property name="testOnReturn" value="false" />
  72. <!-- 打开PSCache,并且指定每个连接上PSCache的大小(Oracle使用)
  73. <property name="poolPreparedStatements" value="true" />
  74. <property name="maxPoolPreparedStatementPerConnectionSize" value="20" /> -->
  75. <!-- 配置监控统计拦截的filters -->
  76. <property name="filters" value="stat" />
  77. </bean>
  78. </beans></span>

6 创建spring-context-shiro.xml文件,配置如下:

Java代码  

  1. <span style="font-size: 16px;"><?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="
  4. http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
  5. http://www.springframework.org/schema/context  http://www.springframework.org/schema/context/spring-context-4.0.xsd"
  6. default-lazy-init="true">
  7. <description>Shiro Configuration</description>
  8. <!-- 加载配置属性文件 -->
  9. <context:property-placeholder ignore-unresolvable="true" location="classpath:ant.properties" />
  10. <!-- Shiro权限过滤过滤器定义 -->
  11. <bean name="shiroFilterChainDefinitions" class="java.lang.String">
  12. <constructor-arg>
  13. <value>
  14. /static/** = anon
  15. /userfiles/** = anon
  16. ${adminPath}/login = authc
  17. ${adminPath}/logout = logout
  18. ${adminPath}/** = user
  19. /act/rest/service/** = user
  20. /ReportServer/** = user
  21. </value>
  22. </constructor-arg>
  23. </bean>
  24. <!-- 安全认证过滤器 -->
  25. <bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean">
  26. <property name="securityManager" ref="securityManager" />
  27. <property name="loginUrl" value="${adminPath}/login" />
  28. <property name="successUrl" value="${adminPath}?login" />
  29. <property name="filters">
  30. <map>
  31. <entry key="authc" value-ref="formAuthenticationFilter"/>
  32. </map>
  33. </property>
  34. <property name="filterChainDefinitions">
  35. <ref bean="shiroFilterChainDefinitions"/>
  36. </property>
  37. </bean>
  38. <!-- 定义Shiro安全管理配置 -->
  39. <bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager">
  40. <property name="realm" ref="systemAuthorizingRealm" />
  41. <property name="sessionManager" ref="sessionManager" />
  42. <property name="cacheManager" ref="shiroCacheManager" />
  43. </bean>
  44. <!-- 自定义会话管理配置 -->
  45. <bean id="sessionManager" class="com.sml.sz.common.security.shiro.session.SessionManager">
  46. <property name="sessionDAO" ref="sessionDAO"/>
  47. <!-- 会话超时时间,单位:毫秒  -->
  48. <property name="globalSessionTimeout" value="${session.sessionTimeout}"/>
  49. <!-- 定时清理失效会话, 清理用户直接关闭浏览器造成的孤立会话   -->
  50. <property name="sessionValidationInterval" value="${session.sessionTimeoutClean}"/>
  51. <property name="sessionValidationSchedulerEnabled" value="true"/>
  52. <property name="sessionIdCookie" ref="sessionIdCookie"/>
  53. <property name="sessionIdCookieEnabled" value="true"/>
  54. </bean>
  55. <bean id="sessionIdCookie" class="org.apache.shiro.web.servlet.SimpleCookie">
  56. <constructor-arg name="name" value="ant.session.id"/>
  57. </bean>
  58. <!-- 自定义Session存储容器 -->
  59. <!-- <bean id="sessionDAO" class="com.sml.sz.common.security.shiro.session.JedisSessionDAO">
  60. <property name="sessionIdGenerator" ref="idGen" />
  61. <property name="sessionKeyPrefix" value="${redis.keyPrefix}_session_" />
  62. </bean> -->
  63. <bean id="sessionDAO" class="com.sml.sz.common.security.shiro.session.CacheSessionDAO">
  64. <property name="sessionIdGenerator" ref="idGen" />
  65. <property name="activeSessionsCacheName" value="activeSessionsCache" />
  66. <property name="cacheManager" ref="shiroCacheManager" />
  67. </bean>
  68. <!-- 定义授权缓存管理器 -->
  69. <bean id="shiroCacheManager" class="org.apache.shiro.cache.ehcache.EhCacheManager">
  70. <property name="cacheManager" ref="cacheManager"/>
  71. </bean>
  72. <bean id="lifecycleBeanPostProcessor" class="org.apache.shiro.spring.LifecycleBeanPostProcessor"/>
  73. <!-- AOP式方法级权限检查  -->
  74. <bean class="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator" depends-on="lifecycleBeanPostProcessor">
  75. <property name="proxyTargetClass" value="true" />
  76. </bean>
  77. <bean class="org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor">
  78. <property name="securityManager" ref="securityManager"/>
  79. </bean>
  80. </beans></span>

7. 代码结构如下:


 
 欢迎大家跟我一起学习《构建dubbo分布式平台》,希望大家持续关注后面的文章!

愿意了解框架技术或者源码的朋友直接求求交流分享技术:2042849237
分布式的一些解决方案,有愿意了解的朋友可以找我们团队探讨
更多详细源码参考来源:http://minglisoft.cn/technology

时间: 2024-11-08 15:58:13

(六) 构建dubbo分布式平台-maven构建config配置项目的相关文章

(八) 构建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核心代码Base封装

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

(十) 构建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构建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构建根项目

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

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

导语:在dubbo分布式架构构建之前,请大家务必掌握maven的相关技能,因为架构中大量使用maven技术进行项目构建,有不熟的朋友可以在网上找一些资料学习. 准备技能 开发语言:JAVA/J2EE 项目构建管理:Maven 持续集成方案:Jenkins SOA服务: Dubbo.zookeeper.Restful SSO单点登录:Redis.JWT.Restful 分布式缓存:Redis 分布式消息中间件:zookeeper+kafka 分布式文件:FastDFS 数据库连接池:Alibaba

构建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-