全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

spring与mybatis整合配置文件

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

基本架构:spring+springmvc+mybatis

分布式框架:dubbo+zookeeper

数据库:mysql

数据库连接池:Druid

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

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

2 spring配置文件spring-register.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:dubbo="http://code.alibabatech.com/schema/dubbo" xmlns="http://www.springframework.org/schema/beans"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
  http://www.springframework.org/schema/beans/spring-beans.xsd
  http://code.alibabatech.com/schema/dubbo
  http://code.alibabatech.com/schema/dubbo/dubbo.xsd">
 <!--引入配置文件-->
 <!--  <context:property-placeholder location="classpath:config/jdbc.properties"/>-->
 <bean class="org.springframework.beans.factory.config.PreferencesPlaceholderConfigurer">
  <property name="locations">
   <list>
    <value>classpath:config/zookeeper.properties</value>
    <value>classpath:config/jdbc.properties</value>
    <value>classpath:config/log4j.properties</value>
   </list>
  </property>
 </bean>
 <bean id="userService" class="com.ivan.dubbo.service.impl.UserServiceImpl"/>
 <!--提供方应用信息,用于计算依赖关系-->
 <dubbo:application name="ivan-dubbo-server"></dubbo:application>
 <!--使用zookeeper广播注册中心暴露服务地址-->
  <dubbo:registry protocol="zookeeper" address="127.0.0.1:2181" />
 <!-- 本机 伪集群 测试 -->
 <!-- <dubbo:registry protocol="zookeeper" address="zookeeper://127.0.0.1:4170?backup=127.0.0.1:4180,127.0.0.1:4190" />-->
<!-- <dubbo:registry protocol="zookeeper" address="127.0.0.1:4170,127.0.0.1:4180,127.0.0.1:4190"/>-->
 <!-- <dubbo:registry id="ivan-dubbo-server1" protocol="zookeeper" address="127.0.0.1:4170" />
  <dubbo:registry id="ivan-dubbo-server2" protocol="zookeeper" address="127.0.0.1:4180" />
  <dubbo:registry id="ivan-dubbo-server3" protocol="zookeeper" address="127.0.0.1:4190" />
 -->
 <!---使用dubbo协议在20880端口暴露服务-->
 <dubbo:protocol name="dubbo" port="20880"/>
 <!--
    官方注释:扫描注解包路径,多个包用逗号分隔,不填pacakge表示扫描当前ApplicationContext中所有的类。
    测试发现:此处package不填写包名会无法注册Service,扫描全包需填写包首即可或者填写至类的上一级目录。
   -->
 <dubbo:annotation package="com"/>
 <dubbo:service interface="com.ivan.service.provider.UserService" ref="userService" timeout="1200000"></dubbo:service>
</beans>

3 spring-mybatis.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:tx="http://www.springframework.org/schema/tx" xmlns="http://www.springframework.org/schema/beans"
    xsi:schemaLocation="http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
    http://www.springframework.org/schema/tx
    http://www.springframework.org/schema/tx/spring-tx-4.1.xsd">
 <!--配置数据源-->
 <bean name="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
  <property name="driverClassName" value="${jdbc.driverClassName}" />
  <property name="url" value="${jdbc.url}"/>
  <property name="username" value="${jdbc.username}"/>
  <property name="password" value="${jdbc.password}"/>
  <!--初始化连接池大小-->
  <property name="initialSize" value="5"/>
  <property name="maxActive" value="20"/>
  <!--连接池最小空闲-->
  <property name="minIdle" value="0"/>
  <!--获取连接池最大等待时间-->
  <property name="maxWait" value="60000"/>
  <property name="poolPreparedStatements" value="true"/>
  <property name="maxPoolPreparedStatementPerConnectionSize" value="33"/>
  <!--检测有效sql-->
  <property name="validationQuery" value="${validationQuery}"/>
  <property name="testOnBorrow" value="false"/>
  <property name="testOnReturn" value="false"/>
  <property name="testWhileIdle" value="true"/>
  <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
  <property name="timeBetweenEvictionRunsMillis" value="60000"/>
  <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
  <property name="minEvictableIdleTimeMillis" value="25200000"/>
  <!-- 打开removeAbandoned功能 -->
  <property name="removeAbandoned" value="true"/>
  <!-- 1800秒,也就是30分钟 -->
  <property name="removeAbandonedTimeout" value="1800"/>
  <!-- 关闭abanded连接时输出错误日志 -->
  <property name="logAbandoned" value="true"/>
  <!-- 监控数据库 -->
  <property name="filters" value="mergeStat"/>
 </bean>
 <!--MyBatis配置文件-->
 <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  <property name="dataSource" ref="dataSource"/>
  <property name="mapperLocations" value="classpath*:com/ivan/**/mapping/*.xml"/>
 </bean>
 <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
  <property name="basePackage" value="com.ivan.dubbo.service.dao.mapper"/>
  <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
 </bean>
 <!--配置事务管理-->
 <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
  <property name="dataSource" ref="dataSource"/>
 </bean>
 <!--注解方式配置事务-->
<!-- <tx:annotation-driven transaction-manager="transactionManager"/>-->
 <!-- 拦截器方式配置事物 -->
 <tx:advice id="transactionAdvice" transaction-manager="transactionManager">
  <tx:attributes>
   <tx:method name="insert*" propagation="REQUIRED"/>
   <tx:method name="update*" propagation="REQUIRED"/>
   <tx:method name="delete*" propagation="REQUIRED"/>
   <tx:method name="get*" propagation="SUPPORTS" read-only="true"/>
   <tx:method name="find*" propagation="SUPPORTS" read-only="true"/>
   <tx:method name="select*" propagation="SUPPORTS" read-only="true"/>
  </tx:attributes>
 </tx:advice>
 <!--
<span style="font-family:FangSong_GB2312;">       </span>Spring aop事务管理
<span style="font-family:FangSong_GB2312;">       此处配置正确无法发布提供者服务,目前没找到解决方案</span>
    -->
 <!-- <aop:config>
   <aop:pointcut id="transactionPointcut" expression="execution(* com.ivan..service.impl.*Impl.*(..))" />
   <aop:advisor advice-ref="transactionAdvice" pointcut-ref="transactionPointcut"/>
 </aop:config> -->
</beans>

总结

以上所述是小编给大家介绍的spring与mybatis整合配置文件,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# spring  # mybatis  # 整合  # Spring整合SpringMVC + Mybatis基础框架的配置文件详解  # springboot的yml配置文件通过db2的方式整合mysql的教程  # spring boot-2.1.16整合swagger-2.9.2 含yml配置文件的代码详解  # Spring 整合多个配置文件的方法  # spring+hibernate 两种整合方式配置文件的方法  # Spring配置文件的拆分和整合过程分析  # 配置文件  # 连接池  # 小编  # 多个  # 在此  # 给大家  # 本机  # 现将  # 所述  # 给我留言  # 感谢大家  # 池中  # 全包  # 疑问请  # 有任何  # 多久  # 拦截器  # 整合了  # schemaLocation  # xsd 


相关文章: 如何设置并定期更换建站之星安全管理员密码?  网站按钮制作软件,如何实现网页中按钮的自动点击?  小捣蛋自助建站系统:数据分析与安全设置双核驱动网站优化  常州企业网站制作公司,全国继续教育网怎么登录?  微网站制作教程,我微信里的网站怎么才能复制到浏览器里?  C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?  如何快速搭建高效简练网站?  如何快速搭建高效香港服务器网站?  如何通过智能用户系统一键生成高效建站方案?  免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?  大连网站制作公司哪家好一点,大连买房网站哪个好?  建站之星ASP如何实现CMS高效搭建与安全管理?  如何通过商城免费建站系统源码自定义网站主题?  公司门户网站制作流程,华为官网怎么做?  西安专业网站制作公司有哪些,陕西省建行官方网站?  如何选购建站域名与空间?自助平台全解析  武清网站制作公司,天津武清个人营业执照注销查询系统网站?  公司网站制作价格怎么算,公司办个官网需要多少钱?  免费ppt制作网站,有没有值得推荐的免费PPT网站?  C++中引用和指针有什么区别?(代码说明)  网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?  微信小程序 input输入框控件详解及实例(多种示例)  交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?  建站之星在线客服如何快速接入解答?  盐城做公司网站,江苏电子版退休证办理流程?  实例解析angularjs的filter过滤器  jQuery 常见小例汇总  如何高效利用亚马逊云主机搭建企业网站?  天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?  网站制作壁纸教程视频,电脑壁纸网站?  建站168自助建站系统:快速模板定制与SEO优化指南  如何高效利用200m空间完成建站?  盘锦网站制作公司,盘锦大洼有多少5G网站?  如何通过FTP服务器快速搭建网站?  建站主机服务器选购指南:轻量应用与VPS配置解析  Swift开发中switch语句值绑定模式  宝盒自助建站智能生成技巧:SEO优化与关键词设置指南  金*站制作公司有哪些,金华教育集团官网?  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  如何确认建站备案号应放置的具体位置?  建站主机功能解析:服务器选择与快速搭建指南  建站主机服务器选型指南与性能优化方案解析  网站制作员失业,怎样查看自己网站的注册者?  网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何通过老薛主机一键快速建站?  建站为何优先选择香港服务器?  高端云建站费用究竟需要多少预算? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。