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 #长轮询监听实例变更,数值越小,实时性越高,网络交互越频繁

相关推荐
论迹18 小时前
【Redis】-- 单线程模型
数据库·redis·缓存
ChineHe1 天前
Redis基础篇004_Redis Pipeline流水线详解
数据库·redis·缓存
Facechat1 天前
视频混剪-时间轴设计
java·数据库·缓存
win x2 天前
Redis 持久化
数据库·redis·缓存
a努力。2 天前
中国电网Java面试被问:分布式缓存的缓存穿透解决方案
java·开发语言·分布式·缓存·postgresql·面试·linq
码农水水2 天前
美团Java后端Java面试被问:Kafka的零拷贝技术和PageCache优化
java·开发语言·后端·缓存·面试·kafka·状态模式
KlayPeter2 天前
前端数据存储全解析:localStorage、sessionStorage 与 Cookie
开发语言·前端·javascript·vue.js·缓存·前端框架
jayaccc2 天前
前端缓存全解析:提升性能的关键策略
前端·缓存
无限大.2 天前
为什么“缓存“能提高系统性能?——从 CPU 缓存到分布式缓存
分布式·缓存