认识Redis与Redis的数据结构
本文作为Redis的通识教程,旨在让大家对Redis有一个概念性和整体性的认识,并且可以快速上手,为深入Redis打下基础。
文章概要:
- Redis的介绍
- Redis与其他数据库的对比
- Redis与其他缓存实现对比
- Redis的数据结构类型
- Redis命令操作几种数据类型
- Spring Data Redis操作几种数据类型
- ZSET(有序集合)保证顺序
- SET(集合)随机获取元素
Redis的介绍
Redis是一种非关系型数据库(non-relational database, 简称nosql)。
Redis是一个远程内存数据库,Redis客户端可以通过TCP协议请求服务端。
Redis性能强劲,且支持持久化和复制,可以方便地存储和读取海量数据。
那么Redis到底有多快? Redis 自带了一个叫 redis-benchmark 的工具来模拟 N 个客户端同时发出 M 个请求,你可以使用 redis-benchmark -h 来查看参数。
下面测试了100万次SET和GET操作的性能:
$ redis-benchmark -n 1000000 -t set,get -P 16 –q
SET: 198098.27 requests per second
GET: 351988.72 requests per second
Redis与其他数据库的对比
如果仅仅局限于一处,容易“只见树木,不见森林”,或者“手里那个锤子,看什么都像钉子”。
因此,我们首先与市场上常用的数据库系统做下横向对比,这样你可以更直观地感受Redis的特点。
Redis与其他缓存实现对比
同时Redis作为常用的缓存实现,我们也比较一下常用的缓存实现的优缺点。
Redis的数据类型
Redis 5 带来了新的流数据类型(Stream data type),在这之前,Redis可以存储键(key)与5种不同数据结构类型之间的映射,这5种数据结构类型分别为STRING(字符串)、LIST(列表)、SET(集合)、HASH(散列)和ZSET(有序集合)。
分享更多关于 Linux后端开发网络底层原理知识学习提升 ,完善技术栈,内容知识点包括Linux,Nginx,ZeroMQ,MySQL,Redis,线程池,MongoDB,ZK,Linux内核,CDN,P2P,epoll,Docker,TCP/IP,协程,DPDK等等。学习视频点击:C/C++Linux后台服务器开发高级架构师学习视频
Redis 5种数据类型概览
编号 |
结构类型 |
结构存储的值 |
结构的读写能力 |
1 |
STRING |
字符串、整数、浮点数 |
对整个字符串或者字符串的其中一部分执行操作;对整数和浮点数执行自增(increment)或者自减(decrement)操作 |
2 |
LIST |
一个链表,链表上的每个节点都包含了一个字符串 |
从链表的两端推入或者弹出元素(队列操作);根据偏移量对链表进行修剪(trim);读取单个或者多个元素;根据值查找或者移除元素 |
3 |
SET |
包含字符串的无序收集器(unordered collection)且不可重复 |
添加、获取、移除单个元素;检查一个元素是否存在于集合中;计算交集、并集、差集;从集合里面随机获取元素 |
4 |
HASH |
包含键值对的无序散列表 |
添加、获取、移除单个键值对;获取所有键值 |
5 |
ZSET |
字符串成员(member)与浮点数分值(score)之间的有序映射,元素的排列顺序由分值的大小决定 |
添加、获取、删除单个元素;根据分值范围(range)或者成员来获取元 |
Redis命令操作5种数据类型
STRING命令
字符串操作
对于字符串,Redis支持最基础的SET GET 和 DEL操作。也支持很多复杂的操作,下面简要介绍一下。
编号 |
命令 |
描述 |
1 |
SET key value |
设置指定 key 的值 |
2 |
GET key |
获取指定 key 的值 |
3 |
DEL key |
删除此key以及其对应的value,这个命令对5种数据类型都适用 |