您好,登錄后才能下訂單哦!
Spring Cloud是現在流行的分布式服務框架,它提供了很多有用的組件。比如:配置中心、Eureka服務發現、消息總線、熔斷機制等。
配置中心在Spring Cloud的眾多組件中是比較基礎的,它提供了配置文件的統一管理,可以很輕松的切換不通的環境。
它的具體結構如下:
Spring Cloud是建立在Spring Boot基礎上的,Spring Cloud離不開Spring Boot,所以我們的項目都是基于Spring Boot的。
配置文件一般我們放在git上,也好做版本控制。接下來我們講一下配置中心的搭建。
配置中心搭建
首先,引入Spring Boot和Spring Cloud的依賴BOM:
<dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Edgware.SR3</version> <type>pom</type> <scope>import</scope> </dependency> <dependency> <!-- Import dependency management from Spring Boot --> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>1.5.9.RELEASE</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
這里我們需要仔細看一下官方文檔,Spring Cloud的Finchley版本是基于Spring Boot2.0的,在Spring Boot1.5下是不能工作的。而Edgware版本是基于1.5的,在2.0下不能正常工作。這點大家要注意,以免出現不必要的麻煩。
這里我們采用Spring Cloud 的Edgware和Spring Boot的1.5版本。
然后倒入必須的依賴,如下:
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-config-server</artifactId> </dependency> </dependencies>
最后編寫配置中心的啟動類,如下:
@SpringBootApplication @EnableConfigServer public class ConfigServerApplication { public static void main(String[] args) { SpringApplication.run(ConfigServerApplication.class, args); } }
@EnableConfigServer標志著這個服務是一個配置中心服務,具體的信息在application.properties文件中配置:
#服務端口 server.port=9000 #配置文件的git地址 spring.cloud.config.server.git.uri=https://github.com/liubo-tech/spring-cloud-properties #配置文件的臨時文件目錄 spring.cloud.config.server.git.basedir=/d:/config-repo
服務端口和git地址大家都比較明白,第三個是配置臨時文件的目錄。在配置中心被調用后,配置中心會從git上拉取配置文件,并在本地緩存,這個就是配置緩存的目錄,也可以不配置,使用系統默認的。這樣配置中心就搭好了,也可以通過Nginx搭建集群做的高可用。
訪問配置文件格式的如下:
/{application}/{profile}[/{label}] /{application}-{profile}.yml /{label}/{application}-{profile}.yml /{application}-{profile}.properties /{label}/{application}-{profile}.properties
其中:
客戶端調用
以前配置文件都是放在項目中,這使得我們在切換不同環境時非常麻煩,一些配置的敏感信息也對開發人員暴露了。
使用統一的配置中心就可以避免這些,讓我們看一看客戶端是如何調用的。
首先,導入必須依賴的jar包,如下:
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-config</artifactId> </dependency> </dependencies>
只要Spring Cloud Config Client的jar在項目的classpath下,它就會在項目啟動時從配置中心獲取配置,通過bootstrap配置文件中的spring.cloud.config.uri屬性指定配置中心。
這使得客戶端的項目必須有一個bootstrap.yml或者bootstrap.properties文件,否則客戶端是不會從配置中心加載配置文件的。
我們創建bootstrap.properties,如下:
#配置中心地址 spring.cloud.config.uri=http://localhost:9000
指定配置中心的地址,上面的例子中,配置中心的端口我們指定9000。我們在application.properties文件中配置應用的名稱:
spring.application.name=eg-config
我們應用叫作“eg-config”,項目啟動時會從配置中心加載eg-config的文件。接下來我們做個例子,創建一個Bean,并從配置中心注入值
@Component public class MyBean { @Value("${my.name}") private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } }
其中,name會從配置中心加載屬性my.name。啟動類如下:
@SpringBootApplication public class Application { public static void main(String[] args) { ConfigurableApplicationContext applicationContext = SpringApplication.run(Application.class, args); //獲取bean并打印name字段 MyBean bean = applicationContext.getBean(MyBean.class); System.out.println(bean.getName()); } }
啟動后,控制臺打印的結果如下:test
這樣配置中心就介紹完了,具體請參考項目示例:https://github.com/liubo-tech/spring-cloud-config。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。