【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 的各项功能,并掌握其在构建可靠、高可用的微服务体系中的应用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/439214.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

最后50个CC龙年红包封面,免费速领!还有更多......高中生也卷起Steam来了

微信视频号之前是送了我3张新年红包封面&#xff0c;一共是150个&#xff0c;但不太会操作浪费了100个&#xff0c;只能我自己用来送老铁了。 晓衡又做了一条 Cocos 小可爱 CC 封面红包&#xff0c;特别适合送女生或给小朋友们&#xff0c;点击视频领取&#xff01;还好微信又送…

防火墙知识普及详解,使用TOR Router把TOR作为默认网关,增加隐私/匿名性

防火墙知识普及详解,使用TOR Router把TOR作为默认网关,增加隐私/匿名性。 #################### 免责声明:工具本身并无好坏,希望大家以遵守《网络安全法》相关法律为前提来使用该工具,支持研究学习,切勿用于非法犯罪活动,对于恶意使用该工具造成的损失,和本人及开发者…

嵌入式学习 Day13

一. 指针总结 1.指针概念 a.指针 --- 地址 ---内存单元编号 b.指针 --- 数据类型 ---指针类型 不同语境: 定义一个指针 //指针类型的变量 打印某个变量的指针 //指针 --地址 2.指针变量的定义 基类型 * 变量名 a.基类型 …

Pytest中doctests的测试方法应用

在 Python 的测试生态中,Pytest 提供了多种灵活且强大的测试工具。其中,doctests 是一种独特而直观的测试方法,通过直接从文档注释中提取和执行测试用例,确保代码示例的正确性。本文将深入介绍 Pytest 中 doctests 的测试方法,包括基本用法和实际案例,以帮助你更好地利用…

python3.8 安装缺少ssl、_ctypes模块解决办法

问题 安装pyhton3.8安装默认不依赖ssl 运行Flask项目时报错&#xff1a; Traceback (most recent call last):File "/usr/local/python3/bin/flask", line 8, in <module>sys.exit(main())File "/usr/local/python3/lib/python3.8/site-packages/flask…

TensorFlow2实战-系列教程9:RNN文本分类1

&#x1f9e1;&#x1f49b;&#x1f49a;TensorFlow2实战-系列教程 总目录 有任何问题欢迎在下面留言 本篇文章的代码运行界面均在Jupyter Notebook中进行 本篇文章配套的代码资源已经上传 1、文本分类任务 1.1 文本分类 数据集构建&#xff1a;影评数据集进行情感分析&…

[C++历练之路]C++中的继承小学问

W...Y的主页 &#x1f60a; 代码仓库分享&#x1f495; &#x1f354;前言&#xff1a; C中&#xff0c;继承是一种面向对象编程的重要概念&#xff0c;它允许一个类&#xff08;子类/派生类&#xff09;从另一个类&#xff08;父类/基类&#xff09;继承属性和方法。继承是…

python统计分析——样本方差的分布

参考资料&#xff1a;用python动手学统计学 1、导入库 import numpy as np import pandas as pd import scipy as sp from scipy import statsfrom matplotlib import pyplot as plt import seaborn as sns 2、数据准备 建立一个平均数为4&#xff0c;标准差为0.8的正态分布…

ctfshow web72

下载源码&#xff1a; 开启环境&#xff1a; 本题设置了 open_basedir()&#xff0c;将php所能打开的文件限制在指定的目录树中&#xff0c;包括文件本身。 因为 ini_set() 也被限制了&#xff0c;所以 open_basedir() 不能用 ini_set() 重新设置绕过。 使用 php 伪协议 glob:…

前端框架---Vue2学习教程(上)

从HTML到现在一路跟过来的小伙伴们&#xff0c;坚持固然不容易&#xff0c;但我相信大家已经学到了不少&#xff0c;那么我们开始马不停蹄的进入前端的框架吧&#xff0c;下面讲的是Vue2&#xff0c;大家继续加油鸭&#xff01;&#xff01;&#xff01;&#xff01; Vue2 Vu…

Springboot使用数据库连接池druid

springboot框架中可以使用druid进行数据库连接池&#xff0c;下面介绍druid在springboot中使用和参数配置介绍。 数据库连接池&#xff08;Druid&#xff09;是一种用于管理数据库连接的机制&#xff0c;其工作原理和常见使用方法如下&#xff1a; 原理&#xff1a;数据库连接…

awk命令使用方法

简介 awk 是一种强大的文本处理工具&#xff0c;可以用于处理结构化的文本数据。它可以根据指定的模式和动作来筛选、处理和格式化文本。 下面是一些常见的 awk 命令使用方法。 详细介绍 基本语法&#xff1a; awk pattern { action } filename其中&#xff0c;pattern 是用…