SpringCloud Alibaba微服务 -- Nacos使用以及注册中心和配置中心的应用(保姆级)

简介: SpringCloud Alibaba微服务 -- Nacos使用以及注册中心和配置中心的应用(保姆级)

下载并安装启动nacos

1、下载nacos

下载地址:https://github.com/alibaba/nacos/releases/tag/1.4.2

我们选择windows版本

解压得到nacos文件夹

进入到conf目录下修改application.properties配置文件

将以下这几个配置打开,并配置自己的数据库

在数据库执行nacos-mysql.sql的sql执行文件

2、启动nacos

进入到bin目录下执行startup.cmd执行文件

启动

我们看到上面报错了,是因为当前是以集群模式启动,找不到集群相关配置文件cluster.conf;

处理方法:

1 可以使用单机启动方式,在命令行执行 startup.cmd -m standalone

2 集群模式启动,在nacos/conf目录下,将文件 cluster.conf.example 复制一份,重命名未cluster.conf,并将所有内容注释

我们再重新启动

启动成功,访问nacos地址,http://localhost:8848/nacos

将服务注册到nacos

1、引入nacos依赖

<dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <version>${spring-cloud-alibaba.version}</version>
        </dependency>

2、创建application.yml配置文件和启动类并引入nacos

搭建微服务工程 在上一篇文章

springcloud alibaba微服务工程搭建(保姆级)

项目结构

在application.yml文件中添加nacos相关配置

server:
  port: 9090
spring:
  application:
    name: mdx-shop-user
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848

启动项目

已经注册成功,查看nacos服务

2、命名空间

我们新建一个命名空间,可以将服务注册到这个命名空间下,比如同一团队中我们有很多开发人员连接一个nacos,我们都在本地启动user服务,这个时候导致启动了多个user实例,在本地调试中可能会出现问题,所以我们创建一个命名空间,也可以本地一个命名,测试一个命名,生产一个命名这样随意分配都可以

修改application.yml配置,添加命名空间

启动项目

此时服务已经注册到了mdx的命名空间下

nacos配置中心

我们可以把项目中的一些开关等有可能在线上更改的配置放到nacos的统一配置中心,更改配置不用重新的上线下线服务,极大的降低了成本

1、添加配置中心依赖

<dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
            <version>${spring-cloud-alibaba.version}</version>
        </dependency>

2、创建bootstrap.properties配置文件

bootstrap文件会在项目启动后第一个被加载

在配置文件中添加如下配置

server-addr:nacos地址

extension-configs: 扩展配置,支持配置多个配置文件

data-id: 配置文件的文件名称加后缀

group:配置文件的组,默认是DEFAULT_GROUP

refresh: 控制该 Data Id 在配置变更时,是否支持应用中可动态刷新, 感知到最新的配置值。默认是不支持的

file-extension: 配置内容的数据格式,配置文件的格式,一般为properties 和 yaml

namespace: 命名空间

spring.application.name=mdx-shop-user
spring.cloud.nacos.config.server-addr=localhost:8848
spring.cloud.nacos.config.extension-configs[0].data-id=mdx-shop-user.yaml
spring.cloud.nacos.config.extension-configs[0].group=shop
spring.cloud.nacos.config.extension-configs[0].refresh=true
spring.cloud.nacos.config.file-extension=yml
spring.cloud.nacos.config.namespace=mdx
spring.cloud.nacos.config.group=shop

3、在nacos平台上创建配置文件映射相关

在mdx命名空间下新建配置

dataId和group要和配置文件上的对应,并且我们增加一个测试的配置,然后发布

4 启动项目测试

接下来测试一下,我们新建一个HelloWordController作为测试接口

mdx-shop-user.test.userId 这个配置是我们在配置中心加的配置,本地的项目中是没有的

@RestController
@RequestMapping("/user")
public class HelloWordController {
    @Value("${mdx-shop-user.test.userId}")
    private String userId;
    @GetMapping("getUserConfigTest")
    public String getUserConfigTest(){
        return userId != null ? userId : "未获取到配置";
    }
}

启动项目

然后发现报错了,找不到相关配置,导致项目启动失败

原因:

从Spring Boot 2.4版本开始,配置文件加载方式进行了重构,

spring cloud2.4之前的源码:

package org.springframework.cloud.bootstrap;
public class BootstrapApplicationListener implements ApplicationListener<ApplicationEnvironmentPreparedEvent>, Ordered {
    public void onApplicationEvent(ApplicationEnvironmentPreparedEvent event) {
        ConfigurableEnvironment environment = event.getEnvironment();
        if ((Boolean)environment.getProperty("spring.cloud.bootstrap.enabled", Boolean.class, true)) {
        }
    }
}

spring cloud2.4之后的源码:

package org.springframework.cloud.util;
public abstract class PropertyUtils {
    public static boolean bootstrapEnabled(Environment environment) {
        return (Boolean)environment.getProperty("spring.cloud.bootstrap.enabled", Boolean.class, false) || MARKER_CLASS_EXISTS;
    }
}

在spring cloud2.4之后将bootstrap.enabled设置为false

我们需要在pom文件中重新添加bootstrap的依赖

<dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-bootstrap</artifactId>
            <version>3.0.2</version>
        </dependency>

重新启动项目

已经监听到了配置中心的配置

访问浏览器测试 http://localhost:9090/user/getUserConfigTest

成功访问到配置

5 @RefreshScope注解 配置动态刷新

SpringCloud新增了一个自定义的作用域:refresh(可以理解为“动态刷新”),同样用了一种独特的方式改变了Bean的管理方式,使得其可以通过外部化配置(.properties)的刷新,在应用不需要重启的情况下热加载新的外部化配置的值。

具体实现大家可以看一下这篇文章 https://blog.csdn.net/JokerLJG/article/details/120254643

我们来测试一下,在HelloWordController类上增加@RefreshScope注解,重启项目

先来访问一下这个接口 http://localhost:9090/user/getUserConfigTest

获取到的值为 mdx123456

然后我们改一下配置中心的配置

将值改为 mdx123456-new 然后发布

现在我们不重新启动项目,直接浏览器访问网址 http://localhost:9090/user/getUserConfigTest

成功返回我们新改的配置

创作不易,点个赞吧👍

最后的最后送大家一句话

白驹过隙,沧海桑田

与君共勉

项目搭建请看上一篇文章

springcloud alibaba微服务工程搭建(保姆级)

下一篇文章

springcloud alibaba微服务 – openfeign的使用(保姆级)

文末送福利啦~

1、Java(SE、JVM)、算法数据结构、数据库(Mysql、redis)、Maven、Netty、RocketMq、Zookeeper、多线程、IO、SSM、Git、Linux、Docker、Web前端相关学习笔记
2、2023最新BATJ大厂面试题集
3、本教程项目源码
领取方式:关注下方公主号,回复:【笔记】、【面试】、【mdx-shop】获取相关福利。

文章持续更新,可以关注下方公众号或者微信搜一搜「 最后一支迷迭香 」获取项目源码、干货笔记、面试题集,第一时间阅读,获取更完整的链路资料。

相关文章
|
23小时前
|
负载均衡 Nacos 数据库
【Nacos】配置管理、微服务配置拉取、实现配置热更新、多环境配置
【Nacos】配置管理、微服务配置拉取、实现配置热更新、多环境配置
9 1
|
12天前
|
SpringCloudAlibaba 应用服务中间件 Nacos
【微服务 SpringCloudAlibaba】实用篇 · Nacos配置中心(下)
【微服务 SpringCloudAlibaba】实用篇 · Nacos配置中心
32 0
|
12天前
|
JSON SpringCloudAlibaba Java
【微服务 SpringCloudAlibaba】实用篇 · Nacos配置中心(上)
【微服务 SpringCloudAlibaba】实用篇 · Nacos配置中心
39 1
|
12天前
|
机器学习/深度学习 Java Nacos
Nacos 配置中心(2023旧笔记)
Nacos 配置中心(2023旧笔记)
22 0
|
12天前
|
Java API Nacos
第十二章 Spring Cloud Alibaba Sentinel
第十二章 Spring Cloud Alibaba Sentinel
33 0
|
15小时前
|
运维 负载均衡 API
构建高效微服务架构的七大关键策略
【5月更文挑战第27天】 在当前企业级应用开发中,微服务架构已成为实现敏捷、可扩展和灵活部署的主流解决方案。本文将深入探讨构建和维护一个高效微服务系统的七个关键策略,包括服务划分原则、API网关设计、服务发现与注册、配置管理、熔断机制、分布式跟踪及持续集成和部署。这些策略不仅有助于提升系统的稳定性和弹性,还能确保在不断变化的业务需求面前,系统能够快速响应并保持高效的运行状态。
|
15小时前
|
机器学习/深度学习 监控 持续交付
构建高效微服务架构:后端开发的新趋势探索深度学习在图像识别中的边界
【5月更文挑战第27天】随着业务需求的快速变化和市场竞争的激烈,企业需要更灵活、高效和可扩展的系统来支持其运营。微服务架构作为一种新兴的软件开发模式,已经成为后端开发领域的热门话题。本文将深入探讨微服务架构的概念、优势以及如何构建一个高效的微服务架构,帮助后端开发者更好地应对业务挑战。 【5月更文挑战第27天】 随着人工智能的不断进步,深度学习技术已经在图像识别领域取得了显著成就。本文将深入探讨深度学习模型在处理复杂图像数据时的挑战与机遇,分析现有技术的局限性,并提出潜在的改进方向。通过实验验证,我们将展示如何通过创新的网络架构、数据增强策略和损失函数设计来提升模型性能。本研究不仅为深度学习
|
16小时前
|
监控 安全 数据管理
构建高效微服务架构的五大核心要素
【5月更文挑战第27天】在现代软件开发中,微服务架构以其灵活性、可扩展性和容错性而受到企业青睐。本文将深入探讨构建一个高效微服务架构所需的五大核心要素:服务划分策略、通信机制、数据管理、安全性和监控与日志系统。这些要素是确保微服务架构能够高效运行并适应快速变化需求的关键。我们将逐一解析每个要素的重要性及其实现方法,为后端开发者提供一套全面的指导原则和实践技巧。
|
16小时前
|
消息中间件 缓存 数据库
构建高性能微服务架构:从理论到实践
【5月更文挑战第27天】在现代软件开发中,微服务架构已成为实现可扩展、灵活和容错系统的关键设计模式。本文将深入探讨如何构建一个高性能的微服务系统,包括关键的设计理念、技术选型以及性能优化策略。我们将通过分析真实案例,提供一套实用的指导原则和最佳实践,帮助开发者提升系统的响应速度和处理能力,从而满足不断变化的业务需求。
|
16小时前
|
存储 运维 监控
探索微服务架构下的系统监控策略
【5月更文挑战第27天】在当今快速迭代和持续部署盛行的软件工程实践中,微服务架构以其灵活性、可扩展性成为了众多企业技术选型的宠儿。然而,随之而来的复杂性也给系统监控带来了前所未有的挑战。本文深入剖析了在微服务环境中实施有效监控的策略,探讨了如何通过日志聚合、性能指标监控与分布式追踪技术相结合,实现对微服务生态系统的全方位把控。我们将分享一系列实践经验,并讨论监控策略的最佳实践,以期为面临类似挑战的开发者和运维团队提供参考。