SpringBoot在启动时的多环境配置以及加载顺序

  通常我们在开发完成一个SpringBoot项目时,总是要打包部署的。

  在启动SpringBoot应用时,我们常常会使用命令java -jar xxx.jar来启动这个服务。

  命令java -jar 除了启动应用之外,还可以在命令中指定应用的参数,比如一下带参数的命令:

  (1)java -jar xxx.jar --server.port=8081,直接以命令的方式来设置服务的访问端口server.port属性,将端口设置为8081;

  (2)java -jar -Xms1024m -Xmx1024m xxx.jar --spring.profiles.active=test ,以命令方式设置该服务启动时的内存大小,以及设置启动环境为test,并且服务是后台启动。

  在使用命令行方式启动SpringBoot应用时,设置参数时所使用的连续的两个减号 -- 就是对其属性配置文件application.properties或者application.yml中的属性值进行赋值的标识。所以java -jar xxx.jar --server.port=8081命令,就等价于在属性文件中添加属性server.port=8081。

  通过命令行的方式设置启动参数是SpringBoot的一个重要特性,在启动应用时,我们不仅可以设置应用的端口、访问路径、运行环境,还可以设置它的数据库连接等。但是在实际生产过程中,同一套应用程序会被应用和安装到不同的环境中,同时需要设置多个参数,这样的方式肯定不可取的。以是有了SpringBoot的多环境配置。

  一、SpringBoot多环境配置

  在SpringBoot中,进行多环境配置,需要配置多个属性文件。多环境配置的文件名需要满足application-{profile}.properties的格式,其中{profile}对应你的环境标识,比如:

  application-dev.properties: 表示你的开发环境

  application-test.properties: 表示你的测试环境

  application-prod.properties: 表示你的生产环境

  在启动项目的时候具体加载哪个属性文件,需要你在application.properties文件中通过spring.profiles.active属性来设置,比如spring.profiles.active=test就会加载application-test.properties属性文件。

  其中在application.properties属性文件中配置通用内容,并设置spring.profiles.active属性来指定启动环境。而application-{profile}.properties属性文件中则配置各个环境的不同信息,比如数据库连接信息、端口以及其他信息等。另外,虽然我们在application.properties属性文件中指定了启动时的环境,我们依然可以使用java -jar xxx.jar --spring.profiles.active命令来改变它的启动运行环境。

  在实际开发中,为了避免编写多个属性配置文件,我们可以将多个配置文件的内容,写到一个配置文件中,这里以一个application.yml为例,将SpringBoot应用的dev、test、prod等环境写到一个属性文件中,如下:

  server:

  port: 8820

  undertow:

  worker-threads: 400

  io-threads: 100

  buffer-size: 1024

  direct-buffers: true

  spring:

  application:

  name: fuwuhao-management

  profiles:

  active: dev

  jackson:

  time-zone: GMT+8

  ---

  spring:

  profiles: dev

  datasource:

  type: com.zaxxer.hikari.HikariDataSource

  driver-class-name: com.mysql.jdbc.Driver

  hikari:

  username: root

  password: root

  jdbc-url: jdbc:mysql://127.0.0.1:3306/dataBase?autoReconnect=truecharacterEncoding=UTF-8allowMultiQueries=trueuseSSL=false

  minimum-idle: 5

  maximum-pool-size: 15

  auto-commit: true

  idle-timeout: 30002

  pool-name: DatebookHikariCP

  max-lifetime: 500000

  connection-timeout: 30001

  #connection-test-query: SELECT 1

  validation-timeout: 5000

  ---

  spring:

  profiles: test

  datasource:

  type: com.zaxxer.hikari.HikariDataSource

  driver-class-name: com.mysql.jdbc.Driver

  hikari:

  username: root

  password: root

  jdbc-url: jdbc:mysql://127.0.0.1:3306/dataBase?autoReconnect=truecharacterEncoding=UTF-8allowMultiQueries=trueuseSSL=false

  minimum-idle: 5

  maximum-pool-size: 15

  auto-commit: true

  idle-timeout: 30002

  pool-name: DatebookHikariCP

  max-lifetime: 500000

  connection-timeout: 30001

  #connection-test-query: SELECT 1

  validation-timeout: 5000

  ---

  spring:

  profiles: prod

  datasource:

  type: com.zaxxer.hikari.HikariDataSource

  driver-class-name: com.mysql.jdbc.Driver

  hikari:

  username: root

  password: root

  jdbc-url: jdbc:mysql://127.0.0.1:3306/dataBase?autoReconnect=truecharacterEncoding=UTF-8allowMultiQueries=trueuseSSL=false

  minimum-idle: 5

  maximum-pool-size: 15

  auto-commit: true

  idle-timeout: 30002

  pool-name: DatebookHikariCP

  max-lifetime: 500000

  connection-timeout: 30001

  #connection-test-query: SELECT 1

  validation-timeout: 5000

  通过这种方式的配置,就避免了写太多的属性文件。在启动应用的时候,我们可以使用命令java -jar xxx.jar --spring.profiles.active=prod来随意切换环境即可。

  二、SpringBoot启动时加载顺序

  在SpringBoot应用启动时,将会按照下面的顺序来进行属性的加载:

  (1) 首先加载启动命令中传入的参数;

  (2) 加载SPRING_APPLICATION_JSON中的属性。SPRING_APPLICATION_JSON是以JSON格式配置在系统环境变量中的内容;

  (3) 加载java:comp/dev中的JNDI属性;

  (4) 加载Java的系统属性,可以通过System.getProperties()获取到的内容;

  (5) 加载操作系统的环境变量;

  (6) 加载random.*配置的随机属性;

  (7) 加载位于当前应用jar包之外,针对不同{profile}环境的配置文件内容,比如application-{profile}.properties或者YAML定义的配置文件;

  (8) 加载位于当前应用jar包之内,针对不同{profile}环境的配置文件内容,比如application-{profile}.properties或者YAML定义的配置文件;

  (9) 加载位于当前应用jar包之外的application.properties和YAML配置内容;

  (10) 加载位于当前应用jar包之内的application.properties和YAML配置内容;

  (11) 加载含有@Configuration注解的类,通过@PropertySource注解定义的属性;

  (12) 最后加载应用的默认属性,使用SpringApplication.setDefaultProperties定义的内容。

  加载的优先级按照以上顺序由高到底,数字越小的优先级越高,越先被加载。

  在这里额外说一下(6)中提到的随机数:

  在SpringBoot的属性配置文件中,可以通过使用${random}配置来产生随机的int值、long值或者string字符串,这样我们就可以容易地通过配置随机生成属性。

  ${random}的配置主要有以下几种形式:

  (1)随机字符串:

  random.stringValue=${random.value}

  (2)随机int:

  random.intValue=${random.int}

  (3)随机long:

  random.longValue=${random.long}

  (4)100以内的随机数:

  random.number=${random.int(100)}

  (5)100到1000的随机数:

  random.number=${random.int[100,1000]}

?

原文地址:https://www.cnblogs.com/qfjavabd/p/10552890.html

时间: 2024-10-09 12:58:38

SpringBoot在启动时的多环境配置以及加载顺序的相关文章

服务器启动时Webapp的web.xml中配置的加载顺序

一 1.启动一个WEB项目的时候,WEB容器会去读取它的配置文件web.xml,读取<listener>和<context-param>两个结点. 2.紧急着,容创建一个ServletContext(servlet上下文),这个web项目的所有部分都将共享这个上下文. 3.容器将<context-param>转换为键值对,并交给servletContext. 4.容器创建<listener>中的类实例,创建监听器. 二  Load-on-startup Lo

JBoss 配置项目加载顺序

需要注意的是:JBOSS在加载自带的核心JAR之后,将会优先加载下面的两个目录 1.D:\jboss\server\default\lib 2.D:\jboss\server\default\tmp\deploy 但是上面三组均不在以上1 2 所指的2个目录中.接着看...... 找到如下文件,注意这个文件里面蕴藏着jar加载的有一个规则. \jboss-4.2.3.GA\server\default\conf\xmdesc org.jboss.deployment.MainDeployer-x

Spring Boot 配置加载顺序详解

使用 Spring Boot 会涉及到各种各样的配置,如开发.测试.线上就至少 3 套配置信息了.Spring Boot 可以轻松的帮助我们使用相同的代码就能使开发.测试.线上环境使用不同的配置. 在 Spring Boot 里面,可以使用以下几种方式来加载配置.本章内容基于 Spring Boot 2.0 进行详解. 1.properties文件: 2.YAML文件: 3.系统环境变量: 4.命令行参数: 等等-- 我们可以在 Spring Beans 里面直接使用这些配置文件中加载的值,如:

3springboot:springboot配置文件(外部配置加载顺序、自动配置原理,@Conditional)

1.外部配置加载顺序 SpringBoot也可以从以下位置加载配置: 优先级从高到低 高优先级的配置覆盖低优先级的配置,所有的配置会形成互补配置  1.命令行参数 所有的配置都可以在命令行上进行指定 先打包在进行测试 java -jar spring-boot-02-config-02-0.0.1-SNAPSHOT.jar --server.port=8087 --server.context-path=/abc 指定访问的路径 多个配置用空格分开: --配置项=值 -- 由jar包外向jar包

java web项目启动加载顺序

web.xml加载过程(步骤):       1.启动WEB项目的时候,容器(如:Tomcat)会去读它的配置文件web.xml.读两个节点: <listener></listener> 和 <context-param></context-param> 2.紧接着,容器创建一个ServletContext(上下文),这个WEB项目所有部分都将共享这个上下文. 3.容器将<context-param></context-param>转

igmpproxy源代码学习——配置信息加载

在igmpproxy主程序运行之前需要先读取配置文件,igmpproxy的配置文件通常为/etc/igmpproxy.conf或者/var/igmpproxy.conf 其内容如下: quickleave mode 3 phyint ppp0 upstream ratelimit 0 threshold 1 phyint br0 downstream ratelimit 0 threshold 1 igmpproxy加载配置文件信息由main函数中调用loadConfig()实现,加载配置文件的

vue使用ECharts时的异步更新与数据加载

p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 24.0px "Helvetica Neue"; color: #404040 } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 13.0px "Helvetica Neue"; color: #737373 } p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px Monaco

Spring集成JPA配置懒加载两个报错解决办法

一:报错no session 因为entitymanager对象在事物提交后就关闭了 报错的 no session相当于sql的session 解决办法:解决办法 在web.xmL配置一个过滤器 使其在这个session中的manager在结束后再关闭open <!--配置openmanager--> <filter> <filter-name>openEntity</filter-name> <filter-class>org.springfr

SpringBoot程序启动时执行初始化代码

因项目集成了Redis缓存部分数据,需要在程序启动时将数据加载到Redis中,即初始化数据到Redis. 在SpringBoot项目下,即在容器初始化完毕后执行我们自己的初始化代码. 第一步:创建实现ApplicationListener接口的类 package com.stone; import com.stone.service.IPermissionService; import org.springframework.context.ApplicationListener; import