Spring?Cloud?Alibaba使用Nacos作為注冊中心和配置中心
前言
Spring Cloud Alibaba 致力于提供微服務(wù)開發(fā)的一站式解決方案,Nacos 作為其核心組件之一,可以作為注冊中心和配置中心使用,本文將對其用法進(jìn)行詳細(xì)介紹。
Nacos簡介
Nacos 致力于幫助您發(fā)現(xiàn)、配置和管理微服務(wù)。Nacos 提供了一組簡單易用的特性集,幫助您快速實現(xiàn)動態(tài)服務(wù)發(fā)現(xiàn)、服務(wù)配置、服務(wù)元數(shù)據(jù)及流量管理。
Nacos 具有如下特性:
- 服務(wù)發(fā)現(xiàn)和服務(wù)健康監(jiān)測:支持基于DNS和基于RPC的服務(wù)發(fā)現(xiàn),支持對服務(wù)的實時的健康檢查,阻止向不健康的主機或服務(wù)實例發(fā)送請求;
- 動態(tài)配置服務(wù):動態(tài)配置服務(wù)可以讓您以中心化、外部化和動態(tài)化的方式管理所有環(huán)境的應(yīng)用配置和服務(wù)配置;
- 動態(tài) DNS 服務(wù):動態(tài) DNS 服務(wù)支持權(quán)重路由,讓您更容易地實現(xiàn)中間層負(fù)載均衡、更靈活的路由策略、流量控制以及數(shù)據(jù)中心內(nèi)網(wǎng)的簡單DNS解析服務(wù);
- 服務(wù)及其元數(shù)據(jù)管理:支持從微服務(wù)平臺建設(shè)的視角管理數(shù)據(jù)中心的所有服務(wù)及元數(shù)據(jù)。
使用Nacos作為注冊中心
安裝并運行Nacos
我們先從官網(wǎng)下載Nacos,這里下載的是nacos-server-1.1.4.zip文件,
下載地址:https://github.com/alibaba/nacos/releases
配置JAVA_HOME環(huán)境變量,不配置會導(dǎo)致無法運行Nacos;
JAVA_HOME=D:\developer\env\Java\jdk1.8.0_91
解壓安裝包,直接運行bin目錄下的startup.cmd;
運行成功后,訪問http://localhost:8848/nacos可以查看Nacos的主頁,默認(rèn)賬號密碼都是nacos。
創(chuàng)建應(yīng)用注冊到Nacos
我們通過改造consul-user-service和consul-ribbon-service來演示下服務(wù)注冊與發(fā)現(xiàn)的功能,主要是將應(yīng)用原來的Consul注冊中心支持改為Nacos注冊中心支持。
創(chuàng)建nacos-user-service模塊和nacos-ribbon-service模塊;
如果要使用Spring Cloud Alibaba 的組件都需要在pom.xml中添加如下的配置;
<dependencyManagement> <dependencies> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-alibaba-dependencies</artifactId> <version>2.1.0.RELEASE</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
修改相關(guān)依賴,把原來的Consul注冊發(fā)現(xiàn)的依賴改為Nacos的:
<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency>
修改配置文件application.yml,將Consul的注冊發(fā)現(xiàn)配置改為Nacos的:
server: port:8206 spring: application: name:nacos-user-service cloud: nacos: discovery: server-addr:localhost:8848#配置Nacos地址 management: endpoints: web: exposure: include:'*'
運行兩個nacos-user-service和一個nacos-ribbon-service,在Nacos頁面上可以看到如下信息:
負(fù)載均衡功能
由于我們運行了兩個nacos-user-service,而nacos-ribbon-service默認(rèn)會去調(diào)用它的接口,我們調(diào)用nacos-ribbon-service的接口來演示下負(fù)載均衡功能。
多次調(diào)用接口:http://localhost:8308/user/1 ,可以發(fā)現(xiàn)兩個nacos-user-service的控制臺交替打印如下信息。
2019-11-06 14:28:06.458 INFO 12092 --- [nio-8207-exec-2] c.macro.cloud.controller.UserController : 根據(jù)id獲取用戶信息,用戶名稱為:macro
使用Nacos作為配置中心
我們通過創(chuàng)建nacos-config-client模塊,并在Nacos頁面中添加配置信息來演示下配置管理的功能。
創(chuàng)建nacos-config-client模塊
在pom.xml中添加相關(guān)依賴:
<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency>
添加配置文件application.yml,啟用的是dev環(huán)境的配置:
spring: profiles: active:dev
添加配置文件bootstrap.yml,主要是對Nacos的作為配置中心的功能進(jìn)行配置:
server: port:9101 spring: application: name:nacos-config-client cloud: nacos: discovery: server-addr:localhost:8848#Nacos地址 config: server-addr:localhost:8848#Nacos地址 file-extension:yaml#這里我們獲取的yaml格式的配置
創(chuàng)建ConfigClientController,從Nacos配置中心中獲取配置信息:
/** * Created by macro on 2019/9/11. */ @RestController @RefreshScope publicclass ConfigClientController { @Value("${config.info}") private String configInfo; @GetMapping("/configInfo") public String getConfigInfo() { return configInfo; } }
在Nacos中添加配置
我們先來講下Nacos中的dataid的組成格式及與SpringBoot配置文件中的屬性對應(yīng)關(guān)系:
${spring.application.name}-${spring.profiles.active}.${spring.cloud.nacos.config.file-extension}
比如說我們現(xiàn)在要獲取應(yīng)用名稱為nacos-config-client的應(yīng)用在dev環(huán)境下的yaml配置,dataid如下:
nacos-config-client-dev.yaml
按照以上dataid添加如下配置:
config: info:"config info for dev"
填寫配置示意圖:
啟動nacos-config-client,調(diào)用接口查看配置信息:http://localhost:9101/configInfo
config info for dev
Nacos的動態(tài)刷新配置
我們只要修改下Nacos中的配置信息,再次調(diào)用查看配置的接口,就會發(fā)現(xiàn)配置已經(jīng)刷新,Nacos和Consul一樣都支持動態(tài)刷新配置。當(dāng)我們在Nacos頁面上修改配置并發(fā)布后,應(yīng)用會刷新配置并打印如下信息。
2019-11-06 14:50:49.460 INFO 12372 --- [-localhost_8848] trationDelegate$BeanPostProcessorChecker : Bean 'org.springframework.cloud.autoconfigure.ConfigurationPropertiesRebinderAutoConfiguration' of type [org.springframework.cloud.autoconfigure.ConfigurationPropertiesRebinderAutoConfiguration$$EnhancerBySpringCGLIB$$ec395f8e] is not eligible for getting processed by all BeanPostProcessors (for example: not eligible for auto-proxying) 2019-11-06 14:50:49.608 INFO 12372 --- [-localhost_8848] c.a.c.n.c.NacosPropertySourceBuilder : Loading nacos data, dataId: 'nacos-config-client-dev.yaml', group: 'DEFAULT_GROUP' 2019-11-06 14:50:49.609 INFO 12372 --- [-localhost_8848] b.c.PropertySourceBootstrapConfiguration : Located property source: CompositePropertySource {name='NACOS', propertySources=[NacosPropertySource {name='nacos-config-client-dev.yaml'}, NacosPropertySource {name='nacos-config-client.yaml'}]} 2019-11-06 14:50:49.610 INFO 12372 --- [-localhost_8848] o.s.boot.SpringApplication : The following profiles are active: dev 2019-11-06 14:50:49.620 INFO 12372 --- [-localhost_8848] o.s.boot.SpringApplication : Started application in 0.328 seconds (JVM running for 172.085) 2019-11-06 14:50:49.638 INFO 12372 --- [-localhost_8848] o.s.c.e.event.RefreshEventListener : Refresh keys changed: [config.info]
參考資料
Spring Cloud Alibaba 官方文檔:https://github.com/alibaba/spring-cloud-alibaba/wiki
使用到的模塊
springcloud-learning ├── nacos-config-client -- 用于演示nacos作為配置中心的nacos客戶端 ├── nacos-user-service -- 注冊到nacos的提供User對象CRUD接口的服務(wù) └── nacos-service -- 注冊到nacos的ribbon服務(wù)調(diào)用測試服務(wù)
項目源碼地址
https://github.com/macrozheng/springcloud-learning
以上就是Spring Cloud Alibaba使用Nacos作為注冊中心和配置中心的詳細(xì)內(nèi)容,更多關(guān)于Spring Cloud Alibaba使用Nacos注冊配置的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
詳解spring中使用Elasticsearch的代碼實現(xiàn)
本篇文章主要介紹了詳解spring中使用Elasticsearch的代碼實現(xiàn),具有一定的參考價值,有興趣的可以了解一下2017-05-05WeakHashMap?和?HashMap?區(qū)別及使用場景
這篇文章主要為大家介紹了WeakHashMap?和?HashMap?的區(qū)別是什么以及何時使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11使用maven如何將項目中的test代碼打包進(jìn)jar中
這篇文章主要介紹了使用maven如何將項目中的test代碼打包進(jìn)jar中,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03在Mybatis中association標(biāo)簽多層嵌套的問題
這篇文章主要介紹了在Mybatis中association標(biāo)簽多層嵌套的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03Java設(shè)計模式之單例模式實例詳解【懶漢式與餓漢式】
這篇文章主要介紹了Java設(shè)計模式之單例模式,簡單說明了單例模式的原理并結(jié)合具體實例形式分析了單例模式中懶漢式與餓漢式的具體實現(xiàn)與使用技巧,需要的朋友可以參考下2017-09-09