Spring?Cloud?Alibaba使用Nacos作為注冊(cè)中心和配置中心
前言
Spring Cloud Alibaba 致力于提供微服務(wù)開發(fā)的一站式解決方案,Nacos 作為其核心組件之一,可以作為注冊(cè)中心和配置中心使用,本文將對(duì)其用法進(jìn)行詳細(xì)介紹。
Nacos簡介
Nacos 致力于幫助您發(fā)現(xiàn)、配置和管理微服務(wù)。Nacos 提供了一組簡單易用的特性集,幫助您快速實(shí)現(xiàn)動(dòng)態(tài)服務(wù)發(fā)現(xiàn)、服務(wù)配置、服務(wù)元數(shù)據(jù)及流量管理。
Nacos 具有如下特性:
- 服務(wù)發(fā)現(xiàn)和服務(wù)健康監(jiān)測(cè):支持基于DNS和基于RPC的服務(wù)發(fā)現(xiàn),支持對(duì)服務(wù)的實(shí)時(shí)的健康檢查,阻止向不健康的主機(jī)或服務(wù)實(shí)例發(fā)送請(qǐng)求;
- 動(dòng)態(tài)配置服務(wù):動(dòng)態(tài)配置服務(wù)可以讓您以中心化、外部化和動(dòng)態(tài)化的方式管理所有環(huán)境的應(yīng)用配置和服務(wù)配置;
- 動(dòng)態(tài) DNS 服務(wù):動(dòng)態(tài) DNS 服務(wù)支持權(quán)重路由,讓您更容易地實(shí)現(xiàn)中間層負(fù)載均衡、更靈活的路由策略、流量控制以及數(shù)據(jù)中心內(nèi)網(wǎng)的簡單DNS解析服務(wù);
- 服務(wù)及其元數(shù)據(jù)管理:支持從微服務(wù)平臺(tái)建設(shè)的視角管理數(shù)據(jù)中心的所有服務(wù)及元數(shù)據(jù)。
使用Nacos作為注冊(cè)中心
安裝并運(yùn)行Nacos
我們先從官網(wǎng)下載Nacos,這里下載的是nacos-server-1.1.4.zip文件,
下載地址:https://github.com/alibaba/nacos/releases
配置JAVA_HOME環(huán)境變量,不配置會(huì)導(dǎo)致無法運(yùn)行Nacos;
JAVA_HOME=D:\developer\env\Java\jdk1.8.0_91
解壓安裝包,直接運(yùn)行bin目錄下的startup.cmd;
運(yùn)行成功后,訪問http://localhost:8848/nacos可以查看Nacos的主頁,默認(rèn)賬號(hào)密碼都是nacos。

創(chuàng)建應(yīng)用注冊(cè)到Nacos
我們通過改造consul-user-service和consul-ribbon-service來演示下服務(wù)注冊(cè)與發(fā)現(xiàn)的功能,主要是將應(yīng)用原來的Consul注冊(cè)中心支持改為Nacos注冊(cè)中心支持。
創(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注冊(cè)發(fā)現(xiàn)的依賴改為Nacos的:
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
修改配置文件application.yml,將Consul的注冊(cè)發(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:'*'
運(yùn)行兩個(gè)nacos-user-service和一個(gè)nacos-ribbon-service,在Nacos頁面上可以看到如下信息:

負(fù)載均衡功能
由于我們運(yùn)行了兩個(gè)nacos-user-service,而nacos-ribbon-service默認(rèn)會(huì)去調(diào)用它的接口,我們調(diào)用nacos-ribbon-service的接口來演示下負(fù)載均衡功能。
多次調(diào)用接口:http://localhost:8308/user/1 ,可以發(fā)現(xiàn)兩個(gè)nacos-user-service的控制臺(tái)交替打印如下信息。
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,主要是對(duì)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配置文件中的屬性對(duì)應(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"
填寫配置示意圖:

啟動(dòng)nacos-config-client,調(diào)用接口查看配置信息:http://localhost:9101/configInfo
config info for dev
Nacos的動(dòng)態(tài)刷新配置
我們只要修改下Nacos中的配置信息,再次調(diào)用查看配置的接口,就會(huì)發(fā)現(xiàn)配置已經(jīng)刷新,Nacos和Consul一樣都支持動(dòng)態(tài)刷新配置。當(dāng)我們?cè)贜acos頁面上修改配置并發(fā)布后,應(yīng)用會(huì)刷新配置并打印如下信息。
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 -- 注冊(cè)到nacos的提供User對(duì)象CRUD接口的服務(wù) └── nacos-service -- 注冊(cè)到nacos的ribbon服務(wù)調(diào)用測(cè)試服務(wù)
項(xiàng)目源碼地址
https://github.com/macrozheng/springcloud-learning
以上就是Spring Cloud Alibaba使用Nacos作為注冊(cè)中心和配置中心的詳細(xì)內(nèi)容,更多關(guān)于Spring Cloud Alibaba使用Nacos注冊(cè)配置的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
springboot短信驗(yàn)證碼登錄功能的實(shí)現(xiàn)
這篇文章主要介紹了springboot短信驗(yàn)證碼登錄功能的實(shí)現(xiàn),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02
Spring如何使用三級(jí)緩存解決循環(huán)依賴
在Spring框架中,循環(huán)依賴是指兩個(gè)或多個(gè)Bean相互依賴,形成閉環(huán),導(dǎo)致無法完成初始化,此問題僅存在于單例Bean中,而原型Bean會(huì)拋出異常,Spring通過三級(jí)緩存及提前暴露策略解決循環(huán)依賴:一級(jí)緩存存放完全初始化的Bean2024-11-11
Java實(shí)現(xiàn)文件批量重命名,移動(dòng)和刪除
這篇文章主要為大家介紹了如何利用Java語言實(shí)現(xiàn)批量重命名,批量移動(dòng)文件,批量刪除tmp文件等功能,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2022-08-08
springboot中rabbitmq實(shí)現(xiàn)消息可靠性機(jī)制詳解
這篇文章主要介紹了springboot中rabbitmq實(shí)現(xiàn)消息可靠性機(jī)制詳解,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-09-09
SpringBoot Test 多線程報(bào)錯(cuò)的根本原因(dataSource already
在使用Springboot test進(jìn)行相關(guān)測(cè)試的時(shí)候,發(fā)現(xiàn)開啟線程操作數(shù)據(jù)庫的時(shí)候異常,這篇文章主要介紹了SpringBoot Test 多線程報(bào)錯(cuò):dataSource already closed的根本原因及解決方法,需要的朋友可以參考下2022-06-06
Java中的NoClassDefFoundError報(bào)錯(cuò)含義解析
這篇文章主要為大家介紹了Java中的NoClassDefFoundError含義詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助2023-11-11

