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
目录
相关文章
|
16天前
|
NoSQL Redis 数据库
Redis的全局命令及相关误区
Redis的全局命令及相关误区
22 0
|
25天前
|
NoSQL Redis 数据库
Redis中的常用命令有哪些?
Redis常用命令包括:PING测试连接,ECHO回显,SELECT切换数据库,QUIT关闭连接;KEYS查找key,EXISTS检查存在,DEL删除key,EXPIRE设置过期时间,TTL查看剩余生存时间,TYPE检测数据类型;STRING操作如SET/GET/MSET/MGET,INCR/DECR增减计数;HASH命令如HSET/HGET/HMSET/HMGET/HGETALL管理字段;LIST操作如LPUSH/RPUSH/LPOP/RPOP/LRANGE;
10 0
|
30天前
|
NoSQL Redis
Redis集群(六):集群常用命令及说明
Redis集群(六):集群常用命令及说明
194 0
|
1天前
|
NoSQL Redis
Redis入门到通关之Redis主从数据同步原理
Redis入门到通关之Redis主从数据同步原理
|
1天前
|
存储 缓存 NoSQL
Redis入门到通关之Hash命令
Redis入门到通关之Hash命令
|
1天前
|
存储 缓存 NoSQL
Redis入门到通关之String命令
Redis入门到通关之String命令
|
8天前
|
存储 NoSQL Java
Redis 命令
Redis 命令
145 0
|
16天前
|
运维 NoSQL 算法
Java开发-深入理解Redis Cluster的工作原理
综上所述,Redis Cluster通过数据分片、节点发现、主从复制、数据迁移、故障检测和客户端路由等机制,实现了一个分布式的、高可用的Redis解决方案。它允许数据分布在多个节点上,提供了自动故障转移和读写分离的功能,适用于需要大规模、高性能、高可用性的应用场景。
16 0
|
19天前
|
NoSQL Redis 数据库
通过migrate命令实现两个redis实例之间的数据迁移
通过migrate命令实现两个redis实例之间的数据迁移
|
28天前
|
存储 NoSQL Redis
作者推荐 |【Redis技术进阶之路】「原理系列开篇」揭秘高效存储模型与数据结构底层实现(SDS)(三)
作者推荐 |【Redis技术进阶之路】「原理系列开篇」揭秘高效存储模型与数据结构底层实现(SDS)
31 0

热门文章

最新文章