Nacos实例缓存

由于远程调用

  1. 用RestTemplate请求注册中心获取微服务地址列表

  2. 用RestTemplate给对方服务的某个地址发送请求

每次调用都要请求两次,会非常耗费性能

所以

第一次获取实例列表之后,缓存一下,就不用再获取了

|

而实例缓存要做的就是,和注册中心做一个同步/实时更新,如果有一个实例在注册中心被删除了,就从缓存中剔除出去这个实例

这个实例缓存存在本地内存中

缓存更新机制

  • 拉取+长轮询:客户端默认每60秒拉取一次全量实例,同时通过长轮询(默认30秒)监听实例变更,实时更新缓存。

  • 健康检查:Nacos Client会对实例做健康检查(默认心跳间隔5秒,不健康的实例会从可用缓存中剔除.

    spring:
    cloud:
    nacos:
    discovery:
    server-addr: 127.0.0.1:8848
    namespace: public
    heart-beat-intervel: 5000 #实例心跳间隔
    heat-beat-timeout: 15000 # 心跳超时时间(实力被标记为不健康的阈值)
    refresh-intervel: 60000 # 每次拉取实例的事件
    naming-polling-timeout: 30000 #长轮询监听实例变更,数值越小,实时性越高,网络交互越频繁

相关推荐
難釋懷1 小时前
Redis分片集群手动故障转移
数据库·redis·缓存
用什么都重名4 小时前
Redis 入门与实践:从基础到 Stream 消息队列
数据库·redis·缓存
常利兵5 小时前
Spring Boot缓存新玩法:一键切换,租户无忧
spring boot·后端·缓存
Lyyaoo.6 小时前
Spring Boot日志
spring boot·缓存·单元测试
Curvatureflight7 小时前
Redis实战:缓存设计与高频场景全解析
数据库·redis·缓存
我真会写代码7 小时前
从入门到精通:Redis实战指南,解锁高性能缓存核心能力
数据库·redis·缓存
haixingtianxinghai9 小时前
Redis的定期删除和惰性删除
数据库·redis·缓存
努力也学不会java18 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
czlczl200209251 天前
Redis数据编码
数据库·redis·缓存
Wpa.wk1 天前
pb协议接口测试
数据库·redis·缓存