当前位置: 首页 > news >正文

SpringCloud(H版alibaba)框架开发教程之nacos做配置中心——附源码(2)

上篇主要讲了使用eureka,zk,nacos当注册中心

这篇内容是nacos配置中心

代码改动部分mysql驱动更新到8.0,数据库版本升级到了8.0,nacos版本更新到了2.x

nacos2.x链接
链接:https://pan.baidu.com/s/11nObzgTjWisAfOplNuKP-Q?pwd=o93q
提取码:o93q
–来自百度网盘超级会员V7的分享

然后启动nacos,新建两个命名空间,它的作用是为了区分不同环境
在这里插入图片描述
再切换到配置列表,切换到dev的这个命名空间

在这里插入图片描述
点创建配置,创建一个配置文件,类型为yaml

在这里插入图片描述

他们的关系如下

在这里插入图片描述

Nacos默认的Namespace是public,Namespace主要用来实现隔离。

比方说我们现在有三个环境:开发、测试、生产环境,我们就可以创建三个Namespace,不同的Namespace之间是隔离的。

Group默认是DEFAULT_GROUP,Group可以把不同的微服务划分到同一个分组里面去

Service就是微服务:一个Service可以包含多个Cluster (集群),Nacos默认Cluster是DEFAULT,Cluster是对指定微服务的一个虚拟划分。

比方说为了容灾,将Service微服务分别部署在了杭州机房和广州机房,这时就可以给杭州机房的Service微服务起一个集群名称(HZ) ,给广州机房的Service微服务起一个集群名称(GZ),还可以尽量让同一个机房的微服务互相调用,以提升性能。
最后是Instance,就是微服务的实例。

在这里插入图片描述
然后我们启动一下这个服务,调用一下接口,可以看到,成功读取了配置

http://localhost:3377/config/info

在这里插入图片描述

简单使用的就说到这里

后面再说一下其他的

注:

1)不能使用原来的application.yml作为配置文件,而是新建一个bootstrap.yml作为配置文件;

2)在bootstrap和application数据项相同时,bootstrap中的配置不会被覆盖;

配置文件优先级(由高到低):

bootstrap.properties -> bootstrap.yml -> application.properties -> application.yml

在这里插入图片描述

配置动态刷新
在入门案例中,我们实现了配置的远程存放,但是此时如果修改了配置,我们的程序是无法读取到 的,因此,我们需要开启配置的动态刷新功能。

//只需要在需要动态读取配置的类上添加此注解就可以
@RefreshScope

在这里插入图片描述

后面再说一下配置共享

如果想在同一个微服务的不同环境之间实现配置共享,其实很简单。 只需要提取一个以spring.application.name 命名的配置文件,然后将其所有环境的公共配置放在里 面即可。

1 新建一个名为nacos-config-client.yamll配置,代表只要服务名是:nacos-config-client都能读到这个配置

如图
在这里插入图片描述

不同微服务中间共享配置

不同为服务之间实现配置共享的原理类似于文件引入,就是定义一个公共配置,然后在当前配置中引入。

在nacos中定义一个DataID为all-service.yaml的配置,用于所有微服务共享

在这里插入图片描述

在这里插入图片描述

# nacos配置
server:port: 3377spring:application:name: nacos-config-clientcloud:nacos:discovery:server-addr: localhost:8848 #Nacos服务注册中心地址config:server-addr: localhost:8848 #Nacos作为配置中心地址file-extension: yaml #指定yaml格式的配置group: NACOS_GROUPnamespace: dev#共享的配置
#        shared-dataids: all-service.yaml              # 配置要引入的配置
#        refreshable-dataids: all-service.yaml          # 配置要实现动态配置刷新的配置ext-config:- data-id: all-service.yamlgroup: NACOS_GROUPrefresh: true

在这里插入图片描述

http://www.lryc.cn/news/271101.html

相关文章:

  • 网络摄像头爆破实战
  • 亚信安慧AntDB数据并行加载工具的实现(二)
  • 【Java进阶篇】JDK新版本中的新特性都有哪些
  • 力扣labuladong一刷day49天迪杰斯特拉
  • MCS接口技术----定时/计数,中断
  • Java开发框架和中间件面试题(10)
  • C++ 具名要求-基本概念-指定该类型对象可以从右值构造
  • Python如何把类当做字典来访问及浅谈Python类命名空间
  • 简述Redis备份策略以及对应的实现机制
  • 【5G PHY】5G 物理层加速卡介绍
  • lftp学习笔记
  • idea 插件开发之 HelloWorld
  • 极速文件搜索工具Everything结合内网穿透实现远程搜索本地文件
  • 【PowerMockito:编写单元测试过程中采用when打桩失效的问题】
  • [蓝桥杯 2018省赛]回家路费
  • 学生管理系统(vue + springboot)
  • 算法(3)——二分查找
  • golang实现可中断的流式下载
  • SpringBoot 医药咨询系统
  • C语言转WebAssembly的全流程,及Web端调用测试
  • 前端--基础 目录文件夹和根目录 VScode打开目录文件夹
  • 传感器原理与应用复习--超声波、微波、红外及热电偶传感器
  • matlab概率论例子
  • Appium+python自动化(一)- 环境搭建—上(超详解)
  • 基于SpringBoot的精简博客系统
  • STM32的在线升级(IAP)实现方法:BOOT+APP原理详解
  • 【芯片DFX】Arm调试架构篇
  • ES应用_ES实战
  • Ubuntu上如何找到设备,打印串口日志
  • 本地映射测试环境域名,解决登录测试环境后,也可以使用本地域名访问,可以正常跑本地项目