1 什么是redis
redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对很多其它,包含string(字符串)、list(链表)、set(集合)和zset(有序集合)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,并且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。差别的是redis会周期性的把更新的数据写入磁盘或者把改动操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。
2 性能怎么样
Redis是一个高性能的key-value内存数据库。官方性能測试结果: set操作每秒110000次,get操作每秒81000次。
3 可不能够存对象
和Memcached类似,它支持存储的value类型相对很多其它,包含string(字符串)、list(链表)、set(集合)和zset(有序集合)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作。
4 Redis与memcache的最大差别
Replication(树形)
data types(String、Lists、Sorted Sets、Hashes) persistence (snapshot、aof)
非常多开发人员都觉得Redis不可能比Memcached快,Memcached全然基于内存,而Redis具有持久化保存特性,即使是异步的,Redis也不可能比Memcached快。可是測试结果基本是Redis占绝对优势。一直在思考这个原因,眼下想到的原因有这几方面。
Libevent。和Memcached不同,Redis并没有选择libevent。Libevent为了迎合通用性造成代码庞大(眼下Redis代码还不到libevent的1/3)及牺牲了在特定平台的不少性能。Redis用libevent中两个文件改动实现了自己的epoll event loop(4)。业界不少开发人员也建议Redis