在以前的两篇文章
Spring Cloud Alibaba基础教程第一篇:使用Nacos实现服务注册与发现
Spring Cloud Alibaba基础教程第二篇:消费方式
相信咱们已经简单掌握,如何利用Nacos搭建注册中心并实现服务的注册与发现。还有在Alibaba Spring Cloud中,咱们一样可使用Ribbon和Feign两种服务消费方式。那么接下来,咱们再来学习一下Nacos的配置管理,来感觉它的美java
经过官方文档了解到,Nacos不只有服务发现和服务健康监测,实现服务的注册发现以外,还有动态配置服务。Nacos动态配置服务可让您以中心化、外部化和动态化的方式管理全部环境的应用配置和服务配置,咱们能够将整个架构体系内的全部配置都集中在Nacos中存储。这个道理和Spring Cloud Config是同样的,优势主要有如下几点:git
Nacos 提供用于存储配置和其余元数据的 key/value 存储,为分布式系统中的外部化配置提供服务器端和客户端支持。使用 Spring Cloud Alibaba Nacos Config,您能够在 Nacos Server 集中管理你 Spring Cloud 应用的外部属性配置。 Spring Cloud Alibaba Nacos Config 是 Config Server 和 Client 的替代方案,客户端和服务器上的概念与 Spring Environment 和 PropertySource 有着一致的抽象,在特殊的 bootstrap 阶段,配置被加载到 Spring 环境中。当应用程序经过部署管道从开发到测试再到生产时,您能够管理这些环境之间的配置,并确保应用程序具备迁移时须要运行的全部内容github
接下来介绍如何在Nacos中建立配置内容以及如何在Spring Cloud应用中获取Nacos的配置信息 演示相关版本:web
Nacos: 1.0.1 Spring Boot: 2.1.6.RELEASE Spring Cloud: Greenwich.SR1 Spring Cloud Alibaba: 0.2.2.RELEASEspring
打开浏览器输入: localhost:8848 输入帐号密码 进入Nacos控制主页apache
PS:json
在 Nacos Spring Cloud 中,dataId 的完整格式以下:${prefix}-${spring.profile.active}.${file-extension}
bootstrap
${prefix}.${file-extension}
配置完成后是这样的浏览器
参数配置完毕,确定须要程序来获取,安排!bash
这里使用的姿式和上篇文章同样
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.xd</groupId>
<artifactId>SpringCloudAlibabaLearn</artifactId>
<version>1.0-SNAPSHOT</version>
<relativePath>../</relativePath>
</parent>
<artifactId>alibaba-nacos-config-client</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>alibaba-nacos-config-client</name>
<description>Nacos做为配置中心服务</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<!--nacos config依赖-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
复制代码
主要仍是在以前的基础做为子模块,集成父pom文件,添加nacos-config依赖
server.port=8084
#配置客户端 Nacos中建立的配置Data Id匹配( 除了.properties或者.yaml后缀)
spring.application.name=alibaba-nacos-config-client
#注册服务到nacos
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
#配置中心地址
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
复制代码
主要配置注册中心和配置中心 注意:这里必须使用bootstrap.properties。同时,spring.application.name值必须与上一阶段Nacos中建立的配置Data Id匹配(除了.properties或者.yaml后缀)
package com.xd.alibabanacosconfigclient;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RefreshScope //主要用来让这个类下的配置内容支持动态刷新
@SpringBootApplication
public class AlibabaNacosConfigClientApplication {
public static void main(String[] args) {
SpringApplication.run(AlibabaNacosConfigClientApplication.class, args);
}
// nacos配置的参数
@Value("${gongzhonghao}")
private String gongzhonghao;
@GetMapping("/test")
public String getGongzhonghao() {
return gongzhonghao;
}
}
复制代码
@SpringBootApplication
: 定义是个Spring Boot应用
@RestController
: @RestController注解,至关于@Controller+@ResponseBody两个注解的结合,返回json数据不须要在方法前面加@ResponseBody注解 @Value
: 注入了key为gongzhonghao的配置(默认为空字符串),这个配置会经过/test接口返回,后续咱们会经过这个接口来验证Nacos中配置的加载。 @RefreshScope
: 主要用来让这个类下的配置内容支持动态刷新,也就是当咱们的应用启动以后,修改了Nacos中的配置内容以后,这里也会立刻生效
打开浏览器,输入 http://localhost:8084/test 内容显示以下:
若是您对这些感兴趣,欢迎star、follow、收藏、转发给予支持!