深入理解redis

最近想要手写 一个redis,找到了网上的一门教程,想先跟着过一遍可长城,然后再去复现,具体大概入下

在这里插入图片描述
要理解redis我们主要从核心概念,主要流程,数据结构这三个方面去理解
下图是redis的数据结构部分
在这里插入图片描述
如图,redis1.0也就只有几千行,代码很少,主要有上图的几个包组成,redis.c ,redis-cli.c(redis-client以及redis-server) ae.c(ae事件库),anet.c(ae网络库),zmalloc.c(内存库)
在这里插入图片描述
上图是redis核心概念图
redisclient主要有四个组成部分,fd文件描述符,db是一个指向redisDBList的指针,clients是指向redisClientList的指针,最后是最后一个最核心的事件循环,是指向AeEventLoop的指针
redisServer主要也是四个,fd,db同上queryBuffer主要是用来存储查询请求的,reply是一个指向redisObjectList的指针,用来存储返回值

redis里面有一个RedisDB,是一个很大的字典,并且其中的expire表示其有过期时间,int唯一标识

redisObj的结构非常有意思,他的ptr是一个指向任意类型的指针,type表示指向对象的类型,refcount表示指向对象的引用次数
在这里插入图片描述
redis的核心流程主要分为启动流程以及请求流程两部分
关于为什么不用libevent.C是因为这个包太重了,redis只有几千行没必要再引入一个很重的包
在这里插入图片描述
redis的核心数据结构如上,RedisObj,Dict,adlist

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Redis(Remote Dictionary Server)是一个开源的内存数据结构存储系统,常用作数据库、缓存和消息中间件。它支持多种数据结构,包括字符串、哈希表、列表、集合和有序集合等,并且提供了丰富的功能和灵活的配置选项。 下面是一些深入了解 Redis 的主题: 1. 数据结构:Redis 提供了多种数据结构,每种数据结构都有自己的特点和用途。了解每种数据结构的基本操作和适用场景,可以更好地利用 Redis 的功能。 2. 持久化:Redis 支持两种持久化方式,分别是快照(RDB)和追加日志文件(AOF)。深入了解这两种方式的工作原理、优缺点和配置选项,可以根据实际需求选择合适的持久化方式。 3. 高可用性:Redis 提供了一些机制来提高系统的可用性,如主从复制、哨兵和集群等。了解这些机制的原理和使用方法,可以搭建高可用的 Redis 环境,并保证数据的可靠性和可恢复性。 4. 事务和管道:Redis 支持事务和管道操作,可以将多个操作封装成一个原子操作或批量操作,提高系统的性能和效率。深入了解事务和管道的使用方法和注意事项,可以更好地利用这些特性提升系统的性能。 5. 性能优化:Redis 是一个高性能的存储系统,但在实际使用中仍然有一些性能优化的技巧。了解 Redis 的内部原理和性能指标,可以通过优化配置、合理使用数据结构和命令,提升系统的响应速度和吞吐量。 以上只是 Redis 的一些高级深入了解的主题,如果你有具体的问题或者需要更详细的解答,可以继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

会说话的皮卡丘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值