Pom文件
1.首先是父依赖spring-boot-starter-parent:统一springboot相关依赖的版本,导入依赖时只需要依赖名即可,不用版本,例如:
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.8.RELEASE</version>
<relativePath/>
</parent>
2.properties配置:在标签内可以把版本号作为变量进行声明,后面dependency中用到版本号时可以用${变量名}的形式代替,这样做的好处是:当版本号发生改变时,只有更新properties标签中的变量就行了,不用更新所有依赖的版本号,例如:
<properties>
<mybatis-plus-generator.version>3.2.0</mybatis-plus-generator.version>
<lombok>1.18.8</lombok>
<velocity-engine-core>2.2</velocity-engine-core>
<mybatis-plus-boot-starter>3.2.0</mybatis-plus-boot-starter>
<mysql.version>8.0.17</mysql.version>
</properties>
3.SpringBoot项目web程序的必须依赖spring-boot-starter-web:spring-boot-starter-web 为我们提供了嵌入的 Servlet 容器以及 SpringMVC 的依赖,并为 Spring MVC 提供了大量自动配置,可以适用于大多数 Web 开发场景,例如:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
4.junit:提供单元测试的依赖,不是必须,但是推荐,好用!
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
5.spring-boot-starter-thymeleaf:用来渲染html页面,最大作用还是自动帮我们配置项目的静态资源、html文件的路径。
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
6.log4j:打印日志
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
7.mysql-connector-java:mysql连接,web项目不可避免的跟数据库打交道。
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency>
8.druid:阿里的数据库连接池,Springboot1.版本的数据连接池是tomcat的JDBC连接池(Tomcat JDBC Pool)Springboot2.x版本默认的数据库连接池是Hikari,而连接池的作用:众所周知,建立数据库连接耗时耗费资源,一个数据库服务器能够同时建立的连接数也是有限的,在大型的Web应用中,可能同时会有成百上千的访问数据库的请求,如果Web应用程序为每一个客户请求分配一个数据库连接,将导致性能的急剧下降。数据库连接池的意义在于,能够重复利用数据库连接
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.10</version>
</dependency>
配置文件
1.application.properties:用来配置项目的配置,例如:端口。我们也可以使用ymal来写,比properties格式更简洁
server.port=8080
application.yaml写法
spring:
datasource:
url: jdbc:mysql://localhost:3306/bigdata_covid19?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC&nullCatalogMeansCurrent=true
username: root
password: 123456
driver-class-name: com.mysql.cj.jdbc.Driver
2.log4j.properties:log4j日志配置
### 设置###
log4j.rootLogger = INFO,stdout
### 输出信息到控制台 ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n
3.druid配置文件
spring:
datasource:
username: root
password: 123456
url: jdbc:mysql://localhost:3306/bigdata_covid19?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC
driver-class-name: com.mysql.jdbc.Driver
# 配置数据连接池类型
type: com.alibaba.druid.pool.DruidDataSource
#Spring Boot 默认是不注入这些属性值的,需要自己绑定
#druid 数据源专有配置
# 配置连接池初始化大小、最小
initialSize: 10
# 连接池中允许的最小的连接数量,少于它则创建连接
minIdle: 5
# 最大线程数,CPU核数+1,也可以大些但不要超过20,数据库加锁时连接过多性能下降
maxActive: 20
# 配置获取连接等待超时的时间
maxWait: 60000
timeBetweenEvictionRunsMillis: 60000
# 配置一个连接在池中最大空闲时间,单位是毫秒
minEvictableIdleTimeMillis: 300000
validationQuery: SELECT 1
testWhileIdle: true
# 设置从连接池获取连接时是否检查连接有效性,true检查,false不检查
testOnBorrow: false
# 设置从连接池归还连接时是否检查连接有效性,true检查,false不检查
testOnReturn: false
# 可以支持PSCache(提升写入、查询效率),在mysql下建议关闭
poolPreparedStatements: false
# 配置监控统计拦截的filters,stat:监控统计、log4j:日志记录、wall:防御sql注入
#如果允许时报错 java.lang.ClassNotFoundException: org.apache.log4j.Priority
#则导入 log4j 依赖即可,Maven 地址:https://mvnrepository.com/artifact/log4j/log4j
filters: stat,wall,log4j
maxPoolPreparedStatementPerConnectionSize: 20
useGlobalDataSourceStat: true
connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=500
启动类
@SpringBootApplication
public class WebUiApplication {
public static void main(String[] args) {
SpringApplication.run(WebUiApplication.class,args);
}
}
|