memcache and redis 的区别

memcache和redis都属于缓存但是memcache的存储大小是收到 限制的memcache的 键值长度是250,内存的大小限制是1M并且memcache不支持数据的持久化缓存

redis支持五种数据类型,string list set(集合) hash 和Sorted Set(有序集合),并且redi是支持数据的持久化缓存,redis的两种机制AOF和RDB

Redis的持久化

  1. RDB

a) 简而言之,就是在不同的时间点,将redis存储的数据生成快照并存储到磁盘等介质上;

b) 对于RDB方式,redis会单独创建(fork)一个子进程来进行持久化,而主进程是不会进行任何IO操作的,这样就确保了redis极高的性能。

c) 如果需要进行大规模数据的恢复,且对于数据恢复的完整性不是非常敏感,那RDB方式要比AOF方式更加的高效。

d) 如果你对数据的完整性非常敏感,那么RDB方式就不太适合你,因为即使你每5分钟都持久化一次,当redis故障时,仍然会有近5分钟的数据丢失。

  1. AOF

a) 将redis执行过的所有写指令记录下来,在下次redis重新启动时,只要把这些写指令从前到后再重复执行一遍,就可以实现数据恢复了。

b) 默认的AOF持久化策略是每秒钟fsync一次;

c) AOF在文件中采用追加方式来写入,因此不做任何处理的话,AOF文件会变得越来越大,为此,redis提供了AOF文件重写(rewrite)机制,当AOF文件的大小超过所设定的值时,redis就会启动AOF文件的内容压缩,只保留可以恢复数据的最小指令集。假如我们调用了100次INCR指令,在AOF文件中就要存储100条指令,但这明显是很低效的,完全可以把这100条指令合并成一条SET指令,这就是重写机制的原理。

  1. RDB和AOF的区别:

a) RDB方式存的是数据,AOF方式存的是指令;

b) RDB和AOF可以同时使用,在这种情况下,如果redis重启的话,会优先采用AOF方式来进行数据恢复,这是因为AOF方式的数据恢复完整度更高。

c) 同样数据规模的情况下,AOF文件要比RDB文件的体积大。而且,AOF方式的恢复速度也要慢于RDB方式。

  1. AOF重写原理:

a) 首先,当重写开始时,创建一个重写子进程;

b) 子进程读取现有AOF文件中的指令解析并压缩至一个临时文件中;

c) 同时主进程接收到新的写指令时,一边继续向AOF文件中写入,以保证原有AOF文件的可用性,避免重写过程中发生意外,一边向内存缓冲区中写入;

d) 当子进程完成重写任务后,想主进程发送信号,主进程接收到信号后将内存缓冲区中新的写指令追加到新的AOF文件中;

e) 追加结束后,会用新的AOF文件替换旧的AOF文件,至此,重写结束;

Redis的主从

    1. 主从结构,一是为了纯粹的冗余备份,二是为了提升读性能,比如很消耗性能的SORT就可以由从服务器来承担。
    2. redis的主从同步是异步进行的,这意味着主从同步不会影响主逻辑,也不会降低redis的处理性能。
    3. 主从架构中,可以考虑关闭主服务器的数据持久化功能,只让从服务器进行持久化,这样可以提高主服务器的处理性能

Memecached重点启动设置参数

  1. –m:默认分配内存大小为64M,32位操作系统下每个进程最大分配内存为2G,所以如果需要分配更多的内存需要使用64位操作系统,但是这个不会一启动就占用,是随着需要逐步分配给各slab的。;

–I:调整分配page页的大小,默认1M,最小1K,最大128K;

–f:memcached默认情况下下一个slab的最大值为前一个的1.25倍,可通过此参数来设定;

–P:TCP端口设置,默认为11211;

–l:监听的IP地址,如果为本机可不设置;

–d:以守护进程的方式运行;

–u:指定用户;

–M:禁止LRU策略,内存耗尽时返回错误,而不是删除项;

–c:最大同时连接数,默认为1024;

–t:线程数,默认为4;

时间: 2024-12-18 18:13:20

memcache and redis 的区别的相关文章

memcache 和 redis 的区别

1)Redis中,并不是所有的数据都一直存储在内存中的,这是和Memcache相比一个最大的区别.2)Redis在很多方面具备数据库的特征,或者说就是一个数据库系统,而Memcache只是简单的K/V缓存.3)他们的扩展都需要做集群:实现方式:master-slave.Hash.4)在100k以上的数据中,Memcache性能要高于Redis.5)如果要说内存使用效率,使用简单的key-value存储的话,Memcached的内存利用率更高,而如果Redis采用hash结构来做key-value

Memcache和redis的区别

源链接:http://gnucto.blog.51cto.com/3391516/998509 传统MySQL+ Memcached架构遇到的问题 实际MySQL是适合进行海量数据存储的,通过Memcached将热点数据加载到cache,加速访问,很多公司都曾经使用过这样的架构,但随着业务数据量的不断增加,和访问量的持续增长,我们遇到了很多问题: 1.MySQL需要不断进行拆库拆表,Memcached也需不断跟着扩容,扩容和维护工作占据大量开发时间. 2.Memcached与MySQL数据库数据

分布式缓存Memcache和Redis

引言 针对于现在计算机的CPU和网络设施,对应用程序来说,执行效率的瓶颈,已经不是代码的长度(实现同一个功能)和带宽了,而是,代码访问资源的过程,即:让我们的程序慢下来的罪魁祸首就是IO操作. 程序从硬盘上读取数据是一个非常花费时间的操作,因为我们现在所使用的硬盘是机械式的,你想机械的运行速度和电的速度,那是一个级别上的选手吗? 为了解决程序的瓶颈,人们提出了一种想法:使用空间换取时间.程序访问硬盘用的时间长,那就让数据放到内存中,让程序访问内存,这样不就节省了时间.这样确实剩下了我们程序获取数

分针网—每日分享:Redis、Memcache和MongoDB的区别

http://www.f-z.cn/id/189 Memcached Memcached的优点: Memcached可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS(取决于key.value的字节大小以及服务器硬件性能,日常环境中QPS高峰大约在4-6w左右).适用于最大程度扛量. 支持直接配置为session handle. Memcached的局限性: 只支持简单的key/value数据结构,不像Redis可以支持丰富的数据类型. 无法进行持久化,数据不能备份,只能用于缓存使用,且重

Redis、Memcache和MongoDB的区别

Memcached Memcached的优点:Memcached可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS(取决于key.value的字节大小以及服务器硬件性能,日常环境中QPS高峰大约在4-6w左右).适用于最大程度扛量.支持直接配置为session handle.Memcached的局限性:只支持简单的key/value数据结构,不像Redis可以支持丰富的数据类型.无法进行持久化,数据不能备份,只能用于缓存使用,且重启后数据全部丢失.无法进行数据同步,不能将MC中的数据迁移到

memcache和redis区别

memcache和redis区别 2014年4月27日mood暂无评论 memcache官方定义 Free & open source, high-performance, distributed memory object caching system, generic in nature, but intended for use in speeding up dynamic web applications by alleviating database load. redis官方定义Re

Memcache与Redis有什么区别?

Redis 和 Memcache 都是基于内存的数据存储系统.Memcached是高性能分布式内存缓存服务,其本质上就是一个内存key-value数据库.Redis是一个开源的key-value存储系统.与Memcached类似,Redis将大部分数据存储在内存中,支持的数据类型包括:字符串.哈希表.链表.集合.有序集合以及基于这些数据类型的相关操作.那么,Memcache与Redis有什么区别呢?让我们一起来看一下. 1.数据操作不同 与Memcached仅支持简单的key-value结构的数

[转帖]Redis、Memcache和MongoDB的区别

https://www.cnblogs.com/tuyile006/p/6382062.html >>Memcached Memcached的优点:Memcached可以利用多核优势,单实例吞吐量极高,可以达到几十万QPS(取决于key.value的字节大小以及服务器硬件性能,日常环境中QPS高峰大约在4-6w左右).适用于最大程度扛量.支持直接配置为session handle.Memcached的局限性:只支持简单的key/value数据结构,不像Redis可以支持丰富的数据类型.无法进行

Memcache和Redis复习总结

Memcache Memcache是一个高性能的分布式的内存对象缓存系统,主要是用来缓存从MySQL数据库中查询的数据,减少对mysql数据库的压力. Memcache的工作流程: 当用户发生一个动态请求的时候,先去Memcache服务器里面查询缓存数据,当首次查询的时候,Memcache里面肯定是没有数据的,这个时候需要php程序去MySQL数据库里面获取数据,将获取先缓存一份到Memcache服务器里面,在把数据返回给用户.当第二次发生相同的动态的请求的时候,这个时候由于上一次上Memcac