Nacos服务注册和配置中心(Config,Eureka,Bus)2

Nacos数据模型

Nacos领域模型,Namespace命名空间、Group分组、集群这些都是为了进行归类管理,把服务和配置文件进行归类,归类之后就可以实现一定的效果,比如隔离。对于服务来说,不同命名空间中的服务不能够互相访问调用

Namespace:命名空间,对不同的环境进行隔离,比如隔离开发环境、测试环境和生产环境。

Group:分组,将若干个服务或者若干个配置集归为一组,通常习惯一个系统归为一个组。

Service:某一个服务,比如商品微服务。

DataId:配置集或者可以认为是一个配置文件。

Namespace + Group + Service,如同Maven中的GAV坐标,GAV坐标是为了锁定Jar,而这里是为了锁定服务。

Namespace + Group + DataId,如同Maven中的GAV坐标,GAV坐标是为了锁定Jar,而这里是为了锁定配置文件

Namespace 代表不同的环境,如开发dev、测试test、生产环境prod

Group 代表某项目,比如圆心云项目

Service 某个项目中具体xxx服务

DataId 某个项目中具体的xxx配置文件

Nacos配置中心

1.创建命名空间

2.创建配置文件 写完后点击下面的发布然后返回既可,点击详情就可以看到我们刚刚配置的信息

3.在page项目中导入配置所需的依赖

复制代码
<!-- 引入alibaba-nacos-config依赖,可以从Nacos配置中心获得配置信息 -->
    <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
    </dependency>

4.在page项目中添加配置信息,prefix默认为该项目的注册名称,可以省略,在创建文件的时候用服务名,并将该yml的文件名改为bootstrap(优先级更高),不然无法提前获取配置文件

复制代码
spring:
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
      config:
        server-addr: 127.0.0.1:8848
        file-extension: yaml
#        prefix: aaa

5.新建配置类

复制代码
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;

@RefreshScope//nacos自动刷新配置文件数据给客户端
@RestController
@RequestMapping("config")
public class NacosConfigController {
    @Value("${leq.username}")
    private String name;

    @RequestMapping("rote")
    public String roteString(){
        return name;
    }

}

6.重启该项目,访问rote接口

复制代码
http://localhost:9100/config/rote

可以看到我们刚刚写的信息,然后将信息更改在次刷新,就可以看到我获取到的配置文件会实时刷新,比config的配置要简便许多,而且功能更强大

点击发布后,选择确认发布

7.配置多个配置文件,创建一个test1.yaml和test2.taml的配置文件,并查看数据

8.编写page中的配置文件,添加test1和test2 ,并在配置类中添加信息

java 复制代码
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;

@RefreshScope//nacos自动刷新配置文件数据给客户端
@RestController
@RequestMapping("config")
public class NacosConfigController {
    @Value("${leq.username}")
   private String name;
    @Value("${leq.hello}")
    private String aaa;
    @Value("${leq.password}")
    private String bbb;
    @RequestMapping("rote")
    public String roteString(){
        return name+",aaa:"+aaa+",bbb:"+bbb;
    }

}

9.重启page项目,刷新刚刚访问的接口,可以看到我们刚刚添加的配置文件也能获取到,非常方便,数据也是会实时更新的

相关推荐
麦兜*1 小时前
Spring Boot启动优化7板斧(延迟初始化、组件扫描精准打击、JVM参数调优):砍掉70%启动时间的魔鬼实践
java·jvm·spring boot·后端·spring·spring cloud·系统架构
白仑色2 天前
Spring Cloud 微服务(统一网关设计)
spring cloud·微服务·服务治理·统一配置管理·分布式配置中心
述雾学java2 天前
Spring Cloud 服务追踪实战:使用 Zipkin 构建分布式链路追踪
分布式·spring·spring cloud·zipkin
被困者11 天前
Linux部署Sonic前后端(详细版)(腾讯云)
spring cloud·云原生·eureka
Hellyc11 天前
springcloud/springmvc协调作用传递验证信息
后端·spring·spring cloud
Ken_111512 天前
SpringCloud系列(32)--使用Hystrix进行全局服务降级
spring cloud·hystrix
Ken_111512 天前
SpringCloud系列(33)--使用Hystrix进行通配服务降级
spring cloud·hystrix
微信公众号:AI创造财富12 天前
Docker 安装 ModelScope(推荐流程)
spring cloud·docker·eureka
述雾学java12 天前
Spring Cloud 服务调用详解:Ribbon 负载均衡与 Feign 声明式接口调用
spring cloud·ribbon·负载均衡
诗酒当趁年华12 天前
nacos热更新引起tcp激增导致服务不可用
java·tcp/ip·spring cloud