什么是Redis
Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。
Redis特性
更多的数据结构
Redis支持的数据格式有String、List、Set、Sorted Set、Hash。
这里的区别用一张表阐述:
持久化
Redis将数据存储于内存中,或被配置为使用虚拟内存。
Redis的所有数据都是保存在内存中,然后不定期的通过异步方式保存到磁盘上(这称为“半持久化模式”);也可以把每一次数据变化都写入到一个append only file(aof)里面(这称为“全持久化模式”)。
主从同步
主从机器同步更新,多台机器同时存储数据和状态,彼此交换消息来保持数据一致性。
高性能
Redis能读的速度是110000次/s,写的速度是81000次/s 。(官方的bench-mark数据)
Java中使用Redis
要导入Jedis的jar包:
<!-- https://mvnrepository.com/artifact/redis.clients/jedis -->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.9.0</version>
</dependency>
Spring中集成的Redis
pom文件
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-redis</artifactId>
<version>1.7.2.RELEASE</version>
</dependency>
<dependency>
Redis与Memcached对比
Redis和Memcached对比:
集群示意对比:
memcached的服务器端互相完全独立,客户端通常通过对键值应用hash算法决定数据的分区,为了减少服务器的增减对hash结果的影响,导致大面积的缓存失效,多数客户端实现了一致性hash算法。
Redis集群化在不同公司有不同的实现,有的通过比如Codis Proxy的代理,zookeeper的管理,可实现跟memcached一样的功能结构,不过Redis本身还是会通过节点间的自通信来保持node间的数据一致性,关于性能这块,redis本身会将不常用的数据存储到DB中。
Redis思维导图
最后奉上一张在菜鸟学习Redis过程中所画的一张思维导图,有点大,但是比较详细的说…..
链接:http://pan.baidu.com/s/1bplQH1H 密码:7wmp