【微服务】 Nacos的入门级使用 后端程序猿必经之路

本文介绍了Nacos作为微服务注册中心的基础概念,服务注册与发现的过程,并通过实例演示其在服务发现中的优势。步骤包括下载安装、服务注册与消费,以及总结Nacos在现代应用架构中的角色。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Nacos是什么

先看看官方对Nacos的定义

Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您实现动态服务发现、服务配置管理、服务及流量管理。
Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构(例如微服务范式、云原生范式)的服务基础设施。

如果你是刚入门并且能够很透彻的读懂这段话,我只能说“铁子,你真是个天才”
在这里插入图片描述

但如果和我一样,看完这个和没看是一样的,就和听四级听力一样无语的话,咱们继续往下看。
撇开官方文档,其实按我现在的理解,nacos就是一个微服务注册中心,那么什么是微服务注册中心呢,其实服务注册中心主要的提供的功能就是服务注册与发现。那么这个服务注册与发现是什么呢?

服务注册

不来官方的那一套了,其实就是一个微服务在启动之后,注册到注册中心(这里以Nacos为例),注册之后现在注册中心就知道这一个微服务的存在。

服务发现

服务发现的作用就是当客户端进行调用服务时,可以通过注册中心帮你找到这个服务

详细分析

那么这两个功能有什么联系吗,现在设想一下,一个祖传项目—图书管理系统(不知道大家的第一个开发项目是不是这个),该系统中有书籍模块,用户模块,还可以划分的更细,这里以这两个模块为例,那么我们可以将书籍模块独立为一个微服务,将用户模块独立成一个微服务,将两个微服务注册到同一个注册中心(Nacos),这时服务中心已经知道这两个微服务的存在,这就是所谓的服务注册

接下来我们以一个例子来说明服务发现的作用,以还书为例,用户要进行还书操作,首先他个人信息存储的借阅书籍量肯定是要减少,这个没什么,直接调用用户服务中的接口就可以,但就是难在怎么修改被借阅书籍的借阅状态,这时候用户服务中是没有这个接口的,所以需要调用书籍服务的接口,那么怎么调用书籍服务的接口呢,可以使用传统的http响应方式调用,这个绝对是ok的,但是假如此时书籍服务的的ip或则端口突然变化,就需要我们一个个去修改,如果项目很大的话这无疑是一个巨大的工作量,而且及其无聊的一个工作。这时候就凸显服务发现的作用了。
在这里插入图片描述
我们把找书籍服务的ip和端口的工作交给Nacos去处理,调用该服务时只要将书籍服务在Nacos中注册的name(这个是唯一的,类似于数据库中的主键)交给Nacos,就可以通过Nacos调用书籍服务,这个功能就叫做服务发现,这样书籍的ip和端口号怎么变化,我们都不需要做任何的修改,避免上面所说的这个问题。

下面是我理解的Nacos的图解
在这里插入图片描述

这里的服务之间的调用可以认为是以Naocs作为一个中介,帮忙寻找服务。

这里补充两个概念 消费者生产者,在微服务这里,生产者就是提供接口的服务,而消费者就是就是调用其他服务的接口的服务,在刚刚讲到的例子中,用户服务就是消费者,而书籍服务就是生产者。

Nacos的下载和安装

来到github下载,点击进入
在这里插入图片描述
来到这个界面,然后进入README.md
在这里插入图片描述
点击latest stable release.来到这个界面,点击这个下载就可以
在这里插入图片描述
将下载下的压缩包解压,来到bin目录
在这里插入图片描述
运行startup.cmd就是运行Nacos,出现下图界面就是运行成功了
在这里插入图片描述
复制红色箭头指向的地址到浏览器中就可以进入nacos的管理中心了。
在这里插入图片描述

总结

最近把之前学习的东西在整理一下,以上只是我个人对Nacos的理解,欢迎各位大佬指教
在这里插入图片描述

### Java微服务Nacos集成指南 #### 一、Nacos简介及其重要性 Nacos作为阿里巴巴开源的服务发现与配置管理基础设施,旨在帮助开发者更轻松地构建云原生应用。通过提供统一的命名空间和服务治理能力,Nacos能够有效简化分布式系统的开发流程并提升其稳定性[^1]。 #### 二、Nacos配置管理详解 对于采用Java技术栈构建的应用程序而言,利用Nacos实现集中式的配置管理是一项非常有价值的功能。这不仅有助于减少重复劳动,还能确保各个环境中的一致性和安全性。以下是基于Spring Boot框架的具体实施方法: - **创建Spring Boot项目** 为了使应用程序具备访问Nacos的能力,在新建工程时需引入相应的依赖库。通常情况下,只需添加`spring-cloud-starter-alibaba-nacos-config`即可完成基本设置[^4]。 ```xml <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency> ``` - **定义外部化属性文件** 接下来应该准备一份名为`bootstrap.yml`(或`.properties`)的资源文件来指定连接至目标Nacos服务器所需的信息,比如地址、用户名密码等参数[^2]。 ```yaml spring: application: name: demo-service cloud: nacos: config: server-addr: localhost:8848 file-extension: yaml ``` - **注入配置项** 借助于Spring Framework所提供的强大功能集,可以直接在代码内部声明变量并通过自动装配机制获取来自远程存储的数据源。这里列举两种常用方式供参考者选用:一是运用`@Value`标签;二是结合自定义类结构配合`@ConfigurationProperties`注解共同作用。 ```java @RestController public class HelloController { @Value("${example.message}") private String message; // 或者使用@ConfigurationProperties绑定整个对象 } ``` - **支持热加载特性** 值得一提的是,当涉及到频繁变动的关键字表单时,建议开启监听器以便即时响应任何潜在的变化事件。如此这般便能保证本地副本始终处于最新状态而无需重启进程就能生效新版本设定值。 ```yaml management: endpoints: web: exposure: include: refresh ``` #### 三、服务注册与发现原理说明 除了上述提到过的静态资源配置外,动态感知其他成员节点的存在与否同样是至关重要的环节之一。得益于内置的支持插件,只要遵循既定模式编写业务逻辑部分就可无缝对接官方API接口从而达成预期效果。 - **初始化客户端实例** 首先得确认已经成功安装好运行环境并且按照文档指示完成了必要的准备工作之后再继续后续步骤。一般来讲,只需要简单修改几处地方就可以让现有架构兼容新的组件了[^3]。 ```xml <!-- pom.xml --> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> ``` - **标注主类入口** 紧接着要在启动引导阶段加入额外指令以激活该模块的核心功能——即告诉容器当前角色身份以及期望与其他参与者建立联系的方式。 ```java @SpringBootApplication @EnableDiscoveryClient public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` - **测试连通状况** 最后一步则是验证一切是否正常运作。可以通过浏览器或其他工具向暴露出来的HTTP API发送请求来进行初步诊断。如果返回的结果符合预期,则证明整个链路畅通无阻。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小王不头秃

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值