redis相关命令详解及其原理

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: redis相关命令详解及其原理

       redis是远程字典服务,客户端与redis服务通过tcp通信,远程字典服务可以想象成redis服务提供了unordered_map<string, T>的容器,key是string,value是T,T类型有多种数据结构;redis服务访问是请求回应模型;

       redis是内存数据库,数据都在内存中,不可能出现数据不在内存中,而磁盘中有数据;

       redis是kv数据库,kv数据库描述了redis的操作方式和存储方式;kv是通过散列表来存储和访问的;

       redis是数据结构数据库,也就是kv中的v提供了丰富的数据结构,包括string,list,hash,zset,set;

怎么设计kv

       所有key都是string类型的,如果是单个功能一个key,我们通常取有意义的名字;如果是相同功能有多个key(set role:10001 100形式的kv),以:作为分割,构成树状图;

       value提供了丰富的数据结构,每一个value都可以指向不同的结构;比如string结构的二进制安全字符串;hash结构;有序双向循环链表结构;set无序集合结构,对顺序不关注,里面的值都是唯一的;有序集合zset结构,对顺序是关注的,里面的值是唯一的,根据member来确定唯一,根据score来确定有序;

hash结构操作

有序双向循环链表结构结构操作

有序集合zset结构操作

bit运算

redis存储结构

       key是string字符串,字符串长度小于等于32,则对于sdshdr8;在二进制字符串的实现中,我们是以长度进行分割的,所有sdshdr8结构中有个len标记二进制字符串的长度,alloc是分配的长度频繁分配内存,flags说明字符串类型,比如长度是32,还是64;buf是柔性数组,初始不占用空间;

redis的抽象层次

       1)关注命令的参数含义;

       2)关注命令的返回具体值;

       3)redis没有创建数据结构的命令,是设置和添加的同时创建;

       4)redis有删除kv的命令,如果v中没有元素会自动删除kv;

       5)有阻塞连接的概念brpop;

       6)通过命令组合实现其他数据结构;

       7)通过组合数据结构实现功能;hash+list,hash+zset;

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
1天前
|
存储 NoSQL Redis
深入浅出Redis(零):Redis常用命令的使用
深入浅出Redis(零):Redis常用命令的使用
|
1天前
|
存储 NoSQL 关系型数据库
深入浅出Redis(十二):Redis的排序命令Sort
深入浅出Redis(十二):Redis的排序命令Sort
|
1天前
|
负载均衡 NoSQL 关系型数据库
深入浅出Redis(六):Redis的主从架构与主从复制原理
深入浅出Redis(六):Redis的主从架构与主从复制原理
|
2天前
|
NoSQL Linux Redis
Redis的介绍,以及Redis的安装(本机windows版,虚拟机Linux版)和Redis常用命令的介绍
Redis的介绍,以及Redis的安装(本机windows版,虚拟机Linux版)和Redis常用命令的介绍
15 0
|
6天前
|
存储 NoSQL 定位技术
Redis常用数据类型及常用命令
这些是Redis中常用的数据类型和命令。Redis还提供了许多其他命令和功能,用于数据存储、操作和查询。你可以根据需要选择适当的数据类型和命令来满足你的应用程序需求。
20 4
|
11天前
|
监控 NoSQL 算法
深入剖析Redis哨兵模式的原理和应用
Redis的哨兵模式是实现高可用性和自动故障转移的机制,当主服务器故障时,哨兵能自动检测并进行故障转移,确保服务连续和稳定性。哨兵模式通过监控主从服务器状态、自动故障转移、防止数据不一致,提高容错能力和负载均衡,降低运维成本,实现高可用性。哨兵通过检测主观下线和客观下线状态,以及选举Leader Sentinel来协调故障转移。Raft算法在其中用于领导者选举和状态一致性。哨兵模式通过综合考虑多种因素选举新主服务器并执行故障转移,保障集群稳定运行。
44 0
深入剖析Redis哨兵模式的原理和应用
|
15天前
|
NoSQL Redis
Redis入门到通关之Redis主从数据同步原理
Redis入门到通关之Redis主从数据同步原理
25 0
|
15天前
|
存储 NoSQL Redis
Redis入门到通关之Redission原理
Redis入门到通关之Redission原理
20 0
|
15天前
|
存储 NoSQL Java
Redis入门到通关之ZSet命令
Redis入门到通关之ZSet命令
18 0
|
15天前
|
存储 缓存 NoSQL
Redis入门到通关之Set命令
Redis入门到通关之Set命令
18 0