分布式数据缓存工具比较

来源:互联网 发布:淘宝朋友代付退款退哪 编辑:程序博客网 时间:2024/05/22 00:13

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

在网上找了一圈,分布式缓存主要有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编写客户端

0 0
原创粉丝点击