关注
Redis特点
1. 丰富的数据类型 (string, hash, set ,zset, list 等)
2. 读写性能优异
3. 单线程原子性
4. 可持久化 aof/rdb
5. 支持pub/sub 订阅发布模式
6. 高可用方案:哨兵机制
分布式一致性:redis主从为异步复制模式,一致性无法保证 (多节点数据一致性强依赖网络延迟)
主要适用场景:队列, 缓存,分布式session,等非强一致性需求
Etcd特点
1. 分布式一致性:基于raft协议,写入数据需要多数节点应答,确认后才会将数据返回给客户端。
2. 复制模式:基于日志复制
3. 主要适用场景:配置管理、服务发现
4. 易用性方面:Etcd 提供了HTTP API
总结:配置管理/服务发现 需要高可用和强一致性,从上面可以看出,Redis并不具备该特性。Redis有着优秀的并发吞吐能力,在web应用中,Redis大多数当缓存,队列使用,缓解数据库压力。
两者区别:
Etcd的红火来源于K8s用Etcd做服务发现,而Redis的兴起则来源于Memcache缓存本身的局限性。
Etcd是一种分布式存储,更强调的是各个节点之间的通信,同步,确保各个节点上数据和事务的一致性,使得服务发现工作更稳定,本身单节点的写入能力并不强。
Redis更像是内存型缓存,虽然也有Cluster做主从同步和读写分离,但节点间的一致性主要强调的是数据,并不在乎事务,因此读写能力很强,Qps甚至可以达到10万+
两者都是k-v存储,但Redis支持更多的存储模式,包括KEY,STRING,HMAP,SET,SORTEDSET等等,因此Redis本身就可以完成一些比如排序的简单逻辑。而Etcd则支持对Key的版本记录和txn操作和Client对Key的watch,因此适合用做服务发现。
日常使用中,Etcd主要还是做一些事务管理类的,基础架构服务用的比较多,容器类的服务部署是其主流。而Redis广泛地使用在缓存服务器方面,用作Mysql的缓存,通常依据请求量,甚至会做成多级缓存,当然部分情况下也用做存储型Redis做持续化存储。
查看原帖
4 评论
相关推荐
点赞 评论 收藏
分享
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 在大厂上班是一种什么样的体验 #
10515次浏览 131人参与
# 你认为工作的意义是什么 #
249154次浏览 1498人参与
# 程序员找工作至少要刷多少题? #
18201次浏览 246人参与
# 为了减少AI幻觉,你注入过哪些设定? #
4466次浏览 147人参与
# 我现在比当时_,你想录用我吗 #
8603次浏览 111人参与
# 机械人避雷的岗位/公司 #
43339次浏览 298人参与
# 一张图晒一下你的AI员工 #
4951次浏览 114人参与
# 论秋招对个人心气的改变 #
10693次浏览 154人参与
# 关于春招/暑期实习,你想知道哪些信息? #
7340次浏览 119人参与
# 刚入职的你踩过哪些坑 #
6709次浏览 127人参与
# AI Coding的使用心得 #
4558次浏览 101人参与
# 晒晒你司的新年福利 #
8385次浏览 105人参与
# 牛客AI体验站 #
6659次浏览 185人参与
# 12306一秒售罄,你抢到回家的票了吗? #
1905次浏览 47人参与
# 柠檬微趣工作体验 #
14763次浏览 83人参与
# 总结:哪家公司面试体验感最差 #
92964次浏览 430人参与
# 程序员能干到多少岁? #
8495次浏览 115人参与
# 你认为小厂实习有用吗? #
118003次浏览 679人参与
# 互联网公司评价 #
485534次浏览 4109人参与
# 应届生进小公司有什么影响吗 #
118251次浏览 1159人参与
