目录

1. 什么是Redis?

1.1 Redis定义

1.2 Redis的优势

1.3 Redis与其他key-value存储有什么不同

2. Redis的安装(win10)

2.1 下载安装包

2.2  解压安装包,运行.exe文件,启动Redis,验证Redis基本功能

3. Redis配置

3.1 Redis 的配置文件redis.windows.conf

3.2 查看配置:CONFIG GET CONFIG_SETTING_NAME

3.3 编辑配置:CONFIG SET CONFIG_SETTING_NAME NEW_CONFIG_VALUE

3.4 Redis参数说明

4. Redis数据类型

4.1 String

4.2 Hash

4.3 List

4.4 Set

4.5 Zset


1. 什么是Redis?

1.1 Redis定义

(1)Redis 是完全开源的,遵守 BSD 协议,是一个高性能的 key-value 数据库。

(2)Redis与其他 key-value 缓存产品相比,有以下三个特点:

  • Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启时可再次加载进行使用。
  • Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
  • Redis支持数据的备份,即master-slave模式的数据备份。

1.2 Redis的优势

(1)性能极高 :Redis能读的速度是110000次/s,写的速度是81000次/s 。

(2)丰富的数据类型 :Redis支持二进制案例的Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。

(3)原子 :Redis的所有操作都是原子性的,意思就是要么成功执行,要么失败完全不执行。单个操作是原子性的。多个操作也支持事务,即原子性,通过MULTI和EXEC指令包起来。

,(4)丰富的特性 :Redis还支持 publish/subscribe, 通知, key 过期等等特性。

1.3 Redis与其他key-value存储有什么不同

(1)Redis有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径。Redis的数据类型都是基于基本数据结构的,同时对程序员透明,无需进行额外的抽象。

(2)Redis运行在内存中但是可以持久化到磁盘,所以在对不同数据集进行高速读写时需要权衡内存,因为数据量不能大于硬件内存。在内存数据库方面的另一个优点是,相比在磁盘上相同的复杂的数据结构,在内存中操作起来非常简单,这样Redis可以做很多内部复杂性很强的事情。同时,在磁盘格式方面他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。

2. Redis的安装(win10)

2.1 下载安装包

URL:Releases · tporadowski/redis · GitHub

RedissonClient需要单独配置_Redis

2.2  解压安装包,运行.exe文件,启动Redis,验证Redis基本功能

RedissonClient需要单独配置_数据类型_02

 

RedissonClient需要单独配置_redis_03

3. Redis配置

3.1 Redis 的配置文件redis.windows.conf

Redis 的配置文件位于 Redis 安装目录下,文件名为 redis.conf (Windows 名为 redis.windows.conf)。可以通过 CONFIG 命令查看或设置配置项。

3.2 查看配置:CONFIG GET CONFIG_SETTING_NAME

RedissonClient需要单独配置_数据类型_04

 

RedissonClient需要单独配置_数据类型_05

3.3 编辑配置:CONFIG SET CONFIG_SETTING_NAME NEW_CONFIG_VALUE

RedissonClient需要单独配置_数据类型_06

3.4 Redis参数说明

(redis.conf 配置项说明,详细略 )

4. Redis数据类型

Redis支持五种数据类型

string(字符串)

hash(哈希)

list(列表)

set(集合)

zset(sorted set:有序集合)

4.1 String

(1)string 是 redis 最基本的类型,可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。string 类型是二进制安全的,意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。string 类型是 Redis 最基本的数据类型,string 类型的值最大能存储 512MB。

(2)示例:使用了 Redis 的 SET 和 GET 命令。键是demo1,值是Sheryl. 

RedissonClient需要单独配置_redis_07

RedissonClient需要单独配置_数据类型_08

4.2 Hash

(1)Redis hash 是一个键值(key=>value)对集合。Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。每个 hash 可以存储 232 -1 键值对(40多亿)。

(2)示例:使用了 Redis HMSET, HGET 命令,HMSET 设置了两个 field=>value 对, HGET 获取对应 field 对应的 value

RedissonClient需要单独配置_Redis_09

 

RedissonClient需要单独配置_数据类型_10

4.3 List

(1)Redis List列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。列表最多可存储 232 - 1 元素 (4每个列表可存储40多亿)。

(2)示例:

RedissonClient需要单独配置_redis_11

 

RedissonClient需要单独配置_数据类型_12

4.4 Set

(1)Redis Set 是 string 类型的无序集合。集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。集合中最大的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)。

(2)sadd 命令:添加一个 string 元素到 key 对应的 set 集合中,成功返回 1,如果元素已经在集合中返回 0。sadd key member

(3)示例:示例中we 添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。

RedissonClient需要单独配置_Redis_13

 

RedissonClient需要单独配置_redis_14

4.5 Zset

(1)sorted set:有序集合。Redis zset 和 set 一样也是string类型元素的集合, 且不允许重复的成员。不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。zset的成员是唯一的, 但分数(score)却可以重复。

(2)zadd 命令:添加元素到集合,元素在集合中存在则更新对应score。zadd key score member

(3)示例:

RedissonClient需要单独配置_redis_15