zoukankan      html  css  js  c++  java
  • spring,mybatis整合配置文件

    最近因为项目要求整合了spring+mybatis架构进行项目开发,现将相关整合配置文件整理如下:

    基本架构:spring+springmvc+mybatis

    分布式框架:dubbo+zookeeper

    数据库:mysql

    数据库连接池:Druid

    1 数据库连接配置信息jdbc.properties

    1 #mysql version database druid
    2 # setting
    3 validationQuery=SELECT 1  
    4 jdbc.driverClassName=com.mysql.jdbc.Driver  
    5 jdbc.url=jdbc:mysql://localhost:3306/ivan?useUnicode=true&characterEncoding=utf-8&useSSL=true 
    6 jdbc.username=root
    7 jdbc.password=root

    2 spring配置文件spring-register.xml

     1 <?xml version="1.0" encoding="UTF-8"?>
     2 <beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     3        xmlns:dubbo="http://code.alibabatech.com/schema/dubbo" xmlns="http://www.springframework.org/schema/beans"
     4        xsi:schemaLocation="http://www.springframework.org/schema/beans
     5     http://www.springframework.org/schema/beans/spring-beans.xsd
     6     http://code.alibabatech.com/schema/dubbo
     7     http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
     8 
     9   <!--引入配置文件-->
    10   <!--   <context:property-placeholder location="classpath:config/jdbc.properties"/>-->
    11   <bean class="org.springframework.beans.factory.config.PreferencesPlaceholderConfigurer">
    12     <property name="locations">
    13       <list>
    14         <value>classpath:config/zookeeper.properties</value>
    15         <value>classpath:config/jdbc.properties</value>
    16         <value>classpath:config/log4j.properties</value>
    17       </list>
    18     </property>
    19   </bean>
    20   <bean id="userService" class="com.ivan.dubbo.service.impl.UserServiceImpl"/>
    21   <!--提供方应用信息,用于计算依赖关系-->
    22   <dubbo:application name="ivan-dubbo-server"></dubbo:application>
    23 
    24   <!--使用zookeeper广播注册中心暴露服务地址-->
    25    <dubbo:registry protocol="zookeeper" address="127.0.0.1:2181" />
    26 
    27   <!-- 本机 伪集群 测试 -->
    28   <!--  <dubbo:registry  protocol="zookeeper"  address="zookeeper://127.0.0.1:4170?backup=127.0.0.1:4180,127.0.0.1:4190"  />-->
    29 <!--  <dubbo:registry protocol="zookeeper" address="127.0.0.1:4170,127.0.0.1:4180,127.0.0.1:4190"/>-->
    30 
    31   <!-- <dubbo:registry id="ivan-dubbo-server1"  protocol="zookeeper"  address="127.0.0.1:4170"  />
    32    <dubbo:registry id="ivan-dubbo-server2"  protocol="zookeeper"  address="127.0.0.1:4180"  />
    33    <dubbo:registry id="ivan-dubbo-server3"  protocol="zookeeper"  address="127.0.0.1:4190"  />
    34  -->
    35   <!---使用dubbo协议在20880端口暴露服务-->
    36   <dubbo:protocol name="dubbo" port="20880"/>
    37 
    38   <!--
    39         官方注释:扫描注解包路径,多个包用逗号分隔,不填pacakge表示扫描当前ApplicationContext中所有的类。
    40         测试发现:此处package不填写包名会无法注册Service,扫描全包需填写包首即可或者填写至类的上一级目录。
    41      -->
    42   <dubbo:annotation package="com"/>
    43 
    44   <dubbo:service interface="com.ivan.service.provider.UserService" ref="userService"  timeout="1200000"></dubbo:service>
    45 
    46 </beans>

    3 spring-mybatis.xml

     1 <?xml version="1.0" encoding="UTF-8"?>
     2 <beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     3        xmlns:tx="http://www.springframework.org/schema/tx" xmlns="http://www.springframework.org/schema/beans"
     4        xsi:schemaLocation="http://www.springframework.org/schema/beans
     5         http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
     6         http://www.springframework.org/schema/tx
     7         http://www.springframework.org/schema/tx/spring-tx-4.1.xsd">
     8   <!--配置数据源-->
     9   <bean name="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
    10     <property name="driverClassName" value="${jdbc.driverClassName}" />
    11     <property name="url" value="${jdbc.url}"/>
    12     <property name="username" value="${jdbc.username}"/>
    13     <property name="password" value="${jdbc.password}"/>
    14 
    15     <!--初始化连接池大小-->
    16     <property name="initialSize" value="5"/>
    17     <property name="maxActive" value="20"/>
    18 
    19     <!--连接池最小空闲-->
    20     <property name="minIdle" value="0"/>
    21     <!--获取连接池最大等待时间-->
    22     <property name="maxWait" value="60000"/>
    23     <property name="poolPreparedStatements" value="true"/>
    24     <property name="maxPoolPreparedStatementPerConnectionSize" value="33"/>
    25 
    26     <!--检测有效sql-->
    27     <property name="validationQuery" value="${validationQuery}"/>
    28     <property name="testOnBorrow" value="false"/>
    29     <property name="testOnReturn" value="false"/>
    30     <property name="testWhileIdle" value="true"/>
    31 
    32     <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
    33     <property name="timeBetweenEvictionRunsMillis" value="60000"/>
    34     <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
    35     <property name="minEvictableIdleTimeMillis" value="25200000"/>
    36     <!-- 打开removeAbandoned功能 -->
    37     <property name="removeAbandoned" value="true"/>
    38     <!-- 1800秒,也就是30分钟 -->
    39     <property name="removeAbandonedTimeout" value="1800"/>
    40     <!-- 关闭abanded连接时输出错误日志 -->
    41     <property name="logAbandoned" value="true"/>
    42     <!-- 监控数据库 -->
    43     <property name="filters" value="mergeStat"/>
    44 
    45   </bean>
    46   <!--MyBatis配置文件-->
    47   <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    48     <property name="dataSource" ref="dataSource"/>
    49     <property name="mapperLocations" value="classpath*:com/ivan/**/mapping/*.xml"/>
    50   </bean>
    51   <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    52     <property name="basePackage" value="com.ivan.dubbo.service.dao.mapper"/>
    53     <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
    54   </bean>
    55   <!--配置事务管理-->
    56   <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    57     <property name="dataSource" ref="dataSource"/>
    58   </bean>
    59   <!--注解方式配置事务-->
    60 <!--  <tx:annotation-driven transaction-manager="transactionManager"/>-->
    61   <!-- 拦截器方式配置事物 -->
    62   <tx:advice id="transactionAdvice" transaction-manager="transactionManager">
    63     <tx:attributes>
    64       <tx:method name="insert*" propagation="REQUIRED"/>
    65       <tx:method name="update*" propagation="REQUIRED"/>
    66       <tx:method name="delete*" propagation="REQUIRED"/>
    67 
    68       <tx:method name="get*" propagation="SUPPORTS" read-only="true"/>
    69       <tx:method name="find*" propagation="SUPPORTS" read-only="true"/>
    70       <tx:method name="select*" propagation="SUPPORTS" read-only="true"/>
    71 
    72     </tx:attributes>
    73   </tx:advice>
    74   <!--
    75 <span style="font-family:FangSong_GB2312;">             </span>Spring aop事务管理
    76 <span style="font-family:FangSong_GB2312;">             此处配置正确无法发布提供者服务,目前没找到解决方案</span>
    77 
    78        -->
    79   <!-- <aop:config>
    80       <aop:pointcut id="transactionPointcut"  expression="execution(* com.ivan..service.impl.*Impl.*(..))" />
    81       <aop:advisor advice-ref="transactionAdvice" pointcut-ref="transactionPointcut"/>
    82   </aop:config> -->
    83 
    84 </beans>

     

  • 相关阅读:
    mysql 双机互备份
    ubuntu12.04 qtcreate支持中文输入
    新版IDEA 2020.1遇到的坑Error:(3,32)java:程序包org.springframework.boot不存在Error:
    No partition predicate found for Alias "TS" Table ""
    SQL语句中sum与count的区别
    :line 1:100 cannot recognize input near '<EOF>' '<EOF>' '<EOF>' in statement
    mysql计算某个字段最长值
    mysql字段varchar长度分配对性能的影响
    【MySQL】NOT NULL default 0
    FAILED: NoMatchingMethodException No matching method for class org.apache.hadoop.hive.ql.udf.UDFToString with (struct<hashtags:array<string>
  • 原文地址:https://www.cnblogs.com/anqli-java/p/7567478.html
Copyright © 2011-2022 走看看