Springboot学习笔记——2

news2024/11/16 19:41:19

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: dev
    group:
      "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);
    @GetMapping
    public 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.smulll
    iservice: com.fasterxml
  level:
    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 { @GetMapping
    public 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.log
  logback:
    rollingpolicy:
      file-name-pattern: server.%d{yyyy-MM-dd}.%i.log
      max-file-size: 5KB

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

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

相关文章

【计算机网络-自顶向下方法】应用层(HTTP、FTP)

1. Principles of network applications 创建一个网络应用 创建一个网络应用的核心&#xff0c;是编写一个分布式程序&#xff0c;使其可以运行在不同的端系统上&#xff0c;并能通过网络相互通信。&#xff08;例如&#xff0c;web服务器软件与浏览器软件&#xff09;   应…

为什么很多编程语言中数组都是从0开始编号?

文章来源于极客时间前google工程师−王争专栏。 如何实现随机访问? 什么是数组&#xff1f; 数组&#xff08;Array&#xff09;是一种线性表数据结构。它用一组连续的内存空间&#xff0c;来存储一组具有相同类型的数据。 线性表&#xff0c;顾名思义&#xff0c;线性表就…

林沛满-TCP之在途字节数

本文整理自&#xff1a;《Wireshark网络分析的艺术 第1版》 作者&#xff1a;林沛满 著 出版时间&#xff1a;2016-02 我一直谨记斯蒂芬霍金的金玉良言—每写一道数学公式就会失去一半读者。不过为了深度分析网络包&#xff0c;有时候是不得不计算的&#xff0c;好在小学一年级…

DirectX12_Windows_GameDevelop_3:Direct3D的初始化

引言 查看龙书时发现&#xff0c;第四章介绍预备知识的代码不太利于学习。因为它不像是LearnOpenGL那样从头开始一步一步教你敲代码&#xff0c;导致你没有一种整体感。如果你把它当作某一块的代码进行学习&#xff0c;你跟着敲会发现&#xff0c;总有几个变量是没有定义的。这…

【C++设计模式之策略模式】分析及示例

描述 策略模式&#xff08;Strategy Pattern&#xff09;是一种行为型设计模式&#xff0c;它允许在运行时根据不同的情况选择算法的行为。该模式将算法的定义封装成一组易于切换和替换的类&#xff0c;使得算法可以独立于其使用者进行变化。 原理 策略模式通过将具体的算法…

FastThreadLocal 快在哪里 ?

FastThreadLocal 快在哪里 &#xff1f; 引言FastThreadLocalset如何获取当前线程私有的InternalThreadLocalMap &#xff1f;如何知道当前线程使用到了哪些FastThreadLocal实例 ? get垃圾回收 小结 引言 FastThreadLocal 是 Netty 中造的一个轮子&#xff0c;那么为什么放着…

前端到底有多卷?可以转行吗?

我前几天招人&#xff0c;前后端各招一个人。 后端一天大概60多个投简历的。 前端岗位发出去&#xff0c;我吃了个饭&#xff0c;1小时回来 收到300多份简历…… 是一位HR回复的前端卷到什么程度的回答&#xff01; 下面我们来看两组官方纰漏的数据&#xff1a; 2023届全国高…

Git 学习笔记 | Git 的简介与历史

Git 学习笔记 | Git 的简介与历史 Git 学习笔记 | Git 的简介与历史Git 简介Git 历史 Git 学习笔记 | Git 的简介与历史 Git 简介 Git是分布式版本控制系统&#xff08;Distributed Version Control System&#xff0c;简称 DVCS&#xff09;&#xff0c;分为两种类型的仓库&…

100M跨境电商服务器能同时容纳多少人访问?

​  随着“出国”“出海”需求的业务量增多&#xff0c;网络的不断发展&#xff0c;服务商开始在带宽资源配备上作出各种改进。无论是纯国际带宽还是优化回国带宽租用&#xff0c;我们都可以独享&#xff0c;并且享受到大带宽。一般&#xff0c;做跨境电商业务的群体&#xf…

黑客都是土豪吗?真实情况是什么?

黑客的利益链条真的这么大这么好么,连最外围的都可以靠信息不对称赚普通人大学毕业上班族想都不敢想的金钱数目,黑客们是不是基本都是土豪 网络技术可以称为黑客程度的技术是不是真的很吃香&#xff1f;如果大部分大学生的智力资源都用在学习网络技术&#xff0c;会不会出现僧…

如何杜绝聊天泄密事件的发生呢(企业如何管理通讯工具,防止员工聊天泄密)

在现代企业中&#xff0c;员工之间的沟通是必不可少的。然而&#xff0c;随着科技的发展&#xff0c;员工聊天泄密的风险也日益增加。企业需要采取一系列措施来防止员工聊天泄密&#xff0c;以保护企业的核心竞争力和商业机密。本文将介绍一些有效的防止员工聊天泄密的方法。 1…

PHP8的匿名类-PHP8知识详解

PHP8支持通过new class 来实例化一个匿名类。所谓匿名类&#xff0c;就是指没有名称的类&#xff0c;只能在创建时使用new语句来声明它们。 匿名类是一种没有命名的即时类&#xff0c;可以用于简单的对象封装和实现接口。 以下是PHP 8中匿名类的基本语法示例&#xff1a; $ob…

Springboot使用Aop保存接口请求日志到mysql(及解决Interceptor拦截器中引用mapper和service为null)

一、Springboot使用Aop保存接口请求日志到mysql 1、添加aop依赖 <!-- aop日志 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId></dependency> 2、新建接口保存数据…

VsCode 常见的配置、常用好用插件

1、自动保存&#xff1a;不用装插件&#xff0c;在VsCode中设置一下就行 2、设置ctr滚轮改变字体大小 3、设置选项卡多行展示 这样打开了很多个文件&#xff0c;就不会导致有的打开的文件被隐藏 4、实时刷新网页的插件&#xff1a;LiveServer 5、open in browser 支持快捷键…

FM100/FM101协议系列-快速充电接口芯片

产品描述&#xff1a; FM100/FM101是一款支持Quick Charge 2.0&#xff08;QC 2.0&#xff09;快速充电协议的充电接口控制器 IC&#xff0c;可自动识别快速充电设备类型&#xff0c;并通过QC2.0协议与设备握手&#xff0c;使之获得设备允许的安全最高充电电压&#xff0c;在保…

为什么程序员必须坚持写技术博客?

当你申请一份工作的时候&#xff0c;你的简历通常大概只有两页的篇幅。当你接受面试的时候&#xff0c;你通常会跟面试官聊上一两个小时。以如此简短的简历和如此短暂的面试来评估一名软件开发人员的技能非常困难&#xff0c;所以雇主以此判定某个人是否适合某个工作岗位也颇具…

VB.NET vs. VB6.0:现代化编程语言 VS 经典老旧语言

目录 ​.NET背景&#xff1a; 特点: VB6.0背景&#xff1a; 特点: 两者之间的不同: 总结: 升华: .NET背景&#xff1a; VB.NET一种简单&#xff0c;现代&#xff0c;面向对象计算机编程语言&#xff0c;有微软开发&#xff0c;VB.NET是一种基于.NET Framework的面向对象…

基于Dockerfile搭建LNMP

目录 一、基础环境准备 1、环境前期准备 二、部署nginx&#xff08;容器IP 为 172.18.0.10&#xff09; 1、配置Dockerfile文件 2、配置nginx.conf文件 3、构建镜像、启动镜像 三、部署mysql 1、配置Dockerfile文件 2、配置my.conf文件 3、构建镜像、启动镜像 5、验…

Linux 基本指令(上)

文章内容&#xff1a; 1. ls 指令 语法&#xff1a; ls [选项][目录或文件] 功能&#xff1a;对于目录&#xff0c;该命令列出该目录下的所有子目录与文件。对于文件&#xff0c;将列出文件名以及其他信息。 单个ls显示当前目录下的文件和目录 常用选项&#…

5MW风电永磁直驱发电机-1200V直流并网Simulink仿真模型

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…