在之前的两篇文章
Spring Cloud Alibaba基础教程第一篇:使用Nacos实现服务注册与发现
Spring Cloud Alibaba基础教程第二篇:消费方式
相信我们已经简单掌握,如何利用Nacos搭建注册中心并实现服务的注册与发现。还有在Alibaba Spring Cloud中,我们同样可以使用Ribbon和Feign两种服务消费方式。那么接下来,我们再来学习一下Nacos的配置管理,来感受它的美
通过官方文档了解到,Nacos不仅有服务发现和服务健康监测,实现服务的注册发现之外,还有动态配置服务。Nacos动态配置服务可以让您以中心化、外部化和动态化的方式管理所有环境的应用配置和服务配置,我们可以将整个架构体系内的所有配置都集中在Nacos中存储。这个道理和Spring Cloud Config是一样的,优点主要有以下几点:
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 环境中。当应用程序通过部署管道从开发到测试再到生产时,您可以管理这些环境之间的配置,并确保应用程序具有迁移时需要运行的所有内容
接下来介绍如何在Nacos中创建配置内容以及如何在Spring Cloud应用中获取Nacos的配置信息 演示相关版本:
Nacos: 1.0.1 Spring Boot: 2.1.6.RELEASE Spring Cloud: Greenwich.SR1 Spring Cloud Alibaba: 0.2.2.RELEASE
打开浏览器输入: localhost:8848 输入账号密码 进入Nacos控制主页
点击右上角:heavy_plus_sign: 填入以下相关配置
PS:
在 Nacos Spring Cloud 中,dataId 的完整格式如下: ${prefix}-${spring.profile.active}.${file-extension}
${prefix}.${file-extension}
配置完成后是这样的
参数配置完毕,肯定需要程序来获取,安排!
这里使用的姿势和上篇文章一样
<?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中的配置内容之后,这里也会马上生效
可以看到返回结果变了