Springboot学习笔记——2

Springboot学习笔记——2

  • 一、打包与运行
    • 1.1、程序打包与运行(windows版)
    • 1.2、打包插件
    • 1.3、Boot工程快速启动(Linux版)
  • 二、配置高级
    • 2.1、临时属性设置
    • 2.2、配置程序四级分类
    • 2.3、自定义配置文件
  • 三、多环境开发
    • 3.1、多环境开发(YAML版)
    • 3.2、多环境开发文件版(YAML版)
    • 3.3、多环境开发文件版(properties版)
    • 3.4、多环境分组管理
    • 3.5、多环境开发控制
  • 四、日志
    • 4.1、日志基础
    • 4.2、快速创建日志对象
    • 4.3、日志输入格式控制
    • 4.4、文件记录日志

一、打包与运行

1.1、程序打包与运行(windows版)

  1. 对SpringBoot项目打包(执行Maven构建指令package)
    在这里插入图片描述
  2. 运行项目(在cmd中执行启动指令)
java -jar springboot.jar

jar支持命令行启动需要依赖maven插件支持,请确认打包时是否具有SpringBoot对应的maven插件

<build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins>
</build>

1.2、打包插件

  • 使用SpringBoot提供的maven插件可以将工程打包成可执行jar包
<build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins>
</build>

在这里插入图片描述

jar包描述文件(MANIFEST.MF)

  • 普通工程
Manifest-Version: 1.0
Implementation-Title: springboot_08_ssmp
Implementation-Version: 0.0.1-SNAPSHOT
Build-Jdk-Spec: 1.8
Created-By: Maven Jar Plugin 3.2.0
  • 基于spring-boot-maven-plugin打包的工程
Manifest-Version: 1.0
Spring-Boot-Classpath-Index: BOOT-INF/classpath.idx
Implementation-Title: springboot_08_ssmp
Implementation-Version: 0.0.1-SNAPSHOT
Spring-Boot-Layers-Index: BOOT-INF/layers.idx
Start-Class: com.itheima. SSMPApplication
Spring-Boot-Classes: BOOT-INF/classes/
Spring-Boot-Lib: BO0T-INF/lib/
Build-Jdk-Spec: 1.8
Spring-Boot-Version: 2.5.4
Created-By: Maven Jar Plugin 3.2.0
Main-Class: org.springframework.boot.loader.JarLauncher
  • Windows端口被占用
#查询端口
netstat -ano
#查询指定端口
netstat -ano |findstr "端口号"
#根据进程PID查询进程名称
tasklist lfindstr "进程PID号"
# 根据PID杀死任务
taskkill /F /PID "进程PID号"
# 根据进程名称杀死任务
taskkill -f -t -im "进程名称"

1.3、Boot工程快速启动(Linux版)

  • 基于Linux ( CenteroS7)
  • 安装JDK,且版本不低于打包时使用的JDK版本
  • 安装包保存在/usr/local/自定义目录中或$HOME下
  • 其他操作参照windows版进行

二、配置高级

2.1、临时属性设置

  • 带属性启动Springboot
java -jar springboot.jar --server.port=80
  • 携带多个属性启动Springboot,属性间使用空格分隔
  • 临时属性必须是当前boot工程支持的属性,否则设置无效
    属性加载优先顺序
    参看属性加载优先顺序文档
    在这里插入图片描述
  • 带属性启动SpringBoot程序,为程序添加运行属性
    在这里插入图片描述
  • 通过编程形式带参数启动SpringBoot程序,为程序添加运行参数
@SpringBootApplication
public class SsmpApplication {public static void main(String[] args) {//可以通过设置一个字符串数组的方式定义参数String[] arg =  new  String[1];arg[0] = "--server.port=8082";SpringApplication.run(SsmpApplication.class, arg);}
}
  • 不携带参数启动SpringBoot程序
@SpringBootApplication
public class SsmpApplication {public static void main(String[] args) {//可以在启动boot程序时断开读取外部临时配置对应的入口,也就是去掉读取外部参数的形参SpringApplication.run(SsmpApplication.class);}
}

2.2、配置程序四级分类

  1. SpringBoot中4级配置文件
    1级: file : config/application. yml
    2级: file : application.yml
    3级: classpath: config/application.yml
    4级: classpath: application.yml
  2. 作用:
    • 1级与2级留做系统打包后设置通用属性,1级常用于运维经理进行线上整体项目部署方案调控
    • 3级与4级用于系统开发阶段设置通用属性,3级常用于项目经理进行整体项目属性调控

2.3、自定义配置文件

  • 通过启动参数加载配置文件(无需书写配置文件扩展名)

在这里插入图片描述

  • 通过启动参数加载指定文件路径下的配置文件时可以加载多个配置
    在这里插入图片描述
    注意事项:

多配置文件常用于将配置进行分类,进行独立管理,或将可选配置单独制作便于上线更新维护

重要说明

  • 单服务器项目:使用自定义配置文件需求较低
  • 多服务器项目:使用自定义配置文件需求较高,将所有配置放置在一个目录中,统一管理
  • 基于SpringCloud技术,所有的服务器将不再设置配置文件,而是通过配置中心进行设定,动态加载配置信息

三、多环境开发

3.1、多环境开发(YAML版)

在这里插入图片描述

#应用环境
spring:profiles:active: pro
---
#设置环境
#生产环境
spring:config:activate:on-profile: pro
server:port: 80
---
#开发环境
spring:config:activate:on-profile: dev
server:port: 81
---
#测试环境
spring:config:activate:on-profile: test
server:port: 82

在这里插入图片描述

3.2、多环境开发文件版(YAML版)

  1. 主启动配置文件application.yml
#应用环境
spring:profiles:active: dev
  1. 配置分类配置文件application-pro.yml
server:port: 80
  1. 配置分类配置文件application-dev.yml
server:port: 81
  1. 配置分类配置文件application-test.yml
server:port: 82
  • 主配置文件中设置公共配置(全局)
  • 环境分类配置文件中常用于设置冲突属性(局部)

3.3、多环境开发文件版(properties版)

  1. 主启动配置文件application.properties
spring.profiles.active=pro
  1. 配置分类配置文件application-pro.properties
server.port=9080
  1. 配置分类配置文件application-dev.properties
server.port=9081
  1. 配置分类配置文件application-test.properties
server.port=9082

3.4、多环境分组管理

  • 根据功能对配置文件中的信息进行拆分,并制作成独立的配置文件,命名规则如下

    • application-devDB.yml
    • application-devRedis.yml
    • application-devMVC.yml
  • 使用include属性在激活指定环境的情况下,同时对多个环境进行加载使其生效,多个环境间使用逗号分隔

spring:profiles:active:include: devDB,devRedis,devMVC

注意事项:

当主环境dev与其他环境有相同属性时,主环境属性生效;其他环境中有相同属性时,最后加载的环境属性生效

  • 从SpringBoot2.4版开始使用group属性替代include属性,降低了配置书写量
  • 使用group属性定义多种主环境与子环境的包含关系
spring:profiles:active: devgroup:"dev": devMVC,devDB,devRedis"pro": proMVC,proDB,proRedis

3.5、多环境开发控制

  1. Maven中设置多环境
<profiles><profile><id>env_dev</id><properties><profile.active>dev</profile.active><activation><activeByDefault>true</activeByDefault></activation></properties></profile><profile><id>env_pro</id><properties><profile.active>pro</profile.active></properties></profile><profile><id>env_test</id><properties><profile.active>test</profile.active></properties></profile>
</profiles>
  1. SpringBoot中引用Maven属性
spring:profiles:active: @profile.active@
  1. 执行Maven打包指令,并在生成的boot打包文件.jar文件中查看对应信息
  • 当Maven与SpringBoot同时对多环境进行控制时,以Maven为主,SpringBoot使用@…@占位符读取Maven对应的配置属性值
  • 基于SpringBoot读取Maven配置属性的前提下,如果在Idea下测试工程时pom.xml每次更新需要手动compile方可生效

四、日志

4.1、日志基础

  • 日志(log)作用
    • 编程期调试代码
    • 运行期记录信息
      • 记录日常运营重要信息(峰值流量、平均响应时长……)
      • 记录应用报错信息(错误堆栈)
      • 记录运维过程数据(扩容、宕机、报警……)
  1. 添加日志记录操作
@RestController
@RequestMapping("/books")
public class bookController {//创建记录日志的对象private static final Logger log = LoggerFactory.getLogger(bookController.class);@GetMappingpublic String getById(){System.out.println("SpringBoot is running...");log.debug("debug.............");log.info("info.............");log.warn("warn.............");log.error("error.............");return "SpringBoot is running...";}
}
  • 日志级别
    • TRACE:运行堆栈信息,使用率低
    • DEBUG:程序员调试代码使用
    • INFO:记录运维过程数据
    • WARN:记录运维过程报警数据
    • ERROR:记录错误堆栈信息
    • FATAL:灾难信息,合并计入ERROR
  1. 设置日志输入级别
# 开启debug模式,输出调试信息。常用于检查系统运行情况
debug:true
# 设置日志级别,root表示根节点,即整体应用日志级别
logging:level:root: info
  1. 设置日志组,控制指定包对应的日志输出级别,也可以直接控制指定包对应的日志输出级别
logging:#设置分组group:ebank: com.smulll.controller,com.smullliservice: com.fasterxmllevel:root: info#设置某个包的日志级别com.smulll.controller: debug#设置分组,对某个分组设置日志级别ebank: debug

4.2、快速创建日志对象

  • 引入lombok的依赖
<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId>
</dependency>
  • 使用lombok提供的注解@slf4j简化开发,减少日志对象的声明操作
@Slf4j
@RestController
@RequestMapping("/books")
public class bookController { @GetMappingpublic String getById(){System.out.println("SpringBoot is running...");log.debug("debug.............");log.info("info.............");log.warn("warn.............");log.error("error.............");return "SpringBoot is running...";}
}

4.3、日志输入格式控制

在这里插入图片描述

  • PID:进程ID,用于表明当前操作所处的进程,当多服务同时记录日志时,该值可用于协助程序员调试程序
  • 所属类/接口名:当前显示信息为SpringBoot重写后的信息,名称过长时,简化包名书写为首字母,甚至直接删除
  • 设置日志输出格式
logging:pattern:console: 
  • %d:日期
  • %m:消息
  • %n:换行
logging:pattern:console: "%d %clr(%5p) ---[%16t] %clr(%-40.40c){cyan} : %m %n"

4.4、文件记录日志

  • 设置日志文件
logging:
#设置日志文件file:name: server.log
  • 日志文件详细设置
logging:
#设置日志文件file:name: server.loglogback:rollingpolicy:file-name-pattern: server.%d{yyyy-MM-dd}.%i.logmax-file-size: 5KB

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/96773.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深圳市重点实验室申报条件-华夏泰科

深圳市重点实验室是一个致力于科学研究和技术创新的重要机构。作为中国科技创新的重要一环&#xff0c;深圳市重点实验室在多个领域展开前沿研究&#xff0c;并为科学家、工程师和创新者提供了宝贵的资源和支持。、在接下来的内容中&#xff0c;华夏泰科将为您说明深圳市重点实…

强化学习------Sarsa算法

简介 SARSA&#xff08;State-Action-Reward-State-Action&#xff09;是一个学习马尔可夫决策过程策略的算法&#xff0c;通常应用于机器学习和强化学习学习领域中。它由Rummery 和 Niranjan在技术论文“Modified Connectionist Q-Learning&#xff08;MCQL&#xff09;” 中…

SpringTask ----定时任务框架 ----苍穹外卖day10

目录 SpringTask 需求分析 快速入门 使用步骤 ​编辑业务开发 SpringTask 定时任务场景特化的框架 需求分析 快速入门 使用cron表达式来使用该框架 使用步骤 添加注解 自定义定时任务类 重点在于以下cron表达式的书写,精确表达触发的间隔 业务开发 主task方法 time使用(-…

数据结构:二叉树(超详解析)

目录​​​​​​​ 1.树概念及结构 1.1树的概念 1.2树的相关概念 1.3树的表示 1.3.1孩子兄弟表示法&#xff1a; 1.3.2双亲表示法&#xff1a;只存储双亲的下标或指针 两节点不在同一树上&#xff1a; 2.二叉树概念及结构 2.1.概念 2.2.特殊的二叉树&#xff1a; 2…

【C++设计模式之组合模式:结构型】分析及示例

简介 组合模式是一种结构型设计模式&#xff0c;它能够将对象组合成树形结构以表示“整体-部分”的层次结构&#xff0c;并且能够使用相同的方式处理单个对象和组合对象。组合模式使得客户端可以一致地处理单个对象和组合对象&#xff0c;无需关心具体的对象类型。 组合模式将对…

企业想过等保,其中2FA双因素认证手段必不可少

随着信息技术的飞速发展&#xff0c;网络安全问题日益凸显。等保2.0时代的到来&#xff0c;意味着企业和组织需要更加严格地保护自身的信息安全。而在这个过程中&#xff0c;双因素认证的重要性逐渐得到广泛认可。本文将探讨 2FA 双因素认证的重要性。 在了解 2FA 双因素认证的…

2023-IDEA插件推荐

CamelCase 链接 https://plugins.jetbrains.com/plugin/7160-camelcase https://github.com/netnexus/camelcaseplugin 介绍 提供下划线、驼峰等代码风格的切换。快捷键是⇧ ⌥ U / Shift Alt U GsonFormatPlus 链接 https://plugins.jetbrains.com/plugin/14949-gs…

2023/10/7 -- ARM

【程序状态寄存器读写指令】 1.指令码以及格式 mrs:读取CPSR寄存器的值 mrs 目标寄存器 CPSR&#xff1a;读取CPSR的数值保存到目标寄存器中msr:修改CPSR寄存器的数值msr CPSR,第一操作数:将第一操作数的数值保存到CPSR寄存器中//修改CPSR寄存器&#xff0c;也就表示程序的状…

从哈希表到红黑树:探讨 epoll 是如何管理事件的?

一、引言 在计算机领域&#xff0c;事件通知是一种重要的机制&#xff0c;用于监视和响应各种事件&#xff0c;例如网络连接、文件IO、定时器等。随着计算机应用变得越来越复杂&#xff0c;对于高性能事件通知机制的需求也越来越迫切。传统的事件通知机制可能存在效率低下的问…

Excel·VBA使用ADO读取工作簿工作表数据

目录 查询遍历写入数组查询整体写入数组查询工作簿所有工作表名称查询工作簿所有工作表数据 不打开工作簿读取数据&#xff0c;以下举例都为《ExcelVBA合并工作簿》中 7&#xff0c;合并子文件夹同名工作簿中同名工作表&#xff0c;纵向汇总数据所举例的工作簿&#xff0c;使用…

Angular学习笔记:路由

本文是自己的学习笔记&#xff0c;主要参考资料如下。 - B站《Angular全套实战教程》&#xff0c;达内官方账号制作&#xff0c;https://www.bilibili.com/video/BV1i741157Fj?https://www.bilibili.com/video/BV1R54y1J75g/?p32&vd_sourceab2511a81f5c634b6416d4cc1067…

Vue.js3学习篇--Vue模板应用

目录 一,模板基础 1.模板插值 &#xff08;1&#xff09;基础插值 &#xff08;2&#xff09;HTML代码插值 &#xff08;3&#xff09;标签属性插值 2.模板指令 &#xff08;1&#xff09;定义 &#xff08;2&#xff09;指令参数 二.条件渲染 1.使用v-if指令渲染 2.使…

【网络安全 --- 工具安装】Centos 7 详细安装过程及xshell,FTP等工具的安装(提供资源)

VMware虚拟机的安装教程如下&#xff0c;如没有安装&#xff0c;可以参考这篇博客安装&#xff08;提供资源&#xff09; 【网络安全 --- 工具安装】VMware 16.0 详细安装过程&#xff08;提供资源&#xff09;-CSDN博客【网络安全 --- 工具安装】VMware 16.0 详细安装过程&am…

告警繁杂迷人眼,多源分析见月明

随着数字化浪潮的蓬勃兴起&#xff0c;网络安全问题日趋凸显&#xff0c;面对指数级增长的威胁和告警&#xff0c;传统的安全防御往往力不从心。网内业务逻辑不规范、安全设备技术不成熟都会导致安全设备触发告警。如何在海量众多安全告警中识别出真正的网络安全攻击事件成为安…

数据结构(2-5~2-8)

2-5编写算法&#xff0c;在单链表中查找第一值为x的结点&#xff0c;并输出其前驱和后继的存储位置 #include<stdio.h> #include<stdlib.h>typedef int DataType; struct Node {DataType data; struct Node* next; }; typedef struct Node *PNode; …

Pikachu靶场——远程命令执行漏洞(RCE)

文章目录 1. RCE1.1 exec "ping"1.1.1 源代码分析1.1.2 漏洞防御 1.2 exec "eval"1.2.1 源代码分析1.2.2 漏洞防御 1.3 RCE 漏洞防御 1. RCE RCE(remote command/code execute)概述&#xff1a; RCE漏洞&#xff0c;可以让攻击者直接向后台服务器远程注入…

接口测试总结

一、了解一下HTTP与RPC 1. HTTP&#xff08;HyperText Transfer Protocol) 说明&#xff1a;超文本传输协议&#xff0c;是互联网上应用最为广泛的一种网络协议。 优点&#xff1a;就是简单、直接、开发方便&#xff0c;利用现成的http协议进行传输。 流程图&#xff1a; 2. R…

【QT5-程序控制电源-RS232-SCPI协议-上位机-基础样例【1】】

【QT5-程序控制电源-RS232-SCPI协议-上位机-基础样例【1】】 1、前言2、实验环境3、自我总结1、基础了解仪器控制-熟悉仪器2、连接SCPI协议3、选择控制方式-程控方式-RS2324、代码编写 4、熟悉协议-SCPI协议5、测试实验-测试指令&#xff08;1&#xff09;硬件连接&#xff08;…

课题学习(三)----倾角和方位角的动态测量方法(基于陀螺仪的测量系统)

一、内容介绍 该测量系统基于三轴加速度和三轴陀螺仪&#xff0c;安装在钻柱内部&#xff0c;随钻柱一起旋转&#xff0c;形成捷联惯性导航系统&#xff0c;安装如下图所示&#xff1a;   假设三轴加速度和陀螺仪的输出为: f b [ f x f y f z ] T f^b\begin{bmatrix}f_{x} …

Docker 安装 MongoDB

一、什么是MongoDB MongoDB 是一个基于分布式文件存储的数据库。是一个介于关系数据库和非关系数据库之间的产品&#xff0c;是非关系数据库当中功能最丰富&#xff0c;最像关系数据库的。 二、MongoDB的安装 这里使用docker来安装MongoD 1.docker 拉取mysql镜像 docker pu…