草庐IT

【微服务 从0开始 】Spring Cloud 配置文件

桃花键神 2023-04-14 原文

🔎这里是【秒懂·云原生】,关注我学习云原生不迷路
👍如果对你有帮助,给博主一个免费的点赞以示鼓励
欢迎各位🔎点赞👍评论收藏⭐️

👀专栏介绍

【秒懂·云原生】 目前主要更新微服务,一起学习一起进步。

👀本期介绍

主要介绍Spring Cloud 配置文件

文章目录

默认配置文件

在创建Spring Boot项目时,会默认在resource文件夹下创建
application.propertities的属性文件。在上面的例子中,我们在application.propertities中加上了服务启动端口的配置,代码如下所示:

属性文件是最常见的管理配置属性的方式。Spring Boot提供的SpringApplication类会搜索并加载application.properties文件来获取配置属性值。SpringApplication类会在下面位置搜索该文件:
·当前目录的"/config”子目录
·当前目录
.classpath中的"/config"包
.classpath

上面的顺序也表示了该位置上包含的属性文件的优先级。优先级按照从高到低的顺序排列。可以通过spring.config.name配置属性来指定不同的属性文件名称。还可以通过spring.config.location来添加额外的属性文件的搜索路径。如果Spring Boot在优先级更高的位置找到了配置,那么它就会忽略低优先级的配置。

外部化配置

Spring Boot所提供的配置优先级顺序比较复杂。按照优先级从高到低的顺序,具体的列表如下所示:

  • 1)命令行参数。SpringApplication类默认会把命令行参数转化成应用中可以使用的配置参数。
  • 2)通过system#getProperties方法获取的Java系统参数。
  • 3)操作系统环境变量。使用Docker启动时,经常会设置系统变量。 4)从java: complenv得到的JNDI属性。
  • 5)通过RandomValuePropertySource生成的random.*属性。
  • 6)应用jar文件之外的属性文件,如通过spring.config.location参数指定的属性文件。
  • 7)应用jar文件内部的属性文件,这是常用的方式。
  • 8)在应用配置Java类(包含@Configuration注解的Java类)中通过@PropertySource注解声明的属性文件。
  • 9)通过SpringApplication#setDefaultProperties方法声明的默认属性。

有些系统会涉及一些数据库或其他第三方账户等信息,出于安全考虑,这些信息并不会提前配置在项目中。对于这种情况,可以在运行程序的时候通过参数指定一个外部配置文件的方式来解决。
以demo.jar为例,方法如下:

这里指定的外部文件名无固定要求,如果需要通过bash脚本来加载不同环境的外部配置文件,文件的命名可以参考application-{env}.properties。

YAML

YAML是JSON的超集,是一种非常方便的格式,它一般用于指定分层配置数据。SpringApplication类能够自动支持YAML,将其作为Properties属性文件的替代者。SpringFramework提供了两个可用于加载YAML文档的类:
YamlPropertiesFactoryBean将YAML加载为Properties; YamlMapFactoryBean将YAML加载为Map。如下面的属性配置:

相应的YAML的配置如下:

从上面的对比可以看出YAML利于开发者阅读,更易于实施和使用。

自动载入外部属性到Bean

当@EnableConfigurationProperties注解应用到@Configuration修饰的配置类时,任何被@ConfigurationProperties注解的Bean将自动由Environment配置。这种风格的配置特别适合与SpringApplication的外部YAML配置配合使用。

Spring Boot使用相对宽松的规则来将环境属性绑定到使用

@ConfigurationProperties注解的Bean中,所以不需要环境属性名称和Bean属性名称完全匹配。Java中的属性变量命名使用驼峰法,例如当属性名定义为maxLength时,在配置文件中max-length和MAXLENGTH都将会被映射到maxLength属性。我们看几个实例应用。
属性实体类代码如下:

在@ConfigurationProperties中指明prefix,定义实体的映射规则,可以简化配置。这种配置方式支持复杂的属性类型,如数组、Map和子对象等。

多Profile

spring Boot使用Profile为不同环境提供不同配置,可以和全局Profile配合使用。
Spring通过配置spring.profiles.active指定激活某个具体的Profile。除了使用spring.profiles.active激活一个或者多个Profile之外,还可以用spring.profiles.include来叠加Profile。如下所示:

spring. profiles.include: prod,dev

一个多Profile的application.yml配置如下所示:

spring:
  profiles:
    active: dev
#开发环境配置
spring:
  profiles: dev
server:
  port: 8080
#测试环境配置
spring:
  profiles: test
server:
  port: 8081
--
#生产环境配置
spring:
  profiles: prod
server:
  port: 8082
 

上述application.yml文件分为四部分,使用一组(—)来作为分隔符。第一部分,通用配置部分,表示三个环境都通用的属性,默认激活了dev的Profile;后面三部分分别表示不同的环境,指定了不同的端口(port) 。

Spring Boot应用通常会被打包成jar包部署到服务器中。在启动jar应用时,可以加上参数–spring.profiles.active=test指定应用加载哪个环境的配置。在IDEA中也可以直接指定应用启动时激活哪个Profile。

Starter

Spring Boot项目的快速发展与流行,很大程度依赖于Starter的出现。Starter方便了Spring各项依赖的集成,通过Starter,可以在Spring Boot中获取到所需相关技术的一站式支持(依赖、相关的自动配置文件和相关的Bean),而无需通过实例代码和复制粘贴来获取依赖。例如当需要Spring中的Web支持时,可以通过引入spring-boot-starter-web这个Starter依赖,它将自动为项目配置一个内嵌的Tomcat以及开启SpringWebMvc的功能,下面是一些常用的Starter:

  • spring-boot-starter:核心Starter,包含自动配置的支持、日志以及YAML解析等。
  • spring-boot-starter-aop:提供Spring AOP和AspectJ的面向切面的编程支持。
  • spring-boot-starter-data-jpa:提供Spring Data JPA支持(由Hibernate提供底层支持)。
  • spring-boot-starter-data-mongodb:提供Spring Data MongoDB和MongoDB支持。
  • spring-boot-starter-jdbc:提供JDBC支持(由Tomcat JDBC连接池提供支持)。
  • spring-boot-starter-jersey:提供使用JAX-RS和Jersey构建RESTful风格的Web应用的支持。
  • spring-boot-starter-web:提供使用Spring MVC构建Web(包含RESTful)应用的支持,使用Tomcat作为默认嵌入式容器。
  • spring-boot-starter-webflux:提供使用Spring Framework的Reactive
    Web构建WebFlux应用的支持。
  • spring-boot-starter-actuator: Spring
  • Boot的Actuator支持,其提供了生产就绪功能,帮助开发者监控和管理应用。

更多的Starter可以通过官方文档查阅。Starter大大简化了开发者对Spring相关依赖的配置,让他们能够将更多的精力放置在业务开发上,提高生产效率。

有关【微服务 从0开始 】Spring Cloud 配置文件的更多相关文章

  1. ruby - 使用 RubyZip 生成 ZIP 文件时设置压缩级别 - 2

    我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看ruby​​zip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d

  2. ruby - 其他文件中的 Rake 任务 - 2

    我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时

  3. ruby-on-rails - 在 Rails 中将文件大小字符串转换为等效千字节 - 2

    我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,

  4. ruby-on-rails - Rails 3 中的多个路由文件 - 2

    Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题

  5. ruby - 将差异补丁应用于字符串/文件 - 2

    对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl

  6. ruby - 如何将脚本文件的末尾读取为数据文件(Perl 或任何其他语言) - 2

    我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚

  7. ruby - 使用 Vim Rails,您可以创建一个新的迁移文件并一次性打开它吗? - 2

    使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta

  8. Ruby 写入和读取对象到文件 - 2

    好的,所以我的目标是轻松地将一些数据保存到磁盘以备后用。您如何简单地写入然后读取一个对象?所以如果我有一个简单的类classCattr_accessor:a,:bdefinitialize(a,b)@a,@b=a,bendend所以如果我从中非常快地制作一个objobj=C.new("foo","bar")#justgaveitsomerandomvalues然后我可以把它变成一个kindaidstring=obj.to_s#whichreturns""我终于可以将此字符串打印到文件或其他内容中。我的问题是,我该如何再次将这个id变回一个对象?我知道我可以自己挑选信息并制作一个接受该信

  9. ruby - 如何使用 Ruby aws/s3 Gem 生成安全 URL 以从 s3 下载文件 - 2

    我正在编写一个小脚本来定位aws存储桶中的特定文件,并创建一个临时验证的url以发送给同事。(理想情况下,这将创建类似于在控制台上右键单击存储桶中的文件并复制链接地址的结果)。我研究过回形针,它似乎不符合这个标准,但我可能只是不知道它的全部功能。我尝试了以下方法:defauthenticated_url(file_name,bucket)AWS::S3::S3Object.url_for(file_name,bucket,:secure=>true,:expires=>20*60)end产生这种类型的结果:...-1.amazonaws.com/file_path/file.zip.A

  10. ruby - rspec 需要 .rspec 文件中的 spec_helper - 2

    我注意到像bundler这样的项目在每个specfile中执行requirespec_helper我还注意到rspec使用选项--require,它允许您在引导rspec时要求一个文件。您还可以将其添加到.rspec文件中,因此只要您运行不带参数的rspec就会添加它。使用上述方法有什么缺点可以解释为什么像bundler这样的项目选择在每个规范文件中都需要spec_helper吗? 最佳答案 我不在Bundler上工作,所以我不能直接谈论他们的做法。并非所有项目都checkin.rspec文件。原因是这个文件,通常按照当前的惯例,只

随机推荐