当前位置: 首页 > article >正文

1. Nacos 全面解析与使用指南

一、什么是 Nacos

Nacos 是一个致力于帮助开发者更轻松构建云原生应用的动态服务发现、配置管理和服务管理平台

1.1 Nacos 功能

1.1.1 配置中心

配置中心是集中化管理配置的关键服务,主要作用显著:集中管理配置信息、动态更新配置、配置信息共享、配置信息安全、信息追溯。

1.1.2 注册中心

注册中心是微服务架构的核心组件,主要作用如下:服务注册、服务发现、服务健康检查、服务路由、服务监控、服务更新。

1.2 Nacos 优点

  • 简单易用、特性丰富、超高性能、高可用、超大容量。

二、Nacos 基本使用

2.1 Nacos 部署安装

2.1.1 部署方式

单机模式、集群模式、多集群模式

2.1.2 安装并启动

  1. 官网下载安装包

  2. 在mysql执行本地sql语句样例(nacos\conf\mysql-schema.sql)

  3. 修改配置,nacos后台数据存储到mysql(文件:nacos\conf\application.properties)

    spring.datasource.platform=mysql
    db.num=1
    db.url.0=jdbc:mysgl://localhost:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketT
    db.user=nacos devtest
    db.password=youdontknow
    
  4. 启动nacos

    startup.cmd -m standalone
    

2.2 配置中心使用 ★

Spring Boot 项目使用配置中心,实现步骤如下:

  • 添加配置中心依赖:在项目 pom.xml 文件中添加如下依赖:
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
  • 设置 Nacos 服务端信息:在项目配置文件(application.properties)中添加如下信息:
# Nacos认证信息
spring.cloud.nacos.config.username=nacos
spring.cloud.nacos.config.password=nacos
spring.cloud.nacos.config.contextPath=/nacos
# 设置配置中心服务端地址
spring.cloud.nacos.config.server-addr=localhost:8848
# Nacos 配置中心的namespace。需要注意,如果使用 public 的 namcespace ,请不要填写这个值,直接留空即可
# spring.cloud.nacos.config.namespace=
#spring.cloud.nacos.config.group=
spring.config.import=nacos:nacos-config-example
  • 在nacos上填写配置信息:
    在这里插入图片描述
    在这里插入图片描述

  • 读取配置文件:在 Controller 中使用 @Value 注解和 @RefreshScope 实现配置的读取和自动更新:

@RestController
@RefreshScope
public class TestController {
    @Value("${myconfig}")
    private String myconfig;
    @RequestMapping("/getconfig")
    public String getMyconfig() {
        return myconfig;
    }
}

2.3 注册中心使用 ★

注册中心有两个主要角色:

  • 服务提供者(生产者):对外提供服务的微服务应用,将自身服务地址注册到注册中心,供消费者发现和调用。

  • 服务消费者(消费者):调用其他微服务的应用程序,向注册中心订阅所需服务,并基于服务提供者注册信息发起远程调用。

2.3.1 生产者实现

生产者实现步骤如下:

  • 添加 nacos-discovery 框架支持:在项目 pom.xml 文件中添加如下依赖:
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
  • 配置 nacos 服务器端信息:在 application.yml 文件中添加如下配置:
spring:
  application:
    name: nacos-discovery-demo # Nacos 服务名(很重要,命名不用使用“_”)
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848
        username: nacos
        password: nacos
        ephemeral: false # 设置此服务为永久实例
#        group: TEST_GROUP
server:
  port: 0 # 动态端口
  • 编写调用接口:在 Controller 中编写业务接口:
@RestController
@RequestMapping("/user")
public class UserController {
    @Autowired
    private ServletWebServerApplicationContext context;
    @RequestMapping("/getnamebyid")
    public String getNameById(Integer id) throws InterruptedException {
        System.out.println("-------------------- Do Provider getNameById method."
                + LocalDateTime.now());
        Thread.sleep(1500);
        return "provider-name-" + id +
                " | port:" + context.getWebServer().getPort();
    }
}

2.3.2 消费者实现

  • 创建消费者模块

  • 配置

    spring:
      application:
        name: nacos-consumer-demo
      cloud:
        nacos:
          discovery:
            server-addr: localhost:8848
            username: nacos
            password: nacos
            register-enabled: false # 消费者(不需要将此服务注册到nacos)
    server:
      port: 8080
    
  • 使用 FeignClient 调用示例:

    首先添加 Feign 依赖:

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-openfeign</artifactId>
    </dependency>
    

    然后定义 Feign 接口:

    @FeignClient(name = "nacos-discovery-demo")
    public interface UserFeignClient {
        @RequestMapping("/user/getnamebyid")
        String getNameById(Integer id);
    }
    

    最后在 Controller 中使用:

    @RestController
    public class ConsumerFeignController {
        @Autowired
        private UserFeignClient userFeignClient;
        @RequestMapping("/consumer/getnamebyid")
        public String getNameById(Integer id) {
            return userFeignClient.getNameById(id);
        }
    }
    

http://www.kler.cn/a/560643.html

相关文章:

  • 吐血整理:在 Docker 中运行 Milvus
  • CPU多级缓存与缓存一致性协议
  • WordPress R+L Carrier Edition sql注入漏洞复现(CVE-2024-13481)(附脚本)
  • LeetCodehot 力扣热题100 课程表
  • OV-WATCH手表
  • 当我问了DeepSeek关于网络安全行业影响的问题
  • 阶跃星辰 Step-Vedio-T2V Docker 推理
  • 【技术笔记】Cadence 创建元器件 Pin 引脚的创建与设置
  • 深入理解 Redis 设计与集群管理
  • 抖音营销创新策略与案例分析:以奈雪的茶为例及开源AI智能名片2+1链动模式S2B2C商城小程序的启示
  • ubuntu22.04 升级 gcc 12.3
  • SBOM情报预警 | 恶意NPM组件窃取Solana智能合约私钥
  • 算法刷题-字符串-151.反转单词
  • (网络安全)如何建立安全运营中心
  • Css3重点知识讲解
  • Flutter使用permission_handler请求通知权限不会弹出权限弹窗
  • SSE/Fetch API+Stream/WebSocket实时流式接收Node后端传来的处理过后的Coze API数据
  • (七)趣学设计模式 之 适配器模式!
  • DeepSeek 助力 Vue 开发:打造丝滑的滚动动画(Scroll Animations)
  • Python游戏编程之赛车游戏6-4