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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了 构建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.   
  19.     <build>  
  20.         <!-- maven 打包后的包名 -->  
  21.         <finalName>ant-config</finalName>  
  22.         <resources>  
  23.             <!-- 指定 src/main/resources下所有文件及文件夹为资源文件 -->  
  24.             <resource>  
  25.                 <directory>src/main/resources</directory>  
  26.                 <targetPath>${project.build.directory}/classes</targetPath>  
  27.                 <includes>  
  28.                     <include>**/*</include>  
  29.                 </includes>  
  30.                 <filtering>true</filtering>  
  31.             </resource>  
  32.             <!-- 根据env部署环境值,把对应环境的配置文件拷贝到classes目录 -->  
  33.             <resource>  
  34.                 <directory>deployEnv/${env}</directory>  
  35.                 <targetPath>${project.build.directory}/classes</targetPath>  
  36.                 <filtering>true</filtering>  
  37.             </resource>  
  38.         </resources>  
  39.     </build>  
  40. </project>  
  41. </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.   
  4. #Console  
  5. log4j.appender.Console=org.apache.log4j.ConsoleAppender  
  6. log4j.appender.Console.layout=org.apache.log4j.PatternLayout  
  7. log4j.appender.Console.layout.ConversionPattern=%d %-5p [%c{5}] - %m%n  
  8.   
  9. #RollingFile  
  10. log4j.appender.RollingFile=org.apache.log4j.DailyRollingFileAppender  
  11. log4j.appender.RollingFile.File=/logs/ant/ant.log  
  12. log4j.appender.RollingFile.layout=org.apache.log4j.PatternLayout  
  13. log4j.appender.RollingFile.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n  
  14.   
  15. #log4j.logger.java.sql=DEBUG  
  16.   
  17. #Project defalult level  
  18. log4j.logger.com.sml.sz=DEBUG  
  19. log4j.logger.com.sml.sz.common.security.shiro=WARN  
  20. 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.   
  9. #pool settings  
  10. jdbc.pool.init=10  
  11. jdbc.pool.minIdle=30  
  12. jdbc.pool.maxActive=60  
  13.   
  14. #--------------redis settings--------------  
  15. redis.keyPrefix=ant  
  16. redis.host=127.0.0.1  
  17. redis.port=6379  
  18.   
  19. #-------------- System settings --------------  
  20. #\u4ea7\u54c1\u4fe1\u606f\u8bbe\u7f6e  
  21. logoName=ant  
  22. productName=ant \u5206\u5E03\u5F0F\u4F01\u4E1A\u67B6\u6784  
  23. copyrightYear=2017  
  24. version=V1.0.0  
  25.   
  26. #\u662f\u5426\u5141\u8bb8\u591a\u8d26\u53f7\u540c\u65f6\u767b\u5f55  
  27. user.multiAccountLogin=true  
  28.   
  29. #\u5206\u9875\u914d\u7f6e  
  30. page.pageSize=10  
  31.   
  32. #-------------- Framework settings --------------  
  33. #\u4f1a\u8bdd\u8d85\u65f6\uff0c \u5355\u4f4d\uff1a\u6beb\u79d2\uff0c 20m=1200000ms, 30m=1800000ms, 60m=3600000ms  
  34. session.sessionTimeout=1800000  
  35. #\u4f1a\u8bdd\u6e05\u7406\u95f4\u9694\u65f6\u95f4\uff0c \u5355\u4f4d\uff1a\u6beb\u79d2\uff0c2m=120000ms\u3002  
  36. session.sessionTimeoutClean=120000  
  37.   
  38. #\u89c6\u56fe\u6587\u4ef6\u5b58\u653e\u8def\u5f84  
  39. web.view.prefix=/WEB-INF/views/  
  40. web.view.suffix=.jsp  
  41. web.maxUploadSize=10485760  
  42.   
  43. #\u9759\u6001\u6587\u4ef6\u540e\u7f00  
  44. web.staticFile=.css,.js,.png,.jpg,.gif,.jpeg,.bmp,.ico,.swf,.psd,.htc,.htm,.html,.crx,.xpi,.exe,.ipa,.apk  
  45.   
  46. #--------------Email SMTP --------------  
  47. mail.host=smtp.163.com  
  48. mail.port=25  
  49. mail.username=test@163.com  
  50. mail.password=test  
  51. mail.smtp.auth=true  
  52. mail.smtp.timeout=30000  
  53. mail.default.from=test@163.com  
  54.   
  55. #-------------- JMS --------------  
  56. mq.brokerURL=failover\:(tcp\://127.0.0.1\:61616)?randomize\=false&initialReconnectDelay\=1000&maxReconnectDelay\=30000  
  57. mq.userName=ant  
  58. mq.password=ant  
  59. mq.pool.maxConnections=20  
  60. #queueName  
  61. queueName.task=task_queue_1  
  62. </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.     <!-- 全局参数 -->  
  6.     <settings>  
  7.         <!-- 使全局的映射器启用或禁用缓存。 -->  
  8.         <setting name="cacheEnabled" value="true"/>  
  9.           
  10.         <!-- 全局启用或禁用延迟加载。当禁用时,所有关联对象都会即时加载。 -->  
  11.         <setting name="lazyLoadingEnabled" value="true"/>  
  12.           
  13.         <!-- 当启用时,有延迟加载属性的对象在被调用时将会完全加载任意属性。否则,每种属性将会按需要加载。 -->  
  14.         <setting name="aggressiveLazyLoading" value="true"/>  
  15.           
  16.         <!-- 是否允许单条sql 返回多个数据集 -->  
  17.         <setting name="multipleResultSetsEnabled" value="true"/>  
  18.           
  19.         <!-- 是否可以使用列的别名 (取决于驱动的兼容性) default:true -->  
  20.         <setting name="useColumnLabel" value="true"/>  
  21.           
  22.         <!-- 允许JDBC 生成主键。  -->  
  23.         <setting name="useGeneratedKeys" value="false"/>  
  24.           
  25.         <!-- 指定 MyBatis 如何自动映射  -->    
  26.         <setting name="autoMappingBehavior" value="PARTIAL"/>  
  27.           
  28.         <!-- 这是默认的执行类型  -->  
  29.         <setting name="defaultExecutorType" value="SIMPLE"/>  
  30.           
  31.         <!-- 使用驼峰命名法转换字段。 -->  
  32.         <setting name="mapUnderscoreToCamelCase" value="true"/>  
  33.           
  34.         <!-- 设置本地缓存范围 session:就会有数据的共享 -->  
  35.         <setting name="localCacheScope" value="SESSION"/>  
  36.           
  37.         <!-- 设置但JDBC类型为空时,某些驱动程序 要指定值-->  
  38.         <setting name="jdbcTypeForNull" value="NULL"/>  
  39.           
  40.     </settings>  
  41.       
  42.     <!-- 类型别名 -->  
  43.     <!--分页  -->  
  44.     <typeAliases>  
  45.         <typeAlias alias="Page" type="com.sml.sz.common.persistence.Page" />  
  46.     </typeAliases>  
  47.       
  48.     <!-- 插件配置 -->  
  49.     <plugins>  
  50.         <plugin interceptor="com.sml.sz.common.persistence.interceptor.PaginationInterceptor" />  
  51.     </plugins>  
  52.       
  53. </configuration>  
  54. </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.   
  15.     <description>Spring Configuration</description>  
  16.       
  17.     <!-- 加载配置属性文件 -->  
  18.     <context:property-placeholder ignore-unresolvable="true" location="classpath:ant.properties" />  
  19.       
  20.     <!-- 加载应用属性实例-->  
  21.     <util:properties id="APP_PROP" location="classpath:ant.properties" local-override="true"/>  
  22.       
  23.     <!-- 使用Annotation自动注册Bean,解决事物失效问题:在主容器中不扫描@Controller注解,在SpringMvc中只扫描@Controller注解。  -->  
  24.     <context:component-scan base-package="com.sml.sz"><!-- base-package 如果多个,用“,”分隔 -->  
  25.         <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>  
  26.     </context:component-scan>  
  27.       
  28.     <!-- MyBatis begin -->  
  29.     <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
  30.         <property name="dataSource" ref="dataSource"/>  
  31.         <property name="typeAliasesPackage" value="com.sml.sz"/>  
  32.         <property name="typeAliasesSuperType" value="com.sml.sz.common.persistence.BaseEntity"/>  
  33.         <property name="mapperLocations" value="classpath*:mappings/**/*.xml"/>  
  34.         <property name="configLocation" value="classpath:/mybatis-config.xml"></property>  
  35.     </bean>  
  36.       
  37.     <!-- 扫描basePackage下所有以@MyBatisDao注解的接口 -->  
  38.     <bean id="mapperScannerConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer">  
  39.         <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />  
  40.         <property name="basePackage" value="com.sml.sz.*"/>  
  41.         <property name="annotationClass" value="com.sml.sz.common.persistence.annotation.MyBatisDao"/>  
  42.     </bean>  
  43.       
  44.     <!-- 定义事务 -->  
  45.     <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
  46.         <property name="dataSource" ref="dataSource" />  
  47.     </bean>  
  48.       
  49.     <!-- 配置 Annotation 驱动,扫描@Transactional注解的类定义事务  -->  
  50.     <tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true"/>  
  51.     <!-- MyBatis end -->  
  52.       
  53.     <!-- 配置 JSR303 Bean Validator 定义 -->  
  54.     <bean id="validator" class="org.springframework.validation.beanvalidation.LocalValidatorFactoryBean" />  
  55.   
  56.     <!-- 缓存配置 -->  
  57.     <bean id="cacheManager" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean">  
  58.         <property name="configLocation" value="classpath:${ehcache.configFile}" />  
  59.     </bean>  
  60.       
  61.     <!-- 数据源配置, 使用 BoneCP 数据库连接池 -->  
  62.     <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">   
  63.         <!-- 数据源驱动类可不写,Druid默认会自动根据URL识别DriverClass -->  
  64.         <property name="driverClassName" value="${jdbc.driver}" />  
  65.           
  66.         <!-- 基本属性 url、user、password -->  
  67.         <property name="url" value="${jdbc.url}" />  
  68.         <property name="username" value="${jdbc.username}" />  
  69.         <property name="password" value="${jdbc.password}" />  
  70.           
  71.         <!-- 配置初始化大小、最小、最大 -->  
  72.         <property name="initialSize" value="${jdbc.pool.init}" />  
  73.         <property name="minIdle" value="${jdbc.pool.minIdle}" />   
  74.         <property name="maxActive" value="${jdbc.pool.maxActive}" />  
  75.           
  76.         <!-- 配置获取连接等待超时的时间 -->  
  77.         <property name="maxWait" value="60000" />  
  78.           
  79.         <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->  
  80.         <property name="timeBetweenEvictionRunsMillis" value="60000" />  
  81.           
  82.         <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->  
  83.         <property name="minEvictableIdleTimeMillis" value="300000" />  
  84.           
  85.         <property name="validationQuery" value="${jdbc.testSql}" />  
  86.         <property name="testWhileIdle" value="true" />  
  87.         <property name="testOnBorrow" value="false" />  
  88.         <property name="testOnReturn" value="false" />  
  89.           
  90.         <!-- 打开PSCache,并且指定每个连接上PSCache的大小(Oracle使用)  
  91.         <property name="poolPreparedStatements" value="true" />  
  92.         <property name="maxPoolPreparedStatementPerConnectionSize" value="20" /> -->  
  93.           
  94.         <!-- 配置监控统计拦截的filters -->  
  95.         <property name="filters" value="stat" />   
  96.     </bean>  
  97. </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.   
  8.     <description>Shiro Configuration</description>  
  9.   
  10.     <!-- 加载配置属性文件 -->  
  11.     <context:property-placeholder ignore-unresolvable="true" location="classpath:ant.properties" />  
  12.       
  13.     <!-- Shiro权限过滤过滤器定义 -->  
  14.     <bean name="shiroFilterChainDefinitions" class="java.lang.String">  
  15.         <constructor-arg>  
  16.             <value>  
  17.                 /static/** = anon  
  18.                 /userfiles/** = anon  
  19.                 ${adminPath}/login = authc  
  20.                 ${adminPath}/logout = logout  
  21.                 ${adminPath}/** = user  
  22.                 /act/rest/service/** = user  
  23.                 /ReportServer/** = user  
  24.             </value>  
  25.         </constructor-arg>  
  26.     </bean>  
  27.       
  28.     <!-- 安全认证过滤器 -->  
  29.     <bean id="shiroFilter" class="org.apache.shiro.spring.web.ShiroFilterFactoryBean">  
  30.         <property name="securityManager" ref="securityManager" />  
  31.         <property name="loginUrl" value="${adminPath}/login" />  
  32.         <property name="successUrl" value="${adminPath}?login" />  
  33.         <property name="filters">  
  34.             <map>  
  35.                 <entry key="authc" value-ref="formAuthenticationFilter"/>  
  36.             </map>  
  37.         </property>  
  38.         <property name="filterChainDefinitions">  
  39.             <ref bean="shiroFilterChainDefinitions"/>  
  40.         </property>  
  41.     </bean>  
  42.       
  43.     <!-- 定义Shiro安全管理配置 -->  
  44.     <bean id="securityManager" class="org.apache.shiro.web.mgt.DefaultWebSecurityManager">  
  45.         <property name="realm" ref="systemAuthorizingRealm" />  
  46.         <property name="sessionManager" ref="sessionManager" />  
  47.         <property name="cacheManager" ref="shiroCacheManager" />  
  48.     </bean>  
  49.       
  50.     <!-- 自定义会话管理配置 -->  
  51.     <bean id="sessionManager" class="com.sml.sz.common.security.shiro.session.SessionManager">   
  52.         <property name="sessionDAO" ref="sessionDAO"/>  
  53.           
  54.         <!-- 会话超时时间,单位:毫秒  -->  
  55.         <property name="globalSessionTimeout" value="${session.sessionTimeout}"/>  
  56.           
  57.         <!-- 定时清理失效会话, 清理用户直接关闭浏览器造成的孤立会话   -->  
  58.         <property name="sessionValidationInterval" value="${session.sessionTimeoutClean}"/>  
  59.         <property name="sessionValidationSchedulerEnabled" value="true"/>  
  60.           
  61.         <property name="sessionIdCookie" ref="sessionIdCookie"/>  
  62.         <property name="sessionIdCookieEnabled" value="true"/>  
  63.     </bean>  
  64.   
  65.     <bean id="sessionIdCookie" class="org.apache.shiro.web.servlet.SimpleCookie">  
  66.         <constructor-arg name="name" value="ant.session.id"/>  
  67.     </bean>  
  68.   
  69.     <!-- 自定义Session存储容器 -->  
  70.     <!-- <bean id="sessionDAO" class="com.sml.sz.common.security.shiro.session.JedisSessionDAO">  
  71.         <property name="sessionIdGenerator" ref="idGen" />  
  72.         <property name="sessionKeyPrefix" value="${redis.keyPrefix}_session_" />  
  73.     </bean> -->  
  74.     <bean id="sessionDAO" class="com.sml.sz.common.security.shiro.session.CacheSessionDAO">  
  75.         <property name="sessionIdGenerator" ref="idGen" />  
  76.         <property name="activeSessionsCacheName" value="activeSessionsCache" />  
  77.         <property name="cacheManager" ref="shiroCacheManager" />  
  78.     </bean>  
  79.       
  80.     <!-- 定义授权缓存管理器 -->  
  81.     <bean id="shiroCacheManager" class="org.apache.shiro.cache.ehcache.EhCacheManager">  
  82.         <property name="cacheManager" ref="cacheManager"/>  
  83.     </bean>  
  84.       
  85.     <bean id="lifecycleBeanPostProcessor" class="org.apache.shiro.spring.LifecycleBeanPostProcessor"/>  
  86.       
  87.     <!-- AOP式方法级权限检查  -->  
  88.     <bean class="org.springframework.aop.framework.autoproxy.DefaultAdvisorAutoProxyCreator" depends-on="lifecycleBeanPostProcessor">  
  89.         <property name="proxyTargetClass" value="true" />  
  90.     </bean>  
  91.     <bean class="org.apache.shiro.spring.security.interceptor.AuthorizationAttributeSourceAdvisor">  
  92.         <property name="securityManager" ref="securityManager"/>  
  93.     </bean>  
  94.       
  95. </beans></span>  

 7. 代码结构如下:

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

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






以上是关于 构建dubbo分布式平台-maven构建config配置项目的主要内容,如果未能解决你的问题,请参考以下文章

构建dubbo分布式平台-maven代码结构

构建dubbo分布式平台-maven模块规划和平台功能导图

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

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

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

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