• SpringBoot-配置文件properties/yml分析+tomcat最大连接数及最大并发数


    SpringBoot配置文件

    yaml 中的数据是有序的,properties 中的数据是无序的,在一些需要路径匹配的配置中,顺序就显得尤为重要(例如在 Spring Cloud Zuul 中的配置),此时一般采用 yaml。

    Properties

    ①、位置问题
    默认 resources 目录下就有一个 application.properties 文件
    resources目录下的config目录下

    当前项目根目录下
    当前项目根目录下的config目录下

    四个配置优先级依次降低,默认会从这四个位置按顺序去查找相关属性并加载。
    在这里插入图片描述

    也可以采用手动加载其他目录下的配置文件
    在 resources 目录下创建一个 javaboy 目录,目录中存放一个 application.properties 文件。启动 Spring Boot 项目时,这个配置文件是不会被自动加载的
    开发工具中配置了启动位置,通过 spring.config.location 属性来手动的指定配置文件位置,指定完成后,系统就会自动去指定目录下查找 application.properties 文件
    在这里插入图片描述
    如果项目已经打包成 jar ,在启动命令中加入位置参数即可:

    java -jar properties-0.0.1-SNAPSHOT.jar --spring.config.location=classpath:/javaboy/
    
    • 1

    ②、文件名问题
    项目默认是去加载名为 application 的配置文件,若配置文件不叫 application,需要明确指定配置文件的文件名。
    方式和指定路径一致,只不过此时的 key 是 spring.config.name
    在 resources 目录下创建一个 app.properties 文件,然后在 IDEA 中指定配置文件的文件名:
    在这里插入图片描述
    允许自定义文件名的配置文件不放在四个默认位置,而是放在自定义目录下,此时就需要明确指定 spring.config.location
    配置文件位置和文件名称可以同时自定义

    ③、配置文件中属性注入

    public class Book {
        private Long id;
        private String name;
        private String author;
        //省略 getter/setter
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    在 application.properties 文件中定义属性

    book.name=三国演义
    book.author=罗贯中
    book.id=1
    
    • 1
    • 2
    • 3

    直接通过 @Value 注解将这些属性注入到 Book 对象中:

    @Component //Book 对象本身也要交给 Spring 容器去管理,如果 Book 没有交给 Spring 容器,那么 Book 中的属性也无法从 Spring 容器中获取到值
    public class Book {
        @Value("${book.id}")
        private Long id;
        @Value("${book.name}")
        private String name;
        @Value("${book.author}")
        private String author;
        //省略getter/setter
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    配置完成后,在 Controller 或者单元测试中注入 Book 对象,启动项目,就可以看到属性已经注入到对象中了

    实际应用,application.properties 文件中主要存放系统配置,这种自定义配置不建议放在该文件中,可以自定义 properties 文件来存在自定义配置。
    在 resources 目录下,自定义 book.properties 文件

    book.name=三国演义
    book.author=罗贯中
    book.id=1
    
    • 1
    • 2
    • 3

    项目启动并不会自动的加载该配置文件,如果是在 XML 配置中,可以通过如下方式引用该 properties 文件:

    <context:property-placeholder location="classpath:book.properties"/>
    
    • 1

    如果是在 Java 配置中,可以通过 @PropertySource 来引入配置:

    @Component
    @PropertySource("classpath:book.properties")
    public class Book {
        @Value("${book.id}")
        private Long id;
        @Value("${book.name}")
        private String name;
        @Value("${book.author}")
        private String author;
        //getter/setter
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    ④、类型安全的属性注入

    引入 @ConfigurationProperties(prefix = “book”) 注解,并且配置了属性的前缀,此时会自动将 Spring 容器中对应的数据注入到对象对应的属性中,就不用通过 @Value 注解挨个注入了,减少工作量并且避免出错

    @Component
    @PropertySource("classpath:book.properties")
    @ConfigurationProperties(prefix = "book")
    public class Book {
        private Long id;
        private String name;
        private String author;
        //省略getter/setter
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    yml

    相较于properties,yaml 配置目前不支持 @PropertySource 注解

    ①、位置

    项目根目录下的 config 目录中
    项目根目录下

    classpath 下的 config 目录中
    classpath 目录下

    四个位置中的 application.yaml 文件的优先级按照上面列出的顺序依次降低

    ②、自定义名称,需要指定(这样配置之后,在项目启动时,就会按照上面所说的四个位置按顺序去查找一个名为 app.yaml 的文件)
    在这里插入图片描述
    如果项目已经打成 jar 包了,则在项目启动时加入如下参数:

    java -jar myproject.jar --spring.config.name=app
    
    • 1

    这四个位置也不是一成不变的,也可以自己定义,有两种方式,一个是使用 spring.config.location 属性,另一个则是使用 spring.config.additional-location 这个属性,在第一个属性中,表示自己重新定义配置文件的位置,项目启动时就按照定义的位置去查找配置文件,这种定义方式会覆盖掉默认的四个位置,也可以使用第二种方式,第二种方式则表示在四个位置的基础上,再添加几个位置,新添加的位置的优先级大于原本的位置。
    在这里插入图片描述

    ③、数组注入

    my:
      servers:
    	- dev.example.com
    	- another.example.com
    
    • 1
    • 2
    • 3
    • 4

    绑定一个Bean的数组中

    @ConfigurationProperties(prefix="my")
    @Component
    public class Config {
    
    	private List<String> servers = new ArrayList<String>();
    
    	public List<String> getServers() {
    		return this.servers;
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    项目启动后,配置中的数组会自动存储到 servers 集合中。当然,yaml 不仅可以存储这种简单数据,也可以在集合中存储对象。例如下面这种:

    redis:
      redisConfigs:
        - host: 192.168.66.128
          port: 6379
        - host: 192.168.66.129
          port: 6380
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    @Component
    @ConfigurationProperties(prefix = "redis")
    public class RedisCluster {
        private List<SingleRedisConfig> redisConfigs;
    	//省略getter/setter
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    Tomcat

    每个Spring Boot版本和内置容器不同,结果也不同,这里以Spring Boot 2.7.10版本 + 内置Tomcat容器举例。
    在SpringBoot2.7.10版本中内置Tomcat版本是9.0.73,SpringBoot内置Tomcat的默认设置如下:

    • Tomcat的连接等待队列长度,默认是100
    • Tomcat的最大连接数,默认是8192
    • Tomcat的最小工作线程数,默认是10
    • Tomcat的最大线程数,默认是200
    • Tomcat的连接超时时间,默认是20s
      在这里插入图片描述
      相关配置如下:
    server:
      tomcat:
        # 当所有可能的请求处理线程都在使用中时,传入连接请求的最大队列长度
        accept-count: 100
        # 服务器在任何给定时间接受和处理的最大连接数。一旦达到限制,操作系统仍然可以接受基于“acceptCount”属性的连接。
        max-connections: 8192
        threads:
          # 工作线程的最小数量,初始化时创建的线程数
          min-spare: 10
          # 工作线程的最大数量 io密集型建议10倍的cpu数,cpu密集型建议cpu数+1,绝大部分应用都是io密集型
          max: 200
        # 连接器在接受连接后等待显示请求 URI 行的时间。
        connection-timeout: 20000
        # 在关闭连接之前等待另一个 HTTP 请求的时间。如果未设置,则使用 connectionTimeout。设置为 -1 时不会超时。
        keep-alive-timeout: 20000
        # 在连接关闭之前可以进行流水线处理的最大HTTP请求数量。当设置为0或1时,禁用keep-alive和流水线处理。当设置为-1时,允许无限数量的流水线处理或keep-alive请求。 
        max-keep-alive-requests: 100
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
  • 相关阅读:
    一图读懂TWT
    卷积神经网络的算法过程,卷积神经网络原理简述
    服务器中间件的种类和日常使用
    (完整版)英语常用词组大全(2000词以上)
    什么是 Sepolia 测试网以及如何从 Faucet 获取 Sepolia ETH
    Spring(一)核心概念
    LINUX系统搭建FTP服务器--操作步骤
    07_整合spring boot
    网络安全(黑客)自学
    C++ Reference: Standard C++ Library reference: C Library: cstdio: FILE
  • 原文地址:https://blog.csdn.net/usa_washington/article/details/133162706