分布式数据缓存工具比较

应公司要求,需要搭建一个分布式数据缓存,所以这几天找了许多关于分布式的资料。

在网上找了一圈,分布式缓存主要有redis,memcached,还有ehcache,微软的Velocity。现在用的较多的貌似就是redis和memcached本人结合各个网站的资料列出了下面这张表格:

功能redismemcachedehcache
数据结构

k-v hash,list,set以及功能丰富的String的支持

k-v

     
分布式

在服务器端构建分布式存储

服务器端并没有分布式功能。各个memcached不会互相通信以共享信息,只能在客户端通过像一致性哈希这样的 分布式算法来实现Memcached的分布式存储

 
线程

单线程

多线程

 
永久化

内存快照,读写日志

不支持,可通过第三方应用实现

持久化到本地硬盘,生成一个.data和.index文件。cache初始化时会自动查找这两个文件,将数据放入cache

内存分配

实时申请,稍慢

先申请,在使用,预分割成固定大小

 
api

无,自己写


 
内存不够

周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。swap操作,发生阻塞

基于LRU算法自动删除不使用的缓存

LRU(默认),FIFO,LFU

服务器端的数据操作

和一般的 GET/SET一样高效

将数据拿到客户端来进行类似的修改再set回去。这大大增加了网络IO的次数和数据体积

 
性能

每秒处理请求的次数都不会成为瓶颈。(比如瓶颈可能会在网卡)

每秒处理请求的次数都不会成为瓶颈。(比如瓶颈可能会在网卡)

 
网络IO模型

单线程的IO复用模型单线程模型实际会严重影响整体吞吐量,CPU计算过程中,整个IO调度都是被阻塞住的

非阻塞IO复用的网络模型,但是引入了cache coherency和锁的问题

 
数据一致性

提供了事务的功能,可以保证一串 命令的原子性,中间不会被任何操作打断

提供了cas命令,可以保证多个并发访问操作同一份数据的一致性

 
适用性

  
只适用于java体系,只能用java编写客户端

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值