【java、微服务、nacos】nacos学习笔记

Nacos服务分级存储模型

① 一级是服务,例如userservice

②二级是集群,例如杭州或上海

③ 三级是实例,例如杭州机房的某台部署了userservice的服务器

配置实例集群属性

改变服务的yml文件

复制代码
spring:
  cloud:
    nacos:
      discovery:
        cluster-name: HZ

NacosRule负载均衡

在调用模块的yml中添加

复制代码
userservice:
  ribbon:
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule

根据权重负载均衡

环境隔离(namespace)

配置管理

配置更改热更新

统一配置管理:

步骤:

1.引入依赖

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

2.在服务模块添加bootstrap.yml(优先级高于application. yml)

复制代码
spring:
  application:
    name: userservice
  profiles:
    active: dev
  cloud:
    nacos:
      server-addr: localhost:8848
      config:
        file-extension: yaml

执行步骤:项目启动-》读取nacos中配置文件(以bootstrap.yml为引导)-》读取本地配置文件application.yml-》创建spring容器-》加载bean

配置热更新

方法一:在@Value注入的变量所在类上添加注解@RefreshScope

java 复制代码
@Slf4j
@RestController
@RequestMapping("/user")
@RefreshScope
public class UserController {
}

方法二:使用@ConfigurationProperties注解

java 复制代码
package cn.itcast.user.config;

import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;

/**
 * PatternProperties
 *
 * @author huang
 * @package cn.itcast.user.config
 * @since 2024/3/1 19:36
 */
@Data
@Component
@ConfigurationProperties(prefix = "pattern")
public class PatternProperties {
    private String dataformat;
}

之后要用自动装配把PatternProperties实例对象自动加载到要使用的地方

多环境配置共享

Data Id为服务名就是多环境配置共享

如果要分开发和发布环境,要加上-dev或-test之类的

配置优先级:服务名-profile.yaml >服务名称yaml>本地配置

搭建Nacos集群

Feign远程调用

Gateway网关

相关推荐
JHC00000012 小时前
智能体造论子--简单封装大模型输出审核器
开发语言·python·机器学习
【赫兹威客】浩哥12 小时前
可食用野生植物数据集构建与多版本YOLO模型训练实践
开发语言·人工智能·python
沐知全栈开发13 小时前
Java 封装
开发语言
2301_8107301013 小时前
python第三次作业
开发语言·python
小马爱打代码13 小时前
Spring AI 实战:Agent 基础搭建与核心能力解析
java·人工智能·spring
郝学胜-神的一滴13 小时前
Python List操作:+、+=、extend的深度解析
开发语言·数据结构·python·程序人生·架构·list
csdn2015_13 小时前
springboot task
java·spring boot·后端
2301_7903009613 小时前
C++中的命令模式
开发语言·c++·算法
2301_8223769413 小时前
C++中的解释器模式
开发语言·c++·算法
czlczl2002092513 小时前
Spring Boot :如何高性能地在 Filter 中获取响应体(Response Body)
java·spring boot·后端