Redis是一款高性能的NOSQL系列的非关系型数据库。

Redis是用C语言开发的一个开源的高性能键值对(key-value)数据库,官方提供测试数据,50个并发执行100000个请求,读的速度是110000次/s,写的速度是81000次/s ,且Redis通过提供多种键值数据类型来适应不同场景下的存储需求,目前为止Redis支持的键值数据类型如下:
1) 字符串类型 string
2) 哈希类型 hash
3) 列表类型 list
4) 集合类型 set
5) 有序集合类型 sortedset

redis的应用场景

  1. 缓存(数据查询、短连接、新闻内容、商品内容等等)<br /> 聊天室的在线好友列表<br /> 任务队列。(秒杀、抢购、12306等等): list<br /> 应用排行榜: sortedset<br /> 网站访问统计<br /> 数据过期处理(可以精确到毫秒)<br /> 分布式集群架构中的session分离<br />![image.png](https://cdn.nlark.com/yuque/0/2021/png/10379114/1618915707133-5d25e3ba-52fa-46aa-8fa4-bf83080e68e9.png#align=left&display=inline&height=295&margin=%5Bobject%20Object%5D&name=image.png&originHeight=590&originWidth=1750&size=51910&status=done&style=none&width=875)

下载安装

  1. 1. 官网:[https://redis.io](https://redis.io)<br /> 2. 中文网:[http://www.redis.net.cn/](http://www.redis.net.cn/)<br /> 3. 解压直接可以使用:<br /> * redis.windows.conf:配置文件<br /> * redis-cli.exe:redis的客户端<br /> * redis-server.exe:redis服务器端

redis的数据结构

redis存储的是:key,value格式的数据,其中key都是字符串,value有5种不同的数据结构:
1) 字符串类型 string
2) 哈希类型 hash : map格式
3) 列表类型 list : linkedlist格式。支持重复元素
4) 集合类型 set : 不允许重复元素
5) 有序集合类型 sortedset:不允许重复元素,且元素有顺序
image.png

redis 操作命令

1. 字符串类型 string

  1. 存储: set
  2. 获取: get
  3. 删除: del

    1. 127.0.0.1:6379> set username zhangsan
    2. OK
    3. 127.0.0.1:6379> get username
    4. "zhangsan"
    5. 127.0.0.1:6379> del age
    6. (integer) 1

    2. 哈希类型 hash

  4. 存储: hset

  5. 获取:
    • hget : 获取指定的field对应的值
    • hgetall :获取所有的field和value
  6. 删除: hdel ``` 127.0.0.1:6379> hset myhash username lisi (integer) 1 127.0.0.1:6379> hset myhash password 123 (integer) 1

127.0.0.1:6379> hget myhash username “lisi” 127.0.0.1:6379> hgetall myhash 1) “username” 2) “lisi” 3) “password” 4) “123”

127.0.0.1:6379> hdel myhash username (integer) 1

  1. <a name="ciZsC"></a>
  2. ### 3. 列表类型 list:可以添加一个元素到列表的头部(左边)或者尾部(右边)
  3. 1. 添加:
  4. 1. **lpush** <key> <value>: 将元素加入列表左表
  5. 1. **rpush** <key> <value>:将元素加入列表右边<br />
  6. 2. 获取:
  7. - **lrange** <key> <start> [end] :范围获取<br />
  8. 3. 弹出并删除:
  9. - **lpop** <key>: 删除列表最左边的元素,并将元素返回
  10. - **rpop** <key>: 删除列表最右边的元素,并将元素返回

127.0.0.1:6379> lpush myList a (integer) 1 127.0.0.1:6379> lpush myList b (integer) 2 127.0.0.1:6379> rpush myList c (integer) 3

0 -1 表示所有

127.0.0.1:6379> lrange myList 0 -1 1) “b” 2) “a” 3) “c”

  1. <a name="scTO2"></a>
  2. ### 4. 集合类型 set : 不允许重复元素
  3. 1. 存储:**sadd** <key> <value>: 向 set 集合 key 中添加一个元素 value<br />
  4. 1. 获取:**smembers** <key>: 获取set集合中所有元素<br />
  5. 1. 删除:**srem** <key> <value>: 删除set集合中的某个元素 <br />

127.0.0.1:6379> sadd myset a (integer) 1 127.0.0.1:6379> sadd myset a (integer) 0

127.0.0.1:6379> smembers myset 1) “a”

127.0.0.1:6379> srem myset a (integer) 1

  1. <a name="TmjEi"></a>
  2. ### 5. 有序集合类型 sortedset:
  3. - 不允许重复元素,且元素有顺序.
  4. - 每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
  5. 1. 存储:**zadd** <key> <score> <value><br /> 2. 获取:**zrange** <key> <start> <end> [withscores]<br /> 3. 删除:**zrem** <key> <value>

127.0.0.1:6379> zadd mysort 60 zhangsan (integer) 1 127.0.0.1:6379> zadd mysort 50 lisi (integer) 1 127.0.0.1:6379> zadd mysort 80 wangwu (integer) 1

127.0.0.1:6379> zrange mysort 0 -1 1) “lisi” 2) “zhangsan” 3) “wangwu”

127.0.0.1:6379> zrange mysort 0 -1 withscores 1) “zhangsan” 2) “60” 3) “wangwu” 4) “80” 5) “lisi” 6) “500”

127.0.0.1:6379> zrem mysort lisi (integer) 1

  1. <a name="vyLfY"></a>
  2. ### 6. 通用命令
  3. 1. `keys *` : 查询所有的键<br /> 2. `type <key>` : 获取键对应的value的类型<br /> 3. `del <key>`:删除指定的key value
  4. <a name="8w8Vi"></a>
  5. ## 持久化
  6. 1. redis是一个内存数据库,当redis服务器重启,获取电脑重启,数据会丢失,我们可以将redis内存中的数据持久化保存到硬盘的文件中。
  7. 1. redis持久化机制:
  8. 1. RDB:**默认方式**,不需要进行配置,默认就使用这种机制
  9. - 在一定的间隔时间中,检测key的变化情况,然后持久化数据
  10. - 这种方式不能保证持久化所有的数据
  11. 1. 编辑redis.windwos.conf文件:

after 900 sec (15 min) if at least 1 key changed

save 900 1

after 300 sec (5 min) if at least 10 keys changed

save 300 10

after 60 sec if at least 10000 keys changed

save 60 10000

  1. 2. 重新启动redis服务器,并指定配置文件名称:<br />`redis-server.exe redis.windows.conf`
  2. b. AOF:日志记录的方式,可以记录每一条命令的操作。可以每一次命令操作后,持久化数据,对性能的影响非常大。
  3. 1. 编辑redis.windwos.conf文件:<br />

appendonly no(关闭aof) —> appendonly yes (开启aof)

appendfsync always : 每一次操作都进行持久化

appendfsync everysec : 每隔一秒进行一次持久化

appendfsync no : 不进行持久化

```