【Spring实战】32 Spring Boot3 集成 Nacos 服务注册中心 并在 Gateway 网关中应用

本文主要是介绍【Spring实战】32 Spring Boot3 集成 Nacos 服务注册中心 并在 Gateway 网关中应用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 1. 定义
    • 2. 背景
    • 3. 功能和特性
    • 4. 下载安装
    • 5. 服务启动
    • 6. 使用示例
      • 1)服务提供者
      • 2)服务消费者
      • 3)测试
    • 7. 代码参考
    • 结语

1. 定义

Nacos 是 Dynamic Naming and Configuration Service 的首字母简称,一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。它提供了服务发现、动态配置管理和服务元数据等功能,是构建和管理云原生应用的关键组件之一。

2. 背景

随着微服务架构的普及,服务的规模迅速增加,传统的配置管理和服务发现方式逐渐显得力不从心。Nacos 应运而生,致力于解决微服务领域中的服务注册、发现和配置管理等问题,为我们提供了更加灵活、高效的解决方案。它源于阿里巴巴内部对微服务架构管理的需求,经过多年的发展和实践,逐渐演化成了一个功能强大、稳定可靠的开源项目。

3. 功能和特性

  • 服务发现

    提供了强大的服务发现功能,允许微服务注册和发现其他服务。通过 Nacos,服务可以在动态环境中进行注册、注销和发现,确保微服务架构的高可用性和弹性扩展

  • 动态配置管理

    支持动态配置管理,我们可以通过Nacos实时修改配置,而无需重启应用。这为应对不同环境、不同配置需求提供了极大的灵活性

  • 服务健康监测

    能够监测注册在其上的服务的健康状态,及时发现并处理故障,确保整个微服务体系的稳定运行

  • 元数据管理

    允许我们为服务添加自定义的元数据,便于更灵活、更智能地管理服务实例

  • 高可用和扩展性

    是一个高可用和可扩展的系统,支持构建多节点的集群,确保服务的可用性和性能

4. 下载安装

本文选择从官方的 GitHub 进行下载,选取了当前最新版本 2.2.1 ,网址如下:

https://github.com/alibaba/nacos/releases/tag/2.2.1

在这里插入图片描述

等待下载完成

在这里插入图片描述

将其解压到任意位置

在这里插入图片描述

5. 服务启动

根据官网进行修改配置文件

官网描述:

https://nacos.io/docs/v2/quickstart/quick-start/

在这里插入图片描述

因此本地修改 \nacos-server-2.2.1\nacos\conf\application.properties

在这里插入图片描述

然后进入 \nacos\bin 目录下,使用 CMD 执行下面命令来启动服务

startup.cmd -m standalone

在这里插入图片描述

直到看见了 Nacos started successfully in stand alone mode. 这就代表了 Nacos 服务启动成功了,并且端口号是 8848

访问服务,帐号和密码都是 nacos

http://localhost:8848/nacos

在这里插入图片描述

点击提交之后,就可以登录到 Nacos 啦

在这里插入图片描述

6. 使用示例

下面通过一个简单的示例演示如何使用 Nacos 进行服务注册中心和配置管理中心。

在这里插入图片描述

1)服务提供者

首先,我们创建一个简单的 Spring Boot 应用,然后将其注册到 Nacos 注册中心上

添加依赖

            <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>2022.0.0.0-RC1</version><type>pom</type><scope>import</scope></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-bootstrap</artifactId></dependency><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency>

bootstrap.yml 文件中添加服务名以及 Nacos 地址

spring:application:name: accountcloud:nacos:discovery:server-addr: 127.0.0.1:8848

application.yml

server:port: 9501servlet:context-path: /account

创建一个 REST 请求,用于一会测试使用

package com.cheney.koala.account.controller;import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class HelloController {@GetMapping("hello")public String hello() {return "Hello world";}
}

创建一个启动类 KoalaAccountApplication

package com.cheney.koala.account;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
public class KoalaAccountApplication {public static void main(String[] args) {SpringApplication.run(KoalaAccountApplication.class, args);}
}

启动服务之后,这样就可以将一个 Spring boot 应用注册上去了

在这里插入图片描述

在 Nacos 的控制台上,我们可以看到服务已经注册成功了,并且可以看到实例数和健康数等信息

2)服务消费者

首先,我们创建一个再去使用一下 Gateway 网关应用,然后也将其注册到 Nacos 注册中心上

添加依赖

        <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId></dependency><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-bootstrap</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-loadbalancer</artifactId></dependency>

bootstrap.yml

spring:application:name: gatewaycloud:nacos:discovery:server-addr: 127.0.0.1:8848

application.yml

server:port: 9500spring:cloud:gateway:routes:- id: accounturi: lb://accountpredicates:- Path=/account/**

注意,这里的 uri 和之前不一样了,这里使用的是在 Nacos 上注册的服务名,而不是具体的 IP+端口号

这样的好处是无需关心服务的 IP 是多少,端口是多少,只需知道服务名即可,就可以访问了

创建一个启动类 KoalaGatewayApplication

package com.cheney.koala.gateway;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
public class KoalaGatewayApplication {public static void main(String[] args) {SpringApplication.run(KoalaGatewayApplication.class, args);}
}

启动服务之后,这样就可以将我们的 gateway 应用注册上去了

在这里插入图片描述

3)测试

这里我们直接请求 Gateway 网关的 URL 进行测试

http://localhost:9500/account/hello

在这里插入图片描述

7. 代码参考

https://gitee.com/cheney09/koala-system

结语

通过这篇博客,我们初步认识了 Nacos 的定义、背景、起源、功能和特性,并通过简单示例演示了其在微服务中的应用。在接下来的学习过程中,你将更深入地了解 Nacos 的各项功能,并掌握其在构建可靠、高可用的微服务体系中的应用。

这篇关于【Spring实战】32 Spring Boot3 集成 Nacos 服务注册中心 并在 Gateway 网关中应用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/659490

相关文章

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

深度解析Spring Security 中的 SecurityFilterChain核心功能

《深度解析SpringSecurity中的SecurityFilterChain核心功能》SecurityFilterChain通过组件化配置、类型安全路径匹配、多链协同三大特性,重构了Spri... 目录Spring Security 中的SecurityFilterChain深度解析一、Security

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

Python标准库之数据压缩和存档的应用详解

《Python标准库之数据压缩和存档的应用详解》在数据处理与存储领域,压缩和存档是提升效率的关键技术,Python标准库提供了一套完整的工具链,下面小编就来和大家简单介绍一下吧... 目录一、核心模块架构与设计哲学二、关键模块深度解析1.tarfile:专业级归档工具2.zipfile:跨平台归档首选3.