本项目是基于极客兔兔的分布式缓存GeeCache的基础上进行编写的。
│ go.mod
│ go.sum
│ main.go main函数,用于测试
│ README.md MD文档
│ run.bat windows下测试
│ run.sh Linux下测试
│
└─geecache
│ byteview.go 缓存值的抽象与封装
│ cache.go 并发控制
│ geecache.go 负责与外部交互,控制缓存存储和获取的主流程
│ geecache_test.go
│ peers.go 抽象 PeerPicker
│ grpc.go Server和Client的实现
│
├─consistenthash
│ consistenthash.go 一致性哈希算法
│ consistenthash_test.go
│
├─geecachepb
│ geecachepb.pb.go
│ geecachepb.proto protobuf文件
│ geecachepb_grpc.pb.go
│
├─lfu
│ lfu.go LFU算法
│ lfu_test.go
│
├─lru
│ lru.go LRU算法
│ lru_test.go
│
├─registry
│ discover.go 服务发现
│ register.go 服务注册
│
└─singleflight
singleflight.go 防止缓存击穿
singleflight_test.go
- 实现lfu算法和lru算法两种缓存淘汰策略。
- 加入热点缓存hotCache
- 设置ttl和惰性删除
- 增加了grpc进行通信
- 使用etcd做服务注册和服务发现
cannot use target.Endpoint (value of type func() string) as string value in struct literal如果报这个错误,~/GOPATH/pkg/mod/go.etcd.io/etcd/client/[email protected]/naming/resolver这个路径下的resolver.go文件中的第22行改成target: target.Endpoint(),这样就可以了