最近因为项目的原因,开始学习了一下springboot,我看大多数人写的springboot的demo都是单个maven工程的,而如果按web,service,dao这样按层分成不同的maven项目后,关于application.properties的放置,加载问题困扰了我大半天。期初我在service工程,web工程都放置了application.properties,但是springboot项目中只能有一个application.properties配置,导致我的service工程无法自动读取application.properties中的配置自动加载数据源。
先说明一下工程结构如下,jykjParent是一个maven的聚合工程,其他的都是maven module工程,web引用core(service层,数据库业务处理),facade中定义了model、interface,common是一些公用的工具类。
关键的pom引用
org.mybatis.spring.boot
mybatis-spring-boot-starter
1.3.2
com.github.drtrang
druid-spring-boot2-starter
1.1.10
在web工程的主配置文件application.properties中用 spring.profiles.active=coreDev,webDev 来引用core工程,web工程的配置,这样既可以把配置按层分开配置,又可以多环境灵活切换(生产用spring.profiles.active=corePro,webPro ),问题完美解决!完美!
说明:application-coreDev.properties里面主要是数据源,缓存等配置,application-webDev.properties主要是web的一些路径、文件上传、端口等配置。
下面贴下两者的具体配置
application-coreDev.properties配置如下
# Druid\u8FDE\u63A5\u6C60\u914D\u7F6E\uFF0C\u5B98\u65B9\u914D\u7F6E\u53C2\u8003\uFF1Ahttps://github.com/alibaba/druid/tree/master/druid-spring-boot-starter
spring.datasource.druid.url=jdbc:mysql://localhost:3306/edu_dev?useUnicode=true&characterEncoding=utf8
spring.datasource.druid.username=root
spring.datasource.druid.password=root
spring.datasource.druid.initial-size=5
spring.datasource.druid.max-active=20
spring.datasource.druid.min-idle=10
spring.datasource.druid.max-wait=10
spring.datasource.druid.filters=stat,wall
spring.datasource.druid.filter.stat.log-slow-sql=true
spring.datasource.druid.filter.stat.slow-sql-millis=2000
# Druid WebStatFilter\u914D\u7F6E\uFF0C\u8BF4\u660E\u8BF7\u53C2\u8003Druid Wiki\uFF0C\u914D\u7F6E_\u914D\u7F6EWebStatFilter
#spring.datasource.druid.web-stat-filter.enabled=true
#spring.datasource.druid.web-stat-filter.url-pattern=/*
#spring.datasource.druid.web-stat-filter.exclusions=*.gif,*.png,*.jpg,*.html,*.js,*.css,*.ico,/druid/*
# Druid StatViewServlet\u914D\u7F6E\uFF0C\u8BF4\u660E\u8BF7\u53C2\u8003Druid Wiki\uFF0C\u914D\u7F6E_StatViewServlet\u914D\u7F6E
spring.datasource.druid.stat-view-servlet.enabled=true
spring.datasource.druid.stat-view-servlet.url-mappings=/druid/*
spring.datasource.druid.stat-view-servlet.reset-enable=true
spring.datasource.druid.stat-view-servlet.login-username=admin
spring.datasource.druid.stat-view-servlet.login-password=admin
spring.datasource.druid.stat-view-servlet.allow=
spring.datasource.druid.stat-view-servlet.deny=
#Mybatis\u914D\u7F6E,\u5B98\u65B9\u53C2\u8003\uFF1Ahttp://www.mybatis.org/spring-boot-starter/mybatis-spring-boot-autoconfigure/
mybatis.mapperLocations=classpath*:mybatis/*.xml
mybatis.typeAliasesPackage=com.wkp.jykj.model
application-webDev.properties配置如下
server.port=8086
server.servlet.context-path=/jykj
logging.level.root=debug
core工程中关于数据源的关键代码如下
@Configuration
@MapperScan("com.wkp.jykj.dao")
public class SpringScan {
@Resource
private PlatformTransactionManager transactionManager;
@Bean
public TransactionTemplate jykjTransactionTemplate(){
TransactionTemplate jykjTransactionTemplate = new TransactionTemplate(transactionManager);
jykjTransactionTemplate.setIsolationLevelName("ISOLATION_DEFAULT");
jykjTransactionTemplate.setPropagationBehaviorName("PROPAGATION_REQUIRES_NEW");
return jykjTransactionTemplate;
}
}
然后就可以在springboot中使用编程式事务了。就是这么完美,哈哈!
package com.wkp.jykj.service;
import javax.annotation.Resource;
import org.springframework.stereotype.Service;
import org.springframework.transaction.TransactionStatus;
import org.springframework.transaction.support.TransactionCallback;
import org.springframework.transaction.support.TransactionTemplate;
import com.wkp.jykj.dao.EdusBanksMapper;
import com.wkp.jykj.model.EdusBanks;
@Service
public class EdusBanksService {
@Resource
private EdusBanksMapper edusBanksMapper;
@Resource
private TransactionTemplate jykjTransactionTemplate;
public EdusBanks testTran(Long id){
if(id==null){
return null;
}
return jykjTransactionTemplate.execute(new TransactionCallback() {
@Override
public EdusBanks doInTransaction(TransactionStatus arg0) {
return edusBanksMapper.findById(id);
}
});
}
}