百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

阿里P8大佬总结的Nacos入门笔记,从安装到进阶小白也能轻松学会

liuian 2025-01-15 15:15 44 浏览

前言

Nacos /nɑ:k??s/ 是 Dynamic Naming and Configuration Service的首字母简称,一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。

Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。

Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施。

在这个介绍中,可以看出Nacos至少有三个核心功能:

1. 动态服务发现

2. 配置管理

3. 服务管理

后续会分别来介绍这三个功能是怎么回事

下载和解压

教程制作时,Nacos的最新发?版为2.1.1 (Aug 8th, 2022)(本教程就是基于这个版本),官?当前推荐的稳定版本为2.0.3。

查看最新Nacos发?版:https://github.com/alibaba/nacos/releases

并且可以在此??上下载安装包:

下载完了之后进?解压,解压之后的?录为:

1. bin?录下是启动和停?的脚本

2. conf?录下是Nacos的配置?件

3. target?录下是Nacos的jar包(启动脚本中其实就是运?的这个jar包,停?脚步中是直接kill到进程)

启动

解压完之后就可以启动Nacos了,Nacos?持单机和集群,默认是以集群模式启动,通过添加-mstandalone就会以单机模式启动。

Linux/Unix/Mac

启动命令(standalone代表着单机模式运?,?集群模式):

sh startup.sh -m standalone

如果您使?的是ubuntu系统,或者运?脚本报错提示[[符号找不到,可尝试如下运?:

bash startup.sh -m standalone

Windows

启动命令(standalone代表着单机模式运?,?集群模式):

startup.cmd -m standalone

可以发现,默认情况下Nacos占?了8848端?。

我们可以访问http://localhost:8848/nacos,来访问Nacos:

默认的?户名和密码为:nacos/nacos

这个??相当于nacos的管理台,有:

1. 配置管理

2. 服务管理

3. 权限控制

4. 命名空间

5. 集群管理

配置管理

配置,其实就是?个key:value,?如

并且我们通常会把这些配置写在application.properties或application.yml?件中,当时通过这种?式?定配置发?了改变就需要重启应?,并且通过这种?式配置的配置项仅限于当前应?,?不能做到多个应?共享。

那么nacos的配置管理功能就是来解决这些问题的,我们可以直接通过nacos管理台来新增配置,并且这些配置能够被多个应?给使?到。

新建配置

新建配置时可以指定:

1. Data ID:相当于?个配置?件,?如相当于application.properties,或者application-dev.properties,不过要注意的是,我们在某个项?中使?application.properties?件中,那个application表示的就是当前应?,那我们在nacos进?配置时,就要尽可能的取?些有含义的DataID,?如user.properties(表示?户应?的配置),order.properties(表示订单应?的配置),common.properties(表示多个应?共享的配置)。

2. Group:在nacos中,?个Data ID,也就是?个或多个配置?件可以归类到同?个Group中,Group的作?就是?来区分Data ID相同的情况,不同的应?或中间件使?了相同的Data ID时就可以通过Group来进?区分,默认为DEFAULT_GROUP

3. 配置内容:写具体的配置项,可以?properties的格式,也可以?yaml的格式

?如:

拉取配置

在nacos中新建完配置后,那作为?个SpringBoot应?我们如何来获取配置呢?

Java SDK

?先,我们可以直接使?Nacos提供的Java SDK来获取配置。

?先在项?中,添加如下依赖:

<dependency>
<groupId>com.alibaba.nacos</groupId>
<artifactId>nacos-client</artifactId>
<version>2.1.1</version>
</dependency>

然后可以使?如下代码来获取nacos中的配置:

try {
String serverAddr = "localhost:8848";
String dataId = "user.properties";
String group = "DEFAULT_GROUP";
Properties properties = new Properties();
properties.put("serverAddr", serverAddr);
ConfigService configService = NacosFactory.createConfigService(propert
ies);
String content = configService.getConfig(dataId, group, 5000);
System.out.println(content); } catch (NacosException e) {
// TODO Auto-generated catch block
e.printStackTrace(); }

1. serverAddr:nacos的地址

2. dataId:想要获取的配置?件的名字

3. group:分组

在Java SDK中,除开有获取配置的API,同时也提供了新增、删除、监听配置的API。

我们可以通过如下代码来监听配置的变化:

try {
String serverAddr = "localhost:8848";
String dataId = "user.properties";
String group = "DEFAULT_GROUP";
Properties properties = new Properties();
properties.put("serverAddr", serverAddr);
ConfigService configService = NacosFactory.createConfigService(propert
ies);
String content = configService.getConfig(dataId, group, 5000);
System.out.println(content);
configService.addListener(dataId, group, new Listener() {
public void receiveConfigInfo(String configInfo) {
System.out.println("recieve1:" + configInfo); }
public Executor getExecutor() {
return null; } });
// 测试让主线程不退出,因为订阅配置是守护线程,主线程退出守护线程就会退出。 正式代 码中?需下?代码
while (true) {
try {
Thread.sleep(1000); } catch (InterruptedException e) { e.printStackTrace(); } } } catch (NacosException e) {
// TODO Auto-generated catch block
e.printStackTrace(); }

剩余API,?家可以直接参考官?:https://nacos.io/zh-cn/docs/sdk.html

Spring在真正开发时,我们不太会通过Java SDK的?式来拉取nacos中的配置,那Nacos有没有针对Spring提供?些?较好?的注解或API呢?

当然是有的

增加?下依赖(不再需要nacos-client依赖了)

<dependency>
 <groupId>com.alibaba.nacos</groupId>
 <artifactId>nacos-spring-context</artifactId>
 <version>1.1.1</version> </dependency>

我们可以按以下?式来配置Spring容器:

@Configuration
@EnableNacosConfig(globalProperties = @NacosProperties(serverAddr = "127.0.
0.1:8848")) @NacosPropertySource(dataId = "user.properties", autoRefreshed = true) @ComponentScan("com.zhouyu")
public class AppConfig { }

很明显,通过@EnableNacosConfig注解定义了nacos的地址,通过@NacosPropertySource表示想要拉取的dataId,并且设置?动刷新(也就是配置发?了改变则会?动?效)。

那如何使?某?个具体的配置项呢:

@Component
public class UserService {
 @NacosValue("${spring.datasource.username}")
 private String username;
 public void test(){
 System.out.println(username);
 } }

可以通过@NacosValue来使?某?具体的配置项,那@Value?不?呢?也是可以的。

之所以可以,原因是@EnableNacosConfig注解会负责把指定的dataId的配置项拉取到应?,并封装为PropertySource对象添加到Environment对象中,所以@Value也能读取到相应的配置项。

SpringBoot

如果我们使?SpringBoot,那则可以?Spring更加简单。

首先引入依赖:

<dependency>
 <groupId>com.alibaba.boot</groupId>
 <artifactId>nacos-config-spring-boot-starter</artifactId>
 <version>0.2.12</version> </dependency>

然后在application.properties中配置nacos的地址:

nacos.config.server-addr=127.0.0.1:8848

然后:

@SpringBootApplication
@NacosPropertySource(dataId = "user.properties", autoRefreshed = true)
public class UserApplication {
 public static void main(String[] args) {
 ConfigurableApplicationContext applicationContext = SpringApplicat
ion.run(UserApplication.class, args);
 UserService userService = applicationContext.getBean(UserService.c
lass);
 userService.test();
 } }

依旧使?@NacosPropertySource来指定要拉取的配置dataId即可,就可以使?@Value或@NacosValue来获取某个具体的配置项了。

那有同学可能会想到,我们可不可以直接在application.properties?件中来配置dataid呢?确实可以:

nacos.config.server-addr=127.0.0.1:8848
nacos.config.data-id=user.properties
nacos.config.bootstrap.enable=true

不过要注意,?定得把nacos.config.bootstrap.enable设置为true,不然是不?的。

SpringCloud

如果我们是?SpringCloud,那将?SpringBoot更加简单。

总结

本期分享到这就先告一段落了,有对Spring Cloud的用法感兴趣的可以关注我+转发 私信 【292】获取今天这份Nacos的入门学习笔记哦,希望可以对大家的知识认识度有所提升和帮助!

相关推荐

怎样解除自动关机模式(怎样解除自动开关机)

1、打开手机主界面,找到系统自带的“时钟”应用,点击打开它。2、点击进入时钟后,点击右下角的“计时器”。3、进入到计时器后,点击“在计时结束启用雷达”这个选项。4、然后在这里,下拉到最下面,勾选“停...

电脑最高配置是什么配置2025

一,2023最新主流电脑装机配置如下。二,处理器可以使用十二代的i512400或者i512490f,内存16gb双通道,显卡rtx3060,主板可以使用b660m或者h610m。三,如果十三代酷睿...

MySQL慢查询优化:从explain到索引,DBA手把手教你提升10倍性能

数据库性能是应用系统的生命线,而慢查询就像隐藏在系统中的定时炸弹。某电商平台曾因一条未优化的SQL导致订单系统响应时间从200ms飙升至8秒,最终引发用户投诉和订单流失。今天我们就来系统学习MySQL...

一文读懂SQL五大操作类别(DDL/DML/DQL/DCL/TCL)的基础语法

在SQL中,DDL、DML、DQL、DCL、TCL是按操作类型划分的五大核心语言类别,缩写及简介如下:DDL(DataDefinitionLanguage,数据定义语言):用于定义和管理数据库结构...

闲来无事,学学Mysql增、删,改,查

Mysql增、删,改,查1“增”——添加数据1.1为表中所有字段添加数据1.1.1INSERT语句中指定所有字段名语法:INSERTINTO表名(字段名1,字段名2,…)VALUES(值1...

数据库:MySQL 高性能优化规范建议

数据库命令规范所有数据库对象名称必须使用小写字母并用下划线分割所有数据库对象名称禁止使用MySQL保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来)数据库对象的命名要能做到见名识意,...

下载工具合集_下载工具手机版

迅雷,在国内的下载地位还是很难撼动的,所需要用到的地方还挺多。缺点就是不开会员,软件会限速。EagleGet,全能下载管理器,支持HTTP(S)FTPMMSRTSP协议,也可以使用浏览器扩展检测...

mediamtx v1.15.2 更新详解:功能优化与问题修复

mediamtxv1.15.2已于2025年10月14日发布,本次更新在功能、性能优化以及问题修复方面带来了多项改进,同时也更新了部分依赖库并提升了安全性。以下为本次更新的详细内容:...

声学成像仪:泄露监测 “雷达” 方案开启精准防控

声学成像仪背景将声像图与阵列上配装的摄像实所拍的视频图像以透明的方式叠合在一起,就形成了可直观分析被测物产生状态。这种利用声学、电子学和信息处理等技术,变换成人眼可见的图像的技术可以帮助人们直观地认识...

最稳存储方案:两种方法将摄像头接入威联通Qu405,录像不再丢失

今年我家至少被4位邻居敲门,就是为了查监控!!!原因是小区内部监控很早就停止维护了,半夜老有小黄毛掰车门偷东西,还有闲的没事划车的,车主损失不小,我家很早就配备监控了,人来亮灯有一定威慑力,不过监控设...

离岗检测算法_离岗检查内容

一、研发背景如今社会许多岗位是严禁随意脱离岗位的,如塔台、保安室、监狱狱警监控室等等,因为此类行为可能会引起重大事故,而此类岗位监督管理又有一定困难,因此促生了智能视频识别系统的出现。二、产品概述及工...

消防安全通道占用检测报警系统_消防安全通道占用检测报警系统的作用

一、产品概述科缔欧消防安全通道占用检测报警系统,是创新行业智能监督管理方式、完善监管部门动态监控及预警预报体系的信息化手段,是实现平台远程监控由“人为监控”向“智能监控”转变的必要手段。产品致力于设...

外出住酒店、民宿如何使用手机检测隐藏的监控摄像头

最近,一个家庭在他们的民宿收到了一个大惊喜:客厅里有一个伪装成烟雾探测器的隐藏摄像头,监视着他们的一举一动。隐藏摄像头的存在如果您住在酒店或民宿,隐藏摄像头不应再是您的担忧。对于民宿,房东应报告所有可...

基于Tilera众核平台的流媒体流量发生系统的设计

曾帅,高宗彬,赵国锋(重庆邮电大学通信与信息工程学院,重庆400065)摘要:设计了一种基于Tilera众核平台高强度的流媒体流量发生系统架构,其主要包括:系统界面管理模块、服务承载模块和流媒体...

使用ffmpeg将rtsp流转流实现h5端播放

1.主要实现rtsp转tcp协议视频流播放ffmpeg下载安装(公认业界视频处理大佬)a、官网地址:www.ffmpeg.org/b、gitHub:github.com/FFmpeg/FFmp…c、推...