springboot开发常用知识
- 命令行打包
- SpringBoot打包插件
- window端口命令
- 临时属性设置
- 热部署
- 启动热部署
- 热部署范围
- 常用计量单位
- 数据校验
- 加载测试的专用属性
- Web环境模拟测试
- 如何发送虚拟请求
- 业务层测试回滚
- 随机产生测试用例
- 内置数据源
命令行打包
- 对SpringBoot项目进行打包命令行命令
mvn package
SpringBoot打包插件
<build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build>
通过打包插件打包出来的Boot应用程序,可以独立运行,在jar包的目录中将自己开发的东西放在classes文件下,依赖放在lib下,在上一级目录org中存放对应的类加载器相关文件以及运行所必须的工具包,能够通过独立操作运行jar包程序
window端口命令
临时属性设置
带属性数启动SpringBoot
java -jar 工程名.jar --属性名=值
java -jar springboot.jar --server.port=80
通常在上线运维的时候需要用到临时的属性设置达到某些目的
携带多个属性启动SpringBoot,属性间使用空格分隔
临时工程属性必须是当前boot工程支持的属性,否则设置无效
- 属性加载顺序
上述是按照从低到高进行排列
如何在程序运行的时候加一些临时属性:
选择选项
在其中添加临时属性
--server.port=8081
通过编程形式带参数启动SpringBoot程序,为程序添加运行参数
public static void main(String[] args){
String[] arg=new String[1];
arg[0]="--server.port=8081";
}
不携带参数启动SpringBoot程序:
public static void main(String[] args){
SpringApplication.run(application.class,arg);}
上述讲的是在本机开发中程序员自行进行的配置测试,但是在真正上线的时候用的却是另一套配置,那么这种情况怎么处理,难道还是写一些临时属性吗?
这里我们通过创建新的配置文件,在上线的时候对当前配置文件进行覆盖
这就牵扯到了配置文件的等级:
这里的classpath是在类路径下的配置文件
而file是在工程目录下创建的目录
- 资源目录下自定义配置文件
在资源目录下创建一个配置文件,如何让这个配置文件生效
在其中输入: --spring.config.name=ebark 这种是按照配置文件的名称进行修改的
还可以通过路径进行修改: --spring.config.location=路径
热部署
在项目中更改业务代码后无需重新启动服务器加载项目即可完成自动改变
启动热部署
添加依赖:
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId></dependency>
激活热部署:ctrl+F9
关于热部署:
重启:自定义开发代码,包含类,页面,配置文件等,加载位置restart类加载器
重载:jar包,加载位置base类加载器
热部署仅仅加载当前开发者自定义开发的资源,不加载jar资源
- 自动激活热部署
将Build project automatically勾选
然后按下ctrl+alt+shift+/
进行勾选
热部署范围
默认不进行热部署的目录列表
在配置文件中可以进行范围的设置:
设置不参与热部署的文件
devtools:restart:exclude: static/**,...
- 关闭热部署功能:
在配置文件中进行关闭
devtools:restart:exclude: static/**,...enabled: false
常用计量单位
SpringBoot支持JDK8提供的时间与空间计量单位
@ConfigurationProperties(prefix="servers")
public class ServerConfig{
//设置时间的单位@DurationUnit(ChronoUnit.MINUTES)private Duration serverTimeOut;
//设置数据存储容量的单位@DataSizeUnit(DataUnit.MEGABYTES) //设置存储容量的单位private Datasize dataSize;
}
数据校验
在进行业务之前对数据都进行一个有效的数据校验,可以提高配置或者业务数据的安全性
添加数据校验的依赖并使用hibernate框架提供的校验器做实现类
<dependency><groupId>javax.validation</groupId><artifactId>validation-api</artifactId><version>2.0.1.Final</version></dependency><dependency><groupId>org.hibernate.validator</groupId><artifactId>hibernate-validator</artifactId></dependency>
使用注解 @Vaildated注解类表明对类进行数据校验
在属性上方通过注解进行校验规格说明
@Vaildated
public class ServerConfig{@Max(value=4545,message="最大值不能超过4545")private int port;
}
加载测试的专用属性
在测试阶段加载一些自己的专有属性
@SpringBootTest(properties={"test.prop=testValue1"},args={"--test.prop=testValue2"})
public class PropertiesAndArgsTest{
@value("${test.prop}")
private String msg;
}
因为优先级的缘故使用args中的属性设置
Web环境模拟测试
在测试类中,无法进行web环境下的开发测试,无法启用端口进行测试,我们通过给出模拟端口进行web开发测试
模拟端口:
@SpringBootTest(webEnvironment=SpringBootTest.WebEnvironment.RANDOM_PORT)
public class WebTest{
}
如何发送虚拟请求
在测试中,如何用虚拟的请求进行测试
@SpringBootTest
//开启虚拟MVC调用
@AutoConfigureMockMVC
public class WebTest{
@Test
//注入一个MockMvc对象就可以进行虚拟请求
void test1(@Autowired MockMvc mvc){
//模拟一个虚拟的http请求
MockHttpServletRequestBuilder builder=MockHttpServletRequestBuilders.get("/");
//执行对应的请求
mvc.perform(builder);
}
}
- 设定预期值,与真实值进行比较,成功则测试通过
@SpringBootTest
//开启虚拟MVC调用
@AutoConfigureMockMVC
public class WebTest{
@Test
//注入一个MockMvc对象就可以进行虚拟请求
void test1(@Autowired MockMvc mvc){
//模拟一个虚拟的http请求
MockHttpServletRequestBuilder builder=MockHttpServletRequestBuilders.get("/");
//执行对应的请求
ResultActions action=mvc.perform(builder);//定义本次调用的预期值
StatusResultMachers status=MockMvcResultMatchers.status();
//预计本次调用成功的:状态200
ResultMathcher ok =status.isOK();
//添加预计值到本次过程中进行匹配
action.andExpect(ok);
}
}
业务层测试回滚
在项目开发的工程中,如果出现在测试中测试数据但是会出现最后项目运行的时候造成测试类中的数据影响数据库,这个时候可以通过在测试类中添加事务的回滚避免这种现象的发生
@springBootTest
//添加事务注解
@Transactional
@Rollback(true) //控制默认进行回滚
public class Test2{
}
随机产生测试用例
在配置文件中配置随机测试的数据:
testcase:book:id: ${random.int}name: ${random.value}
然后在测试类中加载随机数据
@Compoment
@Data
@ConfigurationProperties(prefix="testcase.book")
public class Bookcase{
private int id;
private String name;
}
注意:一般测试开发的时候配置在多环境下进行
内置数据源
前面我们数据库连接都采用的阿里巴巴的druid数据源进行开发,如果我们不再使用它,那么系统会采用内置的数据源:
- HikariCP
- Tomcat提供DataSource
- Commons DBCP
例如使用HikariCP:
Spring:datasource:url: ...hikari: driver:username:password:# 连接池的最大数量maximum-pool-size: 50