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

springcloud-nacos简述

Spring Cloud alibaba: nacos服务注册中心,配置中心

服务注册中心

1.项目父工程添加springcloudalibaba依赖

<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>${spring-cloud-alibaba.version}</version><type>pom</type><scope>import</scope>
</dependency>

2.将想要暴露的服务对应的pom文件中添加如下依赖

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

3.工程相应yml文件配置

spring:application:name: content-api # 服务名称cloud:nacos:server-addr: 192.168.101.65:8848discovery:namespace: dev402  # 命名空间 要和nacos的相对应group: xuecheng-plus-project # 分组

配置完毕后启动content服务,nacos中观察。

配置中心

需要配置的服务中要引入nacos的config依赖

  <!--nacos配置中心需要加入的依赖--><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId></dependency>

Data Id 的组成(三部分)

第一部分:application.yaml中配置的应用名,即spring.application.name的值

第二部分:环境名,通过spring.profiles.active指定

第三部分:配置文件 的后缀,目前nacos支持properties、yaml等格式类型。

上面所说的三部分都是要在本地的yaml配置文件中配置的,正因为配置了这三部分服务启动的时候可以从nacos中获取到这个服务的配置的信息,即先去找content-api-dev.yaml这个配置文件。具体配置的优先级后面会说。

spring:application:name: content-servicecloud:nacos:server-addr: 192.168.101.65:8848discovery:namespace: dev402group: xuecheng-plus-projectconfig:namespace: dev402group: xuecheng-plus-projectfile-extension: yamlrefresh-enabled: true#profiles默认为devprofiles:active: dev

配置成功后可以看到控制台中打印NacosRestTemplate.java通过Post方式与nacos服务端交互读取配置信息。

 

 下面直接把完整的配置发出来自己,看一下。我全注释一下,简单东西简单说

server:servlet:context-path: /content # 服务请求时映射url前缀port: 6304 #端口号
#微服务配置
spring:application:name: content-api # 服务名Data Id 第一部分cloud:nacos:server-addr: 192.168.101.65:8848 # nacos地址,请确保服务可以正常访问discovery:   #服务注册的相关配置信息 namespace: dev402 # 在nacos页面中创建的命名空间group: xuecheng-plus-project # 服务所属分组config:   #配置文件相关信息namespace: dev402 # 命名空间group: xuecheng-plus-project # 服务所属分组file-extension: yaml # 程序应该使用 YAML 格式的文件作为配置文件refresh-enabled: trueextension-configs: # 直接引入其他配置文件需要配置extension-configs- data-id: content-service-${spring.profiles.active}.yamlgroup: xuecheng-plus-projectrefresh: trueshared-configs: # 公共配置用这个shared-configs:- data-id: swagger-${spring.profiles.active}.yamlgroup: xuecheng-plus-commonrefresh: true- data-id: logging-${spring.profiles.active}.yamlgroup: xuecheng-plus-commonrefresh: true
#  直接引用content-service-dev.yaml的数据库配置 但是理论上api层面不应包含数据库相关配置,引用也不行
#  datasource:
#    driver-class-name: com.mysql.cj.jdbc.Driver
#    url: jdbc:mysql://192.168.101.65:3306/gogs?serverTimezone=UTC&userUnicode=true&useSSL=false&
#    username: root
#    password: mysql#profiles默认为dev 环境名的Data Id 第二部分profiles:active: dev

 配置优先级

 项目启动首先加载bootstrap.yml,拿到nacos的请求地址与id获取到远程的nacos配置

其次加载本地的application.yml配置,并与nacos拉取到的配置合并

最后进行spring容器的创建、bean的加载......

配置文件的有限级:

项目应用名配置文件(data ID) > 扩展配置文件(extension-configs)  > 共享配置文件(shared-configs) > 本地配置文件(其他application.yml)。

配置本地优先

需求:有时候我们在测试程序时直接在本地加一个配置进行测试。

正常在idea的服务配置换个端口就可以但是由于受优先级影响,他会优先去nacos中查找相关服务配置,也就是说我们启动服务就会报错端口被占用。

解决办法:

#配置本地优先 
spring:cloud:config:override-none: true

 

导入配置

如果我们已经有了配置文件的zip包可以直接在nacos中进行配置的导入。

 

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

相关文章:

  • 【SpringSecurity】十二、集成JWT搭配Redis实现退出登录
  • Docker进入容器出现bash: vi: command not found
  • Linux_6_文件查找与打包压缩
  • JavaWeb_LeadNews_Day9-Redis实现用户行为
  • IntelliJ IDEA2021.3.1 使用 MybatisCodeHelperPro插件
  • el-date-picker 等 点击无反应不回显问题解决
  • Ansible学习笔记12
  • sqlmap中文文档
  • 【C++模拟实现】vector的模拟实现
  • go学习part21(3)redis连接池
  • 乐理-笔记
  • java八股文面试[数据库]——B树和B+树的区别
  • 2、Nginx 安装
  • 最适合 AI 的 Python Web 框架
  • 算法通关村第十八关——回溯
  • 使用kafka还在依赖Zookeeper,kraft模式了解下
  • 【100天精通Python】Day52:Python 数据分析_Numpy入门基础与数组操作
  • Day01-Java基础语法
  • 代码随想录二刷day06
  • 可扩展的Blender插件开发汇总
  • 2023_Spark_实验二:IDEA安装及配置
  • 小赢科技,寻找金融科技核心价
  • NAT与代理服务器
  • 24.排序,插入排序,交换排序
  • Navicat16安装教程
  • 【看表情包学Linux】初识文件描述符 | 虚拟文件系统 (VFS) 初探 | 系统传递标记位 | O_TRUNC | O_APPEND
  • ssm+vue“魅力”繁峙宣传网站源码和论文
  • Linux系统编程5(线程概念详解)
  • leetcode645. 错误的集合(java)
  • Pytest参数详解 — 基于命令行模式