Spring Cloud Config(统一配置中心服务端和客户端)

Spring Cloud Config(统一配置中心服务端和客户端),第1张

Spring Cloud Config为分布式系统中的外部化配置提供服务器和客户端支持。Spring Cloud Config 是一种用来动态获取Git、SVN、本地的配置文件的一种工具。可以在所有环境中管理应用程序的外部属性。可以与任何语言运行的任何应用程序一起使用。当应用程序通过部署从开发到测试并进入生产时,可以管理这些环境之间的配置,并确保应用程序具有迁移时需要运行的所有内容。服务器存储后端的默认实现使用git,可以轻松支持配置环境的标签版本,以及可用于管理内容的各种工具。添加替代实现并使用Spring配置插入很容易。

Github地址: >

这种方式适用于采用Spring框架的独立应用程序,需要程序通过配置文件手工初始化Spring的配置信息。

方法二:通过Spring提供的工具类获取ApplicationContext对象

import orgspringframeworkwebcontextsupportWebApplicationContextUtils;

ApplicationContext ac1 =

方法三:继承自抽象类ApplicationObjectSupport

抽象类ApplicationObjectSupport提供getApplicationContext()方法,可以方便的获取到ApplicationContext。Spring初始化时,会通过该抽象类的

方法四:继承自抽象类WebApplicationObjectSupport

类似上面方法,调用getWebApplicationContext()获取WebApplicationContext

方法五:实现接口ApplicationContextAware

实际上就于Spring框架紧密耦合在一起了,因为这些类是运行在Spring框架上的,因此,系统中,应该尽量的减少这类应用,使系统尽可能的独立于当前运行环境。

classpath:是从类路径里查找配置文件,也就是/WEB-INF/classes目录下找SpringMVC-servletxml。

你写了classpath了,不会从web-info下找,而是去web-inf/classes下面找,所以找不到。

服务器(Tomcat)读取资源文件

方式一:采用流+Properties

当工程部署到Tomcat中时,按照上边方式,则会出现找不到该文件路径的异常。经搜索资料知道,Java工程打包部署到Tomcat中时,properties的路径变到顶层(classes下),这是由Maven工程结构决定的。由Maven构建的web工程,主代码放在src/main/java路径下,资源放在src/main/resources路径下,当构建为war包的时候,会将主代码和资源文件放置classes文件夹下,并且,此时读取文件需要采用流(stream)的方式读取,并通过JDK中Properties类加载,可以方便的获取到配置文件中的信息,如下。

采用Spring注解

如果工程中使用Spring,可以通过注解的方式获取配置信息,但需要将配置文件放到Spring配置文件中扫描后,才能将配置信息放入上下文,然后在程序中可以使用 @Value进行获取properties文件中的属性值。

采用Spring配置

也可以在Spring配置文件中读取属性值,赋予类成员变量。

首先Spring security不完全是依赖>

有个独立的API项目,该项目主要是对外部各个系统提供API接口,为了保证调用的安全,需要对请求进行校验,主要校验包括调用频率,访问IP,是否跨域和Token,其中IP和是否跨域的配置会根据接入方进行相应的修改,为了避免每次有新的接入方就得去修改一次配置文件并重启项目,所以打算使用动态配置的方式。

初级实现方案:API服务每隔5分钟向管理端请求一次数据,管理端添加IP和域白名单的管理,这个实现方案,简单好用,但是弊端也明显,管理端每次修改完配置后,客户端需要等待下次请求后才会加载对应的配置,同时,还需要自己管理获取到的配置文件

更新方案:在springboot启动时,先从远端获取配置文件,并将其加载进Environment对象中,其余的,就都交给Spring了。同时配合spring-cloud-context实现远程配置变更后,本地重新拉取配置并更新

点进去之后,springboot会在这里初始化ConfigurableEnvironment对象

这里是给ConfigurableEnvironment做一些初始化工作,我们先不管了,重点在这里,listenersenvironmentPrepared(environment);,Springboot通过事件,将Environment的加载分发出去

到此为止,我们就能像使用本地配置文件一样使用服务器上的配置文件了,但是这里还只实现了加载远程配置文件,我们还需要在远程配置文件变更时,实现配置文件的热更新

首先你要明白spring的ApplicationContext是放在tomcat的application里的,所以第一步是取得application,也就是requestgetSession()getServletContext()

第二步是通过调用spring提供的静态方法取得ApplicationContext,此方法的参数是第一步取得的application

如下:

WebApplicationContextUtilsgetRequiredWebApplicationContext(requestgetSession()getServletContext());

我使用过的方法有两种

通过ClassPathXmlApplicationContext方法或是XmlBeanFactory等方法获得ApplicationContext,它们拥有着继承关系,具体可以搜索一下,这个一般用作测试。

使用spring的bean注入,实现ApplicationContextAware接口,这个可以把调用ApplicationContext做成一个工具类。

以上就是关于Spring Cloud Config(统一配置中心服务端和客户端)全部的内容,包括:Spring Cloud Config(统一配置中心服务端和客户端)、Spring从容器中获取bean对象可以分别通过什么接口、JAVA maven创建web项目,把Spring框架配置文件放在src/main/resources中读取不到配置文件等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9759689.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)