Redis入门

57 阅读3分钟

什么是Redis

  • 基本概念

    redis是一个开源的、使用C语言编写的、支持网络交互的、可基于内存也可持久化的Key-Value数据库(非关系性数据库)。

  • redis的优势

  1. 速度快,因为数据存在内存中,类似于HashMap,HashMap的优势就是查找和操作的时间复杂度都是O(1)
  2. 支持丰富数据类型,支持string,list,set,sorted set,hash
  3. 支持事务,操作都是原子性,所谓的原子性就是对数据的更改要么全部执行,要么全部不执行
  4. 丰富的特性:可用于缓存,消息,按key设置过期时间,过期后将会自动删除

redis的应用场景

  • 缓存

    (1) 对于一些要返回给前端数据的缓存,当有大量数据库sql操作时候,为了避免每次接口请求都要去查询数据库,可以把一些数据缓存到redis中,这样是直接从内存中获取数据,速度回增快很多。

    (2) web端用户,用于登陆缓存session数据,登陆的一些信息存到session中,缓存到redis中

  • 队列

    redis中提供了list接口,这个list提供了lpush和rpop,这两个方法具有原子性,可以插入队列元素和弹出队列元素。

  • 数据存储

    redis是非关系型数据库,可以把redis直接用于数据存储,提供了增删改查等操作,因为redis有良好的硬盘持久化机制,redis数据就可以定期持久化到硬盘中,保证了redis数据的完整性和安全性。

  • redis锁实现防刷机制

    redis锁可以处理并发问题,redis数据类型中有一个set类型,set类型在存储数据的时候是无序的,而且每个值是不一样的,不能重复,这样就可以快速的查找元素中某个值是否存在,精确的进行增加删除操作。

说明:redis使用场景的基本操作会在redis学习(3)-实战篇中讲解

  • 字符串列表(list) list类型是一个有序的列表,有序表示的是从左到右还是从右到左,而且数据内容是可以重复的。 代码实际操作过程:

  • 字符串集合(set)

    set类型中提供了无序的方式来存储多个不同的元素,set类型中每个元素的值都不一样,用户可以快速对元素中的值添加删除,检查某些值是否存在,重复的元素是无法继续插入集合的。 代码实际操作过程:


-   哈希(hashhash类型也叫散列类型,存储的时候存的是键值对。查询条数的时候只要是健不一样,就是不同的条数,尽管值是相同的。

代码实际操作过程:


-   有序字符串集合(sort set)

sore set也叫有序分数集,可以把它看作一个排行榜,每一个同学都有自己的分数,且排行榜中还有一个排名的属性,排行属性从0,根据分数不断变大,排行也不断变大。 


**sort set特性**

1)sore set中的值是全局唯一的。

一个值设置了之后,再次设置不会增加,只会覆盖修改。

2)如果有两条分数相同,排名应该怎那么看? 如果两个分数值形同,会根据值两个元素变量名的字典排序