1、版权相同:它们都是使用的bsd协议,使用它的项目可以用于商业用户,不必发布二次修改的代码,可以修改源代码。
2、value大小不同
memcache是一个内存缓存,key的长度小于250字符,单个item存储要小于1M,不适合虚拟机使用
redis的key值尽量不要超过1024个字节
3、cpu利用
redis单线程模型只能使用一个cpu,可以开启多个redis进程,redis只使用单核,而memcached可以使用多核,所以在比较上,平均每一个核上redis在存储小数据时比memcached性能更高。而在100k以上的数据中,memcached性能要高于redis。内存使用效率:使用简单的key-value存储的话,memcached的内存利用率更高,而如果redis采用hash结构来做key-value存储,由于其组合式的压缩,其内存利用率会高于memcached.
4、数据类型
redis数据类型丰富,支持set、list、Hash、set、sortset等类型
memcache支持简单数据类型、二进制数据类型,需要客户端自己处理复杂对象
5、持久性
redis支持数据落地持久化存储,redis有部份存在硬盘上,这样能保证数据的持久性。
memcache不支持数据持久存储,把数据全部存在内存之中,断电后会挂掉,数据不能超过内存大小
6、分布式存储
redis支持master-slave复制模式
memcache可以利用客户端使用一致性hash做分布式
7、数据一致性不同
redis使用的是单线程模型,保证了数据按顺序提交。
memcache需要使用cas保证数据一致性。CAS(Check and Set)是一个确保并发一致性的机制,属于“乐观锁”范畴;原理很简单:拿版本号,操作,对比版本号,如果一致就操作,不一致就放弃任何操作