【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网关

相关推荐
努力还债的学术吗喽4 分钟前
【项目】pyqt5基于python的照片整蛊项目
开发语言·python·qt
m0_569531019 分钟前
shell(4)--shell脚本中的循环:(if循环,for,while,until)和退出循环(continue,break, exit)
开发语言
不见长安在9 分钟前
分布式ID
java·分布式·分布式id
熊小猿12 分钟前
Redis 缓存怎么更新?—— 四种模型与一次“迟到的删除”
java·后端·spring
星释12 分钟前
Rust 练习册 :掌握文本处理与词频统计
开发语言·后端·rust
火龙谷13 分钟前
DrissionPage遇到iframe
开发语言·前端·javascript
TDengine (老段)22 分钟前
从细胞工厂到智能制造:Extracellular 用 TDengine 打通数据生命线
java·大数据·数据库·科技·制造·时序数据库·tdengine
Boop_wu23 分钟前
[Java EE] 多线程 -- 初阶(1)
java·jvm·算法
HalvmånEver29 分钟前
Linux的第二章 : 基础的指令(二)
linux·运维·服务器·开发语言·学习
egoist202335 分钟前
[linux仓库]线程同步与生产者消费者模型[线程·陆]
linux·c语言·开发语言·线程同步·阻塞队列·生产者消费者模型