文章目录

  • 配置中心提供的基础功能
  • Nacos实现配置中心
  • 1、在配置文件增加配置(application.yml)
  • 2、使用@Value来引用配置
  • 使用配置中心,怎样的配置方式呢
  • 一、安装nacos
  • 二、启动服务发现
  • 1、引入依赖
  • 2、配置文件
  • 3、开启服务注册发现功能
  • 4、启动服务
  • 三、启动配置管理
  • 1、引入依赖
  • 2、获取Nacos server的配置信息
  • 3、新建配置bootstrap.yml文件
  • 四、配置自动刷新
  • 1:引入依赖
  • 2:配置类加入@RefreshScope注解



配置中心提供的基础功能

  • 统一管理不同环境、不同集群的配置
  • 配置修改实时生效(热发布)
  • 版本管理,每次配置的修改都会有版本记录,可随时回滚
  • 权限管理。配置中心可交给专人来管理,做到配置的权限管理

Nacos实现配置中心

使用配置中心之前,一般这样实现配置,把配置都放到配置文件中,Java代码通过@Value去拿配置或者通过@PropertySource来进行配置:

1、在配置文件增加配置(application.yml)

shortLink:
  url: https://openapidev.xinchengyue.com
  appId: 2020092275789623479853728
  privateKeyIsv: MIIEvgIBADANBgqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCe7DUtSpPMpejhC6vg5HR6Xl15A3QwOueu

2、使用@Value来引用配置

import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class Test {

    @Value("${shortLink.url}")
    private String url;

    @Value("${shortLink.appId}")
    private String appId;

    @Value("${shortLink.privateKeyIsv}")
    private String privateKeyIsv;

    @RequestMapping("/test")
    public String test(){
        return "url:" + url + "</br>appId:" + appId + "</br>privateKeyIsv:" + privateKeyIsv;
    }
}

启动服务,访问 http://localhost:8080/test 返回信息

url:https://openapidev.xinchengyue.com
appId:2020092275789623479853728
privateKeyIsv:MIIEvgIBADANBgqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCe7DUtSpPMpejhC6vg5HR6Xl15A3QwOueu

使用配置中心,怎样的配置方式呢

一、安装nacos

参考:安装步骤 启动后如图所示:

nacos 配置中心架构 nacos做配置中心_spring


访问:http://localhost:8848/nacos/index.html用户名: nacos 密码:nacos

nacos 配置中心架构 nacos做配置中心_spring_02

二、启动服务发现

接下来,讲一下如何在您的 Spring Cloud 项目中启用 Nacos 的服务发现功能。配置服务,从而服务可以通过 Nacos 的服务注册发现功能将其服务注册到 Nacos server 上。

1、引入依赖
<dependency>
			<groupId>com.alibaba.cloud</groupId>
			<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
			<version>2.1.1.RELEASE</version>
		</dependency>

注意:版本 2.1.x.RELEASE 对应的是 Spring Boot 2.1.x 版本。版本 2.0.x.RELEASE 对应的是 Spring Boot 2.0.x 版本,版本 1.5.x.RELEASE 对应的是 Spring Boot 1.5.x 版本。

2、配置文件

application.yml中配置 Nacos server 的地址和应用名。

spring:
  application:
    name: nacos-test
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
3、开启服务注册发现功能

通过 Spring Cloud 原生注解 @EnableDiscoveryClient 开启服务注册发现功能。

@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)
@EnableDiscoveryClient
public class XlfTestApplication {
	public static void main(String[] args) {
		SpringApplication.run(XlfTestApplication.class, args);
	}
}
4、启动服务

启动服务,然后到Nacos server查看是否注册成功。

nacos 配置中心架构 nacos做配置中心_nacos 配置中心架构_03

三、启动配置管理

1、引入依赖
<dependency>
			<groupId>com.alibaba.cloud</groupId>
			<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
			<version>2.1.1.RELEASE</version>
		</dependency>

注意:版本 2.1.x.RELEASE 对应的是 Spring Boot 2.1.x 版本。版本 2.0.x.RELEASE 对应的是 Spring Boot 2.0.x 版本,版本 1.5.x.RELEASE 对应的是 Spring Boot 1.5.x 版本。

2、获取Nacos server的配置信息

在Nacos server上增加配置信息(配置管理->配置列表->新增配置)

  

nacos 配置中心架构 nacos做配置中心_spring cloud_04


nacos 配置中心架构 nacos做配置中心_java_05

3、新建配置bootstrap.yml文件
spring:
  application:
    name: nacos-test
  cloud:
    nacos:
      config:
        server-addr: localhost:8848
        group: DEFAULT_GROUP
        file-extension: yml
        refresh-enabled: true
        prefix: nacos-test

为什么要新建bootstrap.yml配置文件,而不是直接在原来的application.yml中新增配置呢?是因为要实现nacos配置中心里面的配置要优先于系统配置文件中的配置,假如两个地方同时配置了,会优先取nacos的配置

配置说明:

  • spring.application.name 配置应用的名称,用于获取配置
  • spring.cloud.nacos.config.server-addr 配置nacos服务的地址
  • spring.cloud.nacos.config.group 配置分组
  • spring.cloud.nacos.config.file-extension 配置文件后缀,用于拼接配置配置文件名称
  • spring.cloud.nacos.config.refresh-enabled 配置自动刷新
  • spring.cloud.nacos.config.prefix 配置文件的前缀

启动项目,访问 http://localhost:8080/test

返回信息

url:nacos------https://openapidev.xinchengyue.com
appId:nacos------2020092275789623479853728
privateKeyIsv:nacos------MIIEvgIBADANBgqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCe7DUtSpPMpejhC6vg5HR6Xl15A3QwOueu

说明已经读到nacos中的配置了,而且本地配置文件和nacos中同时配置的,取的是nacos中的配置

四、配置自动刷新

在配置的类增加@RefreshScope就可以实现自动刷新配置,当nacos中的配置修改后,项目无需重启就可以自动生效,这个在实际生产环境中是很有用的,有时候你需要修改线上的配置,如果没有配置中心,你需要重启服务

1:引入依赖
<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-actuator</artifactId>
		</dependency>
2:配置类加入@RefreshScope注解
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RefreshScope//自动刷新配置
public class Test {

    @Value("${shortLink.url}")
    private String url;

    @Value("${shortLink.appId}")
    private String appId;

    @Value("${shortLink.privateKeyIsv}")
    private String privateKeyIsv;

    @RequestMapping("/test")
    public String test(){
        return "url:" + url + "</br>appId:" + appId + "</br>privateKeyIsv:" + privateKeyIsv;
    }
}