首页 > 其他 > 详细

nacos---作为和服务配置中心

时间:2021-03-29 17:59:37      阅读:183      评论:0      收藏:0      [点我收藏+]

Nacos作为服务配置中心演示

Nacos作为配置中心-基础配置cloudalibaba-config-nacos-client3377

pom.xml

 <!--nacos-config-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>

yml

yml文件有2个。
技术分享图片

bootstrap.yml

# nacos配置
server:
  port: 3377

spring:
  application:
    name: nacos-config-client
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 #Nacos服务注册中心地址
      config:
        server-addr: localhost:8848 #Nacos作为配置中心地址
        file-extension: yaml #指定yaml格式的配置
        #group: DEV_GROUP
        group: TEST_GROUP
        #namespace: 7d8f0f5a-6a53-4785-9686-dd460158e5d4


# ${spring.application.name}-${spring.profile.active}.${spring.cloud.nacos.config.file-extension}
# nacos-config-client-dev.yaml

# nacos-config-client-test.yaml   ----> config.info

application.yml

去nacos中心拉取那个配置文件。

spring:
  profiles:
    #active: dev # 表示开发环境
    #active: test # 表示测试环境
    active: info

主启动类

package com.czf.springcloud;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

@SpringBootApplication
@EnableDiscoveryClient
public class NacosConfigClientApplication3377 {
    public static void main(String[] args) {
        SpringApplication.run(NacosConfigClientApplication3377.class,args);
    }
}

controller

package com.czf.springcloud.controller;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @auther zzyy
 * @create 2020-02-23 17:02
 */
@RestController
@RefreshScope //支持Nacos的动态刷新功能。
public class ConfigClientController
{
    @Value("${config.info}")
    private String configInfo;

    @GetMapping("/config/info")
    public String getConfigInfo() {
        return configInfo;
    }
}

在Nacos中添加配置信息

配置公式

# ${spring.application.name}-${spring.profile.active}.${spring.cloud.nacos.config.file-extension}
# nacos-config-client-dev.yaml

技术分享图片
技术分享图片
技术分享图片

测试

调用接口查看配置信息http://localhost:3377/config/info
技术分享图片
技术分享图片
技术分享图片
自带动态刷新:修改下Nacos中的yaml配置文件,再次调用查看配置的接口,就会发现配置已经刷新

Nacos作为配置中心-分类配置

技术分享图片

Nacos的图形化管理界面

配置管理:
技术分享图片
命名空间:
技术分享图片
Namespace+group+data ID三者关系?为什么这么设计?
技术分享图片
技术分享图片

三种方案加载配置

DataID方案

指定spring.profile.active和配置文件的DataID来使不同环境下读取不同的配置,默认空间+默认分组+新建dev和test两个DataID
新建dev配置DataID:
技术分享图片
新建test配置DataID:
技术分享图片
通过spring.profile.acvice属性就能进行多环境下配置文件的读取
技术分享图片

Group方案

通过Group实现环境区分,新建Group

技术分享图片

在nacos图形界面控制台上新建配置文件DataID

技术分享图片
bootstrap+application
技术分享图片

Namespace方案

新建dev/test的Namespace
技术分享图片
回到服务管理-服务列表查看
技术分享图片
按照域名配置填写
技术分享图片
技术分享图片

nacos---作为和服务配置中心

原文:https://www.cnblogs.com/hello-czf/p/14592636.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!