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]}
SpringBoot在启动时的多环境配置以及加载顺序的更多相关文章
- spring boot入门笔记(四) - 多环境配置、加载顺序、静态资源映射
1.多环境配置 先描述下以前的开发流程:从SVN把项目下载到本地,各种修改配置文件,启动成功:完成功能后上传到公司的测试服务器,修改各种配置文件,启动成功:最后到上线的日子里,把新功能中涉及到的文件打 ...
- 服务器启动时Webapp的web.xml中配置的加载顺序
一 1.启动一个WEB项目的时候,WEB容器会去读取它的配置文件web.xml,读取<listener>和<context-param>两个结点. 2.紧急着,容创建一个Ser ...
- 服务器启动时Webapp的web.xml中配置的加载顺序(转载)
一 1.启动一个WEB项目的时候,WEB容器会去读取它的配置文件web.xml,读取<listener>和<context-param>两个结点. 2.紧急着,容创建一个Ser ...
- web.xml的配置及加载顺序
一web.xml加载过程(步骤): 1.启动WEB项目的时候,容器(如:Tomcat)会去读它的配置文件web.xml.读两个节点: <listener></listener> ...
- Ubuntu环境变量(.profile)加载顺序
Ubuntu下启动的时候的的加载环境变量的过程大致为: /etc/enviroment /etc/profile -->/etc/bash.bashrc --> /etc/prof ...
- springCloud组件启动时,提示内部tomcat无法加载
忘记拷贝当时的异常信息了. 本地启动模块,做测试 大概就是emmble tomcat就是表示内部tomcat无法启动. 出现这样的异常是由于配置中心得代码已经修改,但是没有从git上down下来,然后 ...
- web.xml 文件中一般包括 servlet, spring, filter, listenr的配置的加载顺序
首先可以肯定 加载顺序与他们在web.xml 文件中的先后顺序无关. web.xml 中 listener 和 serverlet 的加载顺序为 先 listener 后serverlet最终得出结果 ...
- SpringBoot中的bean加载顺序
https://www.dazhuanlan.com/2019/10/22/5daebc5d16429/ 最近在做传统Spring项目到SpringBoot项目迁移过程中,遇到了一些bean加载顺序的 ...
- Spring Boot 配置加载顺序详解
使用 Spring Boot 会涉及到各种各样的配置,如开发.测试.线上就至少 3 套配置信息了.Spring Boot 可以轻松的帮助我们使用相同的代码就能使开发.测试.线上环境使用不同的配置. 在 ...
随机推荐
- Java中的文件和流相关知识
1. File File类可以使用文件路径字符串来创建File实例,该文件路径可以是绝对路径或相对路径 File类的list()方法中可以接收一个FilenameFilter参数,通过该参数可以只列出 ...
- apache代理weblogic集群办法
方法一: --关闭iptables和selinux --在apache配置文件httpd.conf最下面添加如下语句,然后重启apache: ServerName 127.0.0.1:80 NameV ...
- (ubuntu ufw)My firewall is blocking network connections from the docker container to outside
Maybe this is due to the current version, but the current answer doesn't work on my system (Docker 0 ...
- installEventFilter可以安装到任何QObject的子类,并不仅仅是UI组件。事件过滤器和安装过滤器的组件必须在同一线程,在它们分属在不同线程时,事件过滤器也是不起作用的
Qt的事件知识点: ①事件对象创建完毕后,Qt 将这个事件对象传递给 QObject 的 event() 函数.event() 函数并不直接处理事件,而是将这些事件对象按照它们不同的类型,分发给不同的 ...
- Sum It Up---poj1564(dfs)
题目链接:http://poj.org/problem?id=1564 给出m个数,求出和为n的组合方式:并按从大到小的顺序输出: 简单的dfs但是看了代码才会: #include <cstdi ...
- RabbitMQ(转)
add by zhj: 如果用Python,那可以用celery,它是一个分布式任务队列,它的broker可以选择Rabbitmq/Redis/Mongodb等, celery通过Kombu这个lib ...
- CSLA.Net学习(2)
采用CSLA.net 2.1.4.0版本的书写方式: using System; using System.ComponentModel; using Csla.Validation; using S ...
- (转)nginx负载均衡(5种方式)、rewrite重写规则及多server反代配置梳理
Nginx除了可以用作web服务器外,他还可以用来做高性能的反向代理服务器,它能提供稳定高效的负载均衡解决方案.nginx可以用轮询.IP哈希.URL哈希等方式调度后端服务器,同时也能提供健康检查功能 ...
- PAT 1075 PAT Judge[比较]
1075 PAT Judge (25 分) The ranklist of PAT is generated from the status list, which shows the scores ...
- R语言基本语法
R语言基本语法 基本数据类型 数据类型 向量 vector 矩阵 matrix 数组 array 数据框 data frame 因子 factor 列表 list 向量 单个数值(标量)没有单独的数据 ...