Redis基础介绍

  • Redis基本概念
  • Redis是单线程
  • Redis的基本类型与操作
  • 基本类型
  • 字符串——string
  • 列表——list
  • 集合——set
  • 哈希——hash
  • 有序集合——zset
  • 基本操作
  • 切换数据库
  • 查看所有的key
  • 查看数据库大小
  • 清除数据库


Redis基本概念

Redis是一个开源的(BSD协议),内存中的数据结构存储系统,可以用来作为数据库,缓存和消息中间件。

支持多种类型的数据结构,如 字符串(strings),散列(hashes), 列表(lists), 集合(sets),有序集合(sorted sets)与范围查询,如:bitmaps,hyperloglogs 和地理空间(geospatial)索引半径查询。

Redis 内置了复制(replication),LUA脚本(Lua scripting), LRU驱动事件(LRU eviction),事务(transactions)和不同级别的磁盘持久化(persistence)–RDB和AOP, 并通过Redis哨兵(Sentinel)和自动分区(Cluster)提供高可用性(high availability)。

Redis中的数据存放在内存中,也提供了Redis的持久化的方式——数据存储到磁盘,以key-value形式存储,提供丰富的数据类型可以使用多种开发场景(支持String、list、set、hash等数据结构)。

Redis性能极高,redis 写8w/s,读 11W/s。(注:W/s:万次/秒)
Redis具有原子性(单条命令的执行),但事务没有原子性
Redis支持数据备份,集群高可用的功能

Redis是单线程

Redis是基于内存操作的,CPU不是Redis的性能瓶颈,Redis的瓶颈是机器的内存和网络带宽。Redis的数据存放在内存中,因此单线程去操作效率是最高的,相比多线程,减少了CPU上下文切换的耗时,对于内存系统而言,没有上下文切换的效率是最高的,多次读写都是在同一个CPU中。

Redis的基本类型与操作

基本类型

字符串——string

这个不多介绍,想必大家对这个类型已经很了解了。

列表——list

类似于linkedlist链表结构,可以添加元素到列表的头部或者是尾部,同样头部和尾部都可以进行获取,可以用来作为栈、队列、阻塞队列

列表中的命令都是以L开头的(大小写均可)。

集合——set

set中元素是不能重复的,set实现是基于哈希表结构实现,在修改、添加等操作复杂度是O(1)。

集合中命令都是以S开头的

哈希——hash

hash是一个map集合,是key-value的map集合。

哈希中的命令都是以h开头的

有序集合——zset

每个元素都会关联一个double类型的分数,Redis正是通过分数为集合中的成员进行从小到大的排序

有序集合的成员是唯一的,但分数是可以重复。

有序集合中的命令都是以z开头的。

基本操作

Redis默认是有16个数据库,默认使用的是第0个数据库,范围是(0-15)可以通过select 切换数据库,Redis的命令大小写不敏感的(不区分大小写)。

小提示:输入命令时,可以通过按tab键,快速自动匹配命令,输入越多,匹配越准确。

切换数据库

默认是0,端口号后面有显示,没显示则是0。

切换数据库的命令格式:select index(index为数据库编号,0-15,方括号中的数字)。

选择第15个数据库

redis 查看键分布 redis查看内容_redis 查看键分布


如果超出范围,则会显示以下错误:

redis 查看键分布 redis查看内容_数据结构_02

查看所有的key

查看所有的key的命令格式:keys *

redis 查看键分布 redis查看内容_redis 查看键分布_03

查看数据库大小

查看数据库大小的命令格式:dbsize

redis 查看键分布 redis查看内容_数据结构_04


可以看出,有8个key,因此,DBSIZE显示的数字为8,是当前数据库中key的个数

清除数据库

清空当前的数据库 格式:flushdb

redis 查看键分布 redis查看内容_数据结构_05


清空所有的数据库 格式:flushall。(此处不做举例演示)