Cache缓存项目学习2

项目架构
缓存服务器设计
ETCD使用:

当Server实例初始化时建立ETCD客户端,当server启动时,进行服务注册。

当服务器实例化peeker时,进行服务发现,服务发现分为全量发现与增量发现。增量更新维持一个watch goroutine,监视etcd的变化,如有新的服务变化,更新peeker缓存。

GRPC使用

Server层进行grpc.Server创建,实现了Get/Set/Delete方法。

Group缓存层当本地缓存未命中时,会调用PickPeer,获取远程客户端发起gRPC调用。

对于Peer节点层,PickPeer会使用一致性哈希选择返回对应的client,方便对其进行RPC调用。

Group设计
复制代码
// Group 是一个缓存命名空间
type Group struct {
    name       string
    getter     Getter
    mainCache  *Cache                //缓存空间
    peers      PeerPicker            //选择器
    loader     *singleflight.Group    //单飞设计
    expiration time.Duration // 缓存过期时间,0表示永不过期
    closed     int32         // 原子变量,标记组是否已关闭
    stats      groupStats    // 统计信息
}

// groupStats 保存组的统计信息
type groupStats struct {
    loads        int64 // 加载次数
    localHits    int64 // 本地缓存命中次数
    localMisses  int64 // 本地缓存未命中次数
    peerHits     int64 // 从对等节点获取成功次数
    peerMisses   int64 // 从对等节点获取失败次数
    loaderHits   int64 // 从加载器获取成功次数
    loaderErrors int64 // 从加载器获取失败次数
    loadDuration int64 // 加载总耗时(纳秒)
}
相关推荐
小宋加油啊16 小时前
学习机械臂相关知识
学习
十月的皮皮20 小时前
C语言学习笔记20260606- 求月份天数三种写法
c语言·笔记·学习
马士兵教育20 小时前
Java还有前景吗?Java+AI大模型学习路线及项目?
java·人工智能·python·学习·机器学习
lizhihai_9921 小时前
股市学习心得-AI 产业链核心标的梳理清单
大数据·服务器·人工智能·科技·学习
Albert Edison21 小时前
【Redis】Centos7.9 安装 Redis 5 教程
数据库·redis·缓存
Steadfast_GG1 天前
Redis中的通用命令
redis·缓存
吃好睡好便好1 天前
说说科学爬山
学习·生活
lunzi_08261 天前
【学习笔记】《Python编程 从入门到实践》第8章:函数定义、参数传递与模块导入
笔记·python·学习
零陵上将军_xdr1 天前
后端转全栈学习-Day5-JavaScript 基础-3
开发语言·javascript·学习