SpringCloud微服务--Nacos Discovery--服务治理

1 服务治理介绍

先来思考一个问题

通过上一篇的操作,我们已经可以实现微服务之间的调用。但是我们把服务提供者的网络地址

ip,端口)等硬编码到了代码中,这种做法存在许多问题:

  1. 一旦服务提供者地址变化,就需要手工修改代码
  2. 一旦是多个服务提供者,无法实现负载均衡功能
  3. 一旦服务变得越来越多,人工维护调用关系困难

那么应该怎么解决呢, 这时候就需要通过注册中心动态的实现服务治理

什么是服务治理

服务治理是微服务架构中最核心最基本的模块。用于实现各个微服务的自动化注册与发现

服务注册:在服务治理框架中,都会构建一个注册中心,每个服务单元向注册中心登记自己提供服

务的详细信息。并在注册中心形成一张服务的清单,服务注册中心需要以心跳30s  90s的方式去监测清单中 的服务是否可用,如果不可用,需要在服务清单中剔除不可用的服务。

服务发现:服务调用方向服务注册中心咨询服务,并获取所有服务的实例清单,实现对具体服务实

例的访问。

通过上面的调用图会发现,除了微服务,还有一个组件是服务注册中心,它是微服务架构非常重要

的一个组件,在微服务架构里主要起到了协调者的一个作用。注册中心一般包含如下几个功能:

1. 服务发现:

服务注册:保存服务提供者和服务调用者的信息

服务订阅:服务调用者订阅服务提供者的信息,注册中心向订阅者推送提供者的信息

2. 服务配置:

配置订阅:服务提

### Spring Cloud Alibaba Nacos DiscoveryNacos 的对应关系 Spring Cloud Alibaba Nacos Discovery 是用于简化微服务架构下服务发现和服务治理的组件之一。通过集成阿里巴巴开源的服务发现工具 Nacos,开发者可以轻松实现服务注册、发现以及配置管理等功能。 #### 关键概念解释 - **Nacos**: 动态服务发现、配置管理和服务中心。它帮助构建云原生应用生态,提供易用的企业级微服务平台解决方案。 - **`spring-cloud-starter-alibaba-nacos-discovery`**: 这是一个 starter 库,旨在让基于 Spring Boot/Spring Cloud 构建的应用能够快速接入并利用 Nacos 提供的功能[^1]。 #### 配置方式 为了使应用程序能正确连接到 Nacos 并完成必要的初始化工作,在项目的 `pom.xml` 文件中需加入如下依赖: ```xml <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <!-- 版本号取决于所使用的 Spring CloudSpring Boot 版本 --> </dependency> ``` 当引入上述依赖之后,框架会自动扫描并加载位于 `META-INF/spring.factories` 下指定的相关类(如 `NacosDiscoveryClientConfigServiceBootstrapConfiguration`),从而确保在应用启动期间执行相应的初始化逻辑[^3]。 #### 使用方法 一旦完成了基本设置,则无需额外编写代码来显式调用 API 或者手动处理服务注册流程;只需正常开发业务功能即可。具体来说: - 如果项目已经标注了 `@EnableDiscoveryClient` 注解,则该实例会被识别为可被其他服务发现的目标,并按照默认规则向 Nacos 注册自己; - 反之亦然,任何希望查找特定名称下的可用实例列表的操作都可以借助内置客户端接口简单几行代码搞定。 此外,对于某些特殊需求场景——比如自定义元数据上传或是调整健康状态检查机制等高级特性支持——可以通过扩展点来自由定制行为模式而不必担心破坏原有体系结构稳定性[^2]。 #### 示例代码片段展示 下面给出一段简单的 Java 代码示例,展示了如何在一个标准的 Spring Boot 工程里启用对 Nacos 的支持: ```java import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient; // 开启服务发现能力 @EnableDiscoveryClient @SpringBootApplication public class MyApplication { public static void main(String[] args) { SpringApplication.run(MyApplication.class, args); } } ``` 此段程序将会尝试联系本地运行着的一个 Nacos Server 实例来进行自我介绍(即注册)。如果一切顺利的话,那么接下来就可以像平常一样与其他已知节点交互啦!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Naaaaa.a

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

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

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

打赏作者

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

抵扣说明:

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

余额充值