SpringCloud Alibaba场景实践(Nacos篇)

一、基于SpringCloud Alibaba的微服务电商解决方案

1.1、什么是SpringCloud Alibaba?

一系列框架的有序的集合

1.2、电商项目的三高

高并发、高新能、高可用

1.3、SpringCloud Alibaba电商微服务 架构


image.png

AKF扩展拆分


image.png

y轴


image.png

x轴


image.png

z轴


image.png

1.4 微服务工程搭建


image.png

搭建结构

版本选择


版本匹配

1.5 Nacos极简入门

1.5.1 介绍

帮助我们发现、配置、管理微服务(alibaba实现的服务注册中心)

1.5.2 使用场景


老项目使用


最新用法

1.5.3 使用

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

启动:

访问:

1.5.4 Nacos与项目整合

启动类上加@EnableDiscoveryClient服务发现注解,在RestTemplate上加@LoadBalanced注解,实现动态路由功能,最后在yml文件中配置nacos地址

pom.xml

复制代码
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

String productName = restTemplate.getForObject("http://product-server/product/createProduct/" + productId, String.class);

二、Nacos Config配置中心

2.1 常见的配置中心

  • Appllo
  • Disconf
  • SpringCloud Config
  • Nacos

2.2 为什么使用配置中心

  • 配置文件分散在各个项目里,不方便维护
  • 配置内容安全与权限
  • 更新配置后,项目需要重启

2.3 配置中心得作用

系统配置的集中管理(编辑、存储、分发)、动态更新配置不重启、回滚配置(变更管理、历史版本管理、变更审计)等所有与配置相关的活动

2.4 不同环境的配置与使用

复制代码
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>

spring:
  application:
    name: configcenter
  cloud:
    nacos:
      config:
        server-addr: ***********:8848
        file-extension: yaml
  profiles:
    active: dev
server:
  port: 7000

配置中心地址:http://47.93.249.168:8848/nacos

nacos配置中心


配置中心详细配置

复制代码
@RestController
@RefreshScope  //动态刷新nacos配置
@RequestMapping("/config")
public class ConfigController {
    @Value("${testStr}")
    private String testStr;
    @Value("${testCommon}")
    private String testCommon;

    @GetMapping("/test")
    public String hello() {
        return testStr + "," +"testCommon";
    }
}
思考:在nacos中配置了四个文件,configcenter-test.yaml,configcenter-dev.yaml,configcenter-prod.yaml,configcenter.yaml
如果同一个配置在四个文件中都存在且值不同,最终项目读取的是那个?

最后会读取configcenter.yaml

结论:如果配置了spring.profile.active则优先获取configcenter-${spring.profile.active}.yaml中的值
总结:
  • 在bootstrap.yaml文件中如果配置了spring.profile.active,在nacos多个配置中,不重合的值都会读取,重合的以active为主。没配置就以configcenter.yaml为主
  • nacos中Data ID(configcenter-dev)的取值要与bootstrap.yaml中 spring.application.name(configcenter)和spring.profiles.active(dev)的值一致

2.5 不同微服务的配置和使用

1、shard-configs
复制代码
spring:
  application:
    name: configcenter
  cloud:
    nacos:
      config:
        server-addr: **********:8848
        file-extension: yaml
        shared-configs[0]:
          dataId: mq.yaml          # 对应的nacos的Data Id
          refresh: true               # 是否刷新
        shared-configs[1]:
          dataId: redis.yaml
          refresh: true

/**
     * 不同微服务的nacos配置
     */
    @Value("${redisStr}")
    private String redisStr;
    @Value("${mqStr}")
    private String mqStr;
    @Value("${test}")
    private String test;

    @GetMapping("/test")
    public String hello() {
        return testStr + "," +testCommon;
    }

    @GetMapping("/test2")
    public String hello2() {
        return redisStr +","+ mqStr;
    }

    @GetMapping("/test3")
    public String hello3() {
        return test;
    }


nacos配置中心

思考:如果shard-configs的文件存在相同的配置,最终会以哪个配置文件中的值为主

会以后配置的配置文件中的值为主

2、extension-configs

extension-configs读取顺序和shard-config配置和读取顺序一样,后配置的为主

复制代码
spring:
  application:
    name: configcenter
  cloud:
    nacos:
      config:
        server-addr: **********:8848
        file-extension: yaml
        extension-configs[0]:
          dataId: redis.yaml          # 对应的nacos的Data Id
          refresh: true               # 是否刷新
        extension-configs[1]:
          dataId: mq.yaml
          refresh: true

总结

当shared-configs和extension-configs存在相同的配置,则以extension-config中的配置为主

三、Nacos Config动态刷新机制

3.1 原理:


image.png
最后编辑于:2025-06-05 21:07:25
© 著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务

喜欢的朋友记得点赞、收藏、关注哦!!!

相关推荐
一 乐1 小时前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
Boilermaker19921 小时前
[Java 并发编程] Synchronized 锁升级
java·开发语言
Cherry的跨界思维1 小时前
28、AI测试环境搭建与全栈工具实战:从本地到云平台的完整指南
java·人工智能·vue3·ai测试·ai全栈·测试全栈·ai测试全栈
alonewolf_992 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
一嘴一个橘子2 小时前
spring-aop 的 基础使用(啥是增强类、切点、切面)- 2
java
sheji34162 小时前
【开题答辩全过程】以 中医药文化科普系统为例,包含答辩的问题和答案
java
恋爱绝缘体13 小时前
2020重学C++重构你的C++知识体系
java·开发语言·c++·算法·junit
HIT_Weston3 小时前
93、【Ubuntu】【Hugo】搭建私人博客:面包屑(一)
linux·运维·ubuntu
wszy18093 小时前
新文章标签:让用户一眼发现最新内容
java·python·harmonyos
cuijiecheng20183 小时前
Linux下Beyond Compare过期
linux·运维·服务器