目录
SpringBoot指标监控_添加Actuator功能
SpringBoot指标监控_Spring Boot Admin
SpringBoot日志管理
SpringBoot项目部署_项目打包
SpringBoot项目部署_多环境配置
SpringBoot容器化部署_安装Docker环境
SpringBoot容器化部署_Dockerfile制作镜像
SpringBoot容器化部署_Maven插件制作镜像
Spring Task_定时任务
Spring Task_入门案例
Spring Task_Cron表达式
Spring Task_Cron实战案例
Spring Task_@Scheduled
Spring Task_多线程任务
Spring Boot Actuator可以帮助程序员监控和管理SpringBoot应 用,比如健康检查、内存使用情况统计、线程使用情况统计等。我 们在SpringBoot项目中添加Actuator功能,即可使用Actuator监控 项目,用法如下:
1.在被监控的项目中添加Actuator起步依赖
org.springframework.boot
spring-boot-starter-actuator
2.编写配置文件
#开启所有监控端点
management.endpoints.web.exposure.include= *
3.访问项目:http://localhost:8080/actuator
通过URL可以调用actuator的功能:
Actuator使用JSON格式展示了大量指标数据,不利于我们查看,我 们可以使用可视化工具Spring Boot Admin查看actuator生成指标 数据。Spring Boot Admin是一个独立的项目,我们需要创建并运 行该项目。
创建Spring Boot Admin服务端项目
1.创建SpringBoot项目,添加SpringMVC和Spring Boot Admin服 务端起步依赖
org.springframework.boot
spring-boot-starter-web
de.codecentric
spring-boot-admin-starter-server
2.修改配置文件
# 端口号
server.port=9090
#日志格式
logging.pattern.console=%d{HH:mm:ss.SSS} %clr(%-5level) --- [%-15thread] %cyan(%-50logger{50}):%msg%n
3.修改启动类
@SpringBootApplication
@EnableAdminServer //开启Spring Boot Admin
服务端
public class MyadminApplication {
public static void main(String[] args)
{
SpringApplication.run(MyadminApplication.class, args);
}
}
连接Spring Boot Admin项目 在被监控的项目中连接Spring Boot Admin项目,才能使用Spring Boot Admin查看指标数据。
1.被监控项目添加Spring Boot Admin客户端起步依赖
de.codecentric
spring-boot-admin-starter-client
2.6.0
2.修改配置文件
#Spring boot admin访问地址
spring.boot.admin.client.url=http://localhost:9090
3.此时Spring Boot Admin即可连接被监控的项目
SpringBoot默认使用Logback组件作为日志管理。Logback是log4j 创始人设计的一个开源日志组件。在SpringBoot项目中我们不需要 额外的添加Logback的依赖,因为在 spring-boot-parent 中已经包含了 Logback的依赖。
1.在 /resources 下添加Logback配置文件logback.xml
%d{MM-dd HH:mm:ss.SSS} [%thread] %-5level%logger{50} - %msg%n
${LOG_HOME}/server.%d{yy 99-MM-dd}.log
30
%d{HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n
10MB
注:Logback配置文件名为logback-test.xml或 logback.xml,如果classpath下没有这两个文件,LogBack 会自动进行最小化配置。
2.在代码中打印日志
@Controller
public class LogbackController {
private final static Logger logger = LoggerFactory.getLogger(LogbackController.class);
@RequestMapping("/printLog")
@ResponseBody
public String showInfo(){
logger.info("记录日志");
return "Hello Logback";
}
}
3.如果日志过多,可以屏蔽一些包的日志,在配置文件中配置
#屏蔽org包中的日志输出
logging.level.org=off
补充:Log4j2安全漏洞 在2021年12月,Log4j2爆出了极其严重的安全漏洞,攻击者可 以让记录的日志包含指定字符串,从而执行任意程序。很多大 型网站,如百度等都是此次Log4j漏洞的受害者,很多互联网企 业连夜做了应急措施。 Log4j2.0到2.14.1全部存在此漏洞,危害范围极其广泛, Log4j2.15.0-rc1中修复了这个 bug。
因Log4j2漏洞的反复无常,导致某些公司已经切换到Logback 来记录日志,但在Log4j2漏洞爆出后,Logback也爆出漏洞: 在Logback1.2.7及之前的版本中,具有编辑配置文件权限的攻 击者可以制作恶意配置,允许从LDAP服务器加载、执行任意代 码。 解决方案为将Logback升级到安全版本: Logback1.2.9+ SpringBoot2.6.2以上的Logback版本已经升到了1.2.9,Log4j2 的版本也升到了2.17.0,所以我们使用SpringBoot2.6.2以上版 本无需担心Log4j2和Logback安全漏洞。
SpringBoot项目是依赖于Maven构建的,但打包时如果只依赖 Maven打包工具则会打包不完整,我们还需要在SpringBoot项目中 引入SpringBoot打包插件 :
org.springframework.boot
spring-boot-mavenplugin
此时再使用Maven插件打包:
打包后jar包解压目录如下:
可以看到该目录少了BOOT-INF,打包是不完整的,也无法运行jar 包
运行jar包:
1 进入jar包所在目录,使用cmd打开命令行窗口
2 输入命令:
java -jar jar包名
在真实开发中,在不同环境下运行项目往往会进行不同的配置,比 如开发环境使用的是开发数据库,测试环境使用的是测试数据库, 生产环境使用的是生产数据库。SpringBoot支持不同环境下使用不 同的配置文件,用法如下:
配置文件名:
application-环境名.properties/yml
如:
1 application-dev.properties/yml 开发环境配置文件
# 开发环境端口号为8080 server: port: 8080
2 application-test.properties/yml 测试环境配置文件
# 测试环境端口号为8081 server: port: 8081
3 application-prod.properties/yml 生产环境配置文件
# 生产环境端口号为80 server: port: 80
运行jar包时选择环境:
java -jar jar包名 --spring.profiles.active=环 境名
为了节约资源,在生产环境中我们更多的是使用Docker容器部署 SpringBoot应用,首先我们准备Docker环境:
1 准备一台centos7系统的虚拟机,连接虚拟机。
2 关闭虚拟机防火墙
# 关闭运行的防火墙 systemctl stop firewalld.service # 禁止防火墙自启动 systemctl disable firewalld.service
3. 安装Docker
# 安装Docker yum -y install docker # 启动docker systemctl start docker
由于在SpringBoot中嵌入了Web容器,所以在制作SpringBoot项目 的镜像时无需依赖Web容器,基于JDK制作镜像即可,接下来我们 使用Dockerfile制作镜像:
1.进入opt目录
cd /opt
2 使用rz命令将项目Jar包上传至虚拟机
3 编写DockerFile
cat <
Dockerfile # 基于JDK11 FROM openjdk:11 # 作者 MAINTAINER itbaizhan # 拷贝到容器opt目录 ADD springbootdemo7-0.0.1-SNAPSHOT.jar /opt #保留端口 EXPOSE 8080 # 启动容器后执行的命令 CMD java -jar /opt/springbootdemo7-0.0.1- SNAPSHOT.jar --spring.profiles.active=dev EOF 4.构建镜像
docker build -t springbootdocker .
5.查看所有的镜像,出现springbootdocker代表镜像构建成功
docker images
6.使用镜像启动容器
docker run -d -p 8080:8080 springbootdocker
7.访问ip地址:8080/printLog查看是否启动成功
除了DockerFile,我们还可以使用Maven插件制作镜像。使用方法 如下:
1.开启远程docker服务
# 修改docker配置文件 vim /lib/systemd/system/docker.service # 在ExecStart=后添加配置,远程访问docker的端口 为2375 ExecStart=/usr/bin/dockerd-current -H tcp://0.0.0.0:2375 -H unix://var/run/docker.sock \ --add-runtime dockerrunc=/usr/libexec/docker/docker-runccurrent \ --default-runtime=docker-runc \ --exec-opt native.cgroupdriver=systemd \ --userland-proxypath=/usr/libexec/docker/docker-proxycurrent \ --initpath=/usr/libexec/docker/docker-initcurrent \ --seccompprofile=/etc/docker/seccomp.json \ $OPTIONS \ $DOCKER_STORAGE_OPTIONS \ $DOCKER_NETWORK_OPTIONS \ $ADD_REGISTRY \ $BLOCK_REGISTRY \ $INSECURE_REGISTRY \ $REGISTRIES # 重启docker systemctl daemon-reload systemctl restart docker
2.在项目的pom文件中添加 docker-maven-plugin 插件
com.spotify docker-mavenplugin 1.2.2 http://192.168.25.101:2375 openjdk:11 xiaotong / ${project.build.directory} ${project.build.finalName}.jar / ["java", "-jar","${project.build.finalName}.jar","--spring.profiles.active=dev"] true ${project.artifactId} ${project.version} 3.使用maven的package命令给项目打包
4.使用maven的docker插件制作镜像
5.查看所有的镜像,出现springbootdemo7代表镜像构建成功
docker images
6.使用镜像启动容器
docker run -d -p 8081:8080 springbootdemo7:0.0.1-SNAPSHOT
定时任务即系统在特定时间执行一段代码,它的场景应用非常广 泛:
1 购买游戏的月卡会员后,系统每天给会员发放游戏资源。
2 管理系统定时生成报表。
3 定时清理系统垃圾。
4 ......
定时任务的实现主要有以下几种方式:
1. Java自带的java.util.Timer类,这个类允许调度一个java.util.TimerTask任务。使用这种方式可以让 程序按照某一个频度执行,但不能在指定时间运行。一般用的较少。
2 Quartz。这是一个功能比较强大的的调度器,可以让程序在指定时间执行,也可以按照某一个频度 执行,配置起来稍显复杂。
3 Spring3.0以后自带Spring Task,可以将它看成一个轻量级的Quartz,使用起来比 Quartz简单许 多,在课程中我们使用Spring Task实现定时任务
1.创建SpringBoot项目,在启动类开启定时任务。
@SpringBootApplication
@EnableScheduling
public class Springbootdemo8Application {
public static void main(String[] args)
{
SpringApplication.run(Springbootdemo8Application.class, args);
}
}
2.编写定时任务类
@Component
public class MyTask {
// 定时任务方法,每秒执行一次
@Scheduled(cron="* * * * * *")
public void task1() {
SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss");
System.out.println(sdf.format(new Date()));
}
}
3.启动项目,定时任务方法按照配置定时执行。
Spring Task依靠Cron表达式配置定时规则。Cron表达式是一个字 符串,分为6或7个域,每一个域代表一个含义,以空格隔开。有如 下两种语法格式:
1.Seconds Minutes Hours DayofMonth Month DayofWeek Year
2 Seconds Minutes Hours DayofMonth Month DayofWeek
@Scheduled写在方法上方,指定该方法定时执行。常用参数如 下:
cron:cron表达式,定义方法执行的时间规则。
fixedDelay:任务立即执行,之后每隔多久执行一次,单位是毫 秒,上一次任务结束后计算下次执行的时间。
// 立即执行,任务结束后每5秒执行一次
@Scheduled(fixedDelay=5000)
public void task1() throws
InterruptedException {
SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss");
Thread.sleep(1000);
System.out.println(sdf.format(new Date()));
}
fixedRate:任务立即执行,之后每隔多久执行一次,单位是毫 秒,上一次任务开始后计算下次执行的时间。
// 立即执行,之后每5秒执行一次
@Scheduled(fixedRate=5000)
public void task2() throws
InterruptedException {
SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss");
Thread.sleep(1000);
System.out.println(sdf.format(new Date()));
}
initialDelay:项目启动后不马上执行定时器,根据initialDelay 的值延时执行。
// 项目启动3秒后执行,之后每5秒执行一次。
@Scheduled(fixedRate=5000,initialDelay =
3000)
public void task3() throws
InterruptedException {
SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss");
Thread.sleep(1000);
System.out.println(sdf.format(new Date()));
}
Spring Task定时器默认是单线程的,如果项目中使用多个定时器, 使用一个线程会造成效率低下。代码如下:
@Scheduled(cron="* * * * * *")
private void task1() throws
InterruptedException {
System.out.println(Thread.currentThread().getId()+"线程执行任务1");
Thread.sleep(5000);
}
@Scheduled(cron="* * * * * *")
private void task2() {
System.out.println(Thread.currentThread().getId()+"线程执行任务2");
}
任务1较浪费时间,会阻塞任务2的运行。此时我们可以给Spring Task配置线程池。