Nacos配置管理简明教程 nacos 配置管理
yuyutoo 2024-10-12 01:39 2 浏览 0 评论
一、前言
在当前的项目开发中,经常会遇到业务变更的情况,比如:今天保留2为位小数,明天要保留4位小数、昨天刚说关闭某项检测,今天又说要打开。从配置式的角度来说,这些可以做成一个开关,需要时开启,不需要时就关闭。
常见的配置式,可以从数据库中、缓存中、文件中进行读取。我们目前适用的是yml配置的形式来进行管理,但是最近一些开关的频繁变动使得我们要积极寻求一个更加灵活和友好的解决方案。
二、Nacos配置管理
2.1、什么是Nacos配置管理
Nacos提供了动态管理配置服务,用户可以通过api调用和控制台操作进行实时服务应用配置的变更,让配置管理变得更加的灵活、高效、便捷。
2.2、配置管理的核心概念
信息来源于Nacos官网:https://nacos.io/zh-cn/docs/concepts.html
① 命名空间(namespace)
用于进行租户粒度的配置隔离。不同的命名空间下,可以存在相同的 Group 或 Data ID 的配置。Namespace 的常用场景之一是不同环境的配置的区分隔离,例如开发测试环境和生产环境的资源(如配置、服务)隔离等。
② 配置项(configuration item)
一个具体的可配置的参数与其值域,通常以 param-key=param-value 的形式存在。例如我们常配置系统的日志输出级别(logLevel=INFO|WARN|ERROR) 就是一个配置项。
③ 配置集(configuration set)
一组相关或者不相关的配置项的集合称为配置集。在系统中,一个配置文件通常就是一个配置集,包含了系统各个方面的配置。例如,一个配置集可能包含了数据源、线程池、日志级别等配置项。
④ 配置ID(data id)
Nacos 中的某个配置集的 ID。配置集 ID 是组织划分配置的维度之一。Data ID 通常用于组织划分系统的配置集。
一个系统或者应用可以包含多个配置集,每个配置集都可以被一个有意义的名称标识。Data ID 通常采用类 Java 包(如 com.taobao.tc.refund.log.level)的命名规则保证全局唯一性。此命名规则非强制。
⑤ 配置分组(group)
Nacos 中的一组配置集,是组织配置的维度之一。通过一个有意义的字符串(如 Buy 或 Trade )对配置集进行分组,从而区分 Data ID 相同的配置集。当您在 Nacos 上创建一个配置时,如果未填写配置分组的名称,则配置分组的名称默认采用DEFAULT_GROUP 。配置分组的常见场景:不同的应用或组件使用了相同的配置类型,如 database_url 配置和 MQ_topic 配置。
三、Nacos配置管理步骤(后端)
3.1、安装Nacos
可以参考我之前的文章:Nacos+Dubbo项目搭建简明教程
3.2、引入需要的Maven
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-spring-boot-starter</artifactId>
<version>2.7.7</version>
</dependency>
<dependency>
<groupId>org.apache.dubbo</groupId>
<artifactId>dubbo-registry-nacos</artifactId>
<version>2.7.7</version>
</dependency>
<dependency>
<groupId>com.alibaba.boot</groupId>
<artifactId>nacos-config-spring-boot-starter</artifactId>
<version>0.2.7</version>
</dependency>
3.3、启用配置服务
在项目的启动类中配置注解:NacosPropertySource 以启动配置服务
@NacosPropertySource(dataId = "guangmuhua_customer_web", autoRefreshed = true)
PS: 这里的dataId要后面我们控制台的配置一致,并设置自动更新
3.4、使用@NacosValue注解
不同于我们之前使用的@Value注解,这里我们使用@NacosValue
@NacosValue(value = "${useDeleted:false}", autoRefreshed = true)
private String useDeleted;
这里我们使用@NacosValue注解来引入userDeleted属性,并默认为false,为了更好的检测效果我们写一个测试类如下:
import com.alibaba.nacos.api.config.annotation.NacosValue;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RefreshScope
public class NacosConfigTest {
@NacosValue(value = "${useDeleted:}", autoRefreshed = true)
private String useDeleted;
@GetMapping("/getNacosConfig")
public String getNacosConfig() {
return String.valueOf(useDeleted);
}
}
四、Nacos控制台配置
4.1、新增一个配置项
控制台操作如下:
4.2、写入配置信息
控制台操作如下:
五、测试效果
5.1、程序默认效果
PS: 没有进行自定义配置时,默认为程序中的false
5.2、配置后的效果
PS: 通过Nacos控制台进行配置后,数据修改为我们定义的true
六、注意事项
① 在属性优先级上:yml文件总配置 > nacos控制台属性配置 > @NacosValue注解定义默认值
② 当yml文件中没有定义,且nacos没有属性配置时,@NacosValue注解或报错
③ 当属性配置不生效时,先检测maven依赖是否正确,如果还是出现问题就重启nacos服务
④ nacos属性配置可以通过api直接进行配置(一如前段时间的nacos通过api添加账户,然后登陆),做好安全处理
七、后记
这里只是简单记录下,Nacos配置管理的基础用法,当然也可以根据业务需要进行更复杂的namespace、groupId等参数的细化。
通过以上操作,我们就可以做到灵活、优雅的管理线上项目的一些开关操作。
更多精彩,请持续关注:guangmuhua.com
相关推荐
- jQuery VS AngularJS 你更钟爱哪个?
-
在这一次的Web开发教程中,我会尽力解答有关于jQuery和AngularJS的两个非常常见的问题,即jQuery和AngularJS之间的区别是什么?也就是说jQueryVSAngularJS?...
- Jquery实时校验,指定长度的「负小数」,小数位未满末尾补0
-
在可以输入【负小数】的输入框获取到焦点时,移除千位分隔符,在输入数据时,实时校验输入内容是否正确,失去焦点后,添加千位分隔符格式化数字。同时小数位未满时末尾补0。HTML代码...
- 如何在pbootCMS前台调用自定义表单?pbootCMS自定义调用代码示例
-
要在pbootCMS前台调用自定义表单,您需要在后台创建表单并为其添加字段,然后在前台模板文件中添加相关代码,如提交按钮和表单验证代码。您还可以自定义表单数据的存储位置、添加文件上传字段、日期选择器、...
- 编程技巧:Jquery实时验证,指定长度的「负小数」
-
为了保障【负小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【负小数】的方法。HTML代码<inputtype="text"class="forc...
- 一篇文章带你用jquery mobile设计颜色拾取器
-
【一、项目背景】现实生活中,我们经常会遇到配色的问题,这个时候去百度一下RGB表。而RGB表只提供相对于的颜色的RGB值而没有可以验证的模块。我们可以通过jquerymobile去设计颜色的拾取器...
- 编程技巧:Jquery实时验证,指定长度的「正小数」
-
为了保障【正小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【正小数】的方法。HTML做成方法<inputtype="text"class="fo...
- jquery.validate检查数组全部验证
-
问题:html中有多个name[],每个参数都要进行验证是否为空,这个时候直接用required:true话,不能全部验证,只要这个数组中有一个有值就可以通过的。解决方法使用addmethod...
- Vue进阶(幺叁肆):npm查看包版本信息
-
第一种方式npmviewjqueryversions这种方式可以查看npm服务器上所有的...
- layui中使用lay-verify进行条件校验
-
一、layui的校验很简单,主要有以下步骤:1.在form表单内加上class="layui-form"2.在提交按钮上加上lay-submit3.在想要校验的标签,加上lay-...
- jQuery是什么?如何使用? jquery是什么功能组件
-
jQuery于2006年1月由JohnResig在BarCampNYC首次发布。它目前由TimmyWilson领导,并由一组开发人员维护。jQuery是一个JavaScript库,它简化了客户...
- django框架的表单form的理解和用法-9
-
表单呈现...
- jquery对上传文件的检测判断 jquery实现文件上传
-
总体思路:在前端使用jquery对上传文件做部分初步的判断,验证通过的文件利用ajaxFileUpload上传到服务器端,并将文件的存储路径保存到数据库。<asp:FileUploadI...
- Nodejs之MEAN栈开发(四)-- form验证及图片上传
-
这一节增加推荐图书的提交和删除功能,来学习node的form提交以及node的图片上传功能。开始之前需要源码同学可以先在git上fork:https://github.com/stoneniqiu/R...
- 大数据开发基础之JAVA jquery 大数据java实战
-
上一篇我们讲解了JAVAscript的基础知识、特点及基本语法以及组成及基本用途,本期就给大家带来了JAVAweb的第二个知识点jquery,大数据开发基础之JAVAjquery,这是本篇文章的主要...
- 推荐四个开源的jQuery可视化表单设计器
-
jquery开源在线表单拖拉设计器formBuilder(推荐)jQueryformBuilder是一个开源的WEB在线html表单设计器,开发人员可以通过拖拉实现一个可视化的表单。支持表单常用控件...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)