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项目,刷新刚刚访问的接口,可以看到我们刚刚添加的配置文件也能获取到,非常方便,数据也是会实时更新的

相关推荐
listhi52011 小时前
Docker中授权普通用户使用docker命令以及解决无权限访问/var/run/docker.sock错误
spring cloud·云原生·eureka
我命由我1234517 小时前
Spring Cloud - Spring Cloud 负载均衡(Ribbon 负载均衡概述、Ribbon 使用)
java·后端·spring·spring cloud·ribbon·java-ee·负载均衡
纳就这样吧2 天前
Spring Cloud中@EnableDiscoveryClient注解详解
spring boot·后端·spring cloud
thginWalker2 天前
SpringCloud微服务项目实战——系统实现篇
spring cloud
云创智城-yuncitys2 天前
SpringCloud 架构在智慧交通路侧停车系统中的实践:从技术落地到城市级服务升级
spring·spring cloud·架构·智慧城市·停车系统·充电系统源码
番茄Salad2 天前
Spring Boot临时解决循环依赖注入问题
java·spring boot·spring cloud
kkkkk0211062 天前
微服务学习笔记(黑马商城)
java·spring boot·spring·spring cloud·sentinel·mybatis·java-rabbitmq
洛克大航海3 天前
5-SpringCloud-服务链路追踪 Micrometer Tracing
后端·spring·spring cloud·zipkin·micrometer
我命由我123453 天前
Spring Cloud - Spring Cloud 微服务概述 (微服务的产生与特点、微服务的优缺点、微服务设计原则、微服务架构的核心组件)
java·运维·spring·spring cloud·微服务·架构·java-ee
我命由我123453 天前
Spring Cloud - Spring Cloud 注册中心与服务提供者(Spring Cloud Eureka 概述、微服务快速入门、微服务应用实例)
java·spring boot·spring·spring cloud·微服务·eureka·java-ee