随笔分类 - 数据库 / Redis
发表于 2023-10-06 18:36阅读:97评论:0推荐:1
摘要:为了满足用户对一趟列车不同站点不同座位类型的余量查询需求,我们采取了一种优化方案。我们将这些余量信息存储在缓存中,以便用户可以快速查询。 然而,在用户创建订单并完成支付时,我们需要同时从数据库和缓存中扣减相应的列车站点余票。这种设计不仅提高了查询效率,也保证了数据的一致性,确保订单操作的准确性。在这个业务场景中的缓存与数据库一致性如何保证?
阅读全文 »
发表于 2023-10-06 18:34阅读:38评论:0推荐:0
摘要:分布式锁相信大家一定不会陌生,想要用好或者自己写一个却没那么简单。想要达到上述的条件,一定要 **掌握分布式锁的应用场景**,以及分布式锁的不同实现,不同实现之间有什么区别。
阅读全文 »
发表于 2023-09-10 19:39阅读:41评论:0推荐:0
摘要:【引入】 【1】为什么要使用分布式锁 我们在开发应用的时候,如果需要对某一个共享变量进行多线程同步访问的时候,可以使用我们学到的锁进行处理,并且可以完美的运行,毫无Bug! 注意这是单机应用,后来业务发展,需要做集群,一个应用需要部署到几台机器上然后做负载均衡,大致如下图: 上图可以看到 变量A存在
阅读全文 »
发表于 2023-09-10 14:16阅读:13评论:0推荐:0
摘要:【一】Redis介绍与安装 什么是Redis 非关系型数据库和关系型数据库 Redis的特点 Redis的安装 Redis的连接与停止 【二】Redis使用 Redis普通连接与连接池 Redis之字符串操作 Redis之hash类型操作 Redis之列表操作 Redis之其他操作 Redis之管道
阅读全文 »
发表于 2023-09-10 13:38阅读:70评论:0推荐:0
摘要:【一】缓存的收益与成本 【1】受益 1 加速读写 2 降低后端负载:后端服务器通过前端缓存降低负载,业务端使用redis降低后端mysql负载 【2】成本 1 数据不一致:缓存层和数据层有时间窗口不一致,和更新策略有关 2 代码维护成本:多了一层缓存逻辑 3 运维成本:比如使用了Redis Clus
阅读全文 »
发表于 2023-09-10 13:38阅读:55评论:0推荐:0
摘要:【一】主从复制 【1】引入 原因 : redis 单实例 机器故障;容量瓶颈;QPS瓶颈 主从复制:一主一从,一主多从 做读写分离 做数据副本 扩展数据性能 一个master可以有多个slave 一个slave只能有一个master 数据流向是单向的,从master到slave 【2】主从原理 主从
阅读全文 »
发表于 2023-09-10 13:37阅读:176评论:0推荐:0
摘要:【一】Redis持久化 【1】什么是持久化 redis的所有数据保存在内存中,对数据的更新将异步的保存到硬盘上 持久化是指将Redis的数据保存到硬盘上,以确保数据在重启、断电等异常情况下的持久性。 Redis提供了三种持久化方式:RDB、AOF和混合持久化。 【2】持久化的实现方式 数据库(mys
阅读全文 »
发表于 2023-09-10 13:37阅读:131评论:0推荐:0
摘要:【一】慢查询 【1】生命周期 我们配置一个时间,如果查询时间超过了我们设置的时间,我们就认为这是一个慢查询. 慢查询发生在第三阶段 客户端超时不一定慢查询,但慢查询是客户端超时的一个可能因素 慢查询是指执行时间超过预设阈值的数据库查询语句。在慢查询的生命周期中,以下是一般的流程: 客户端发送查询请求
阅读全文 »
发表于 2023-09-10 13:36阅读:55评论:0推荐:0
摘要:【图解Redis数据结构】 【Redis单线程架构】 【1】单线程架构 一个瞬间只会执行一条命令 Redis的主要任务是处理来自客户端的请求并执行命令。 在任意时刻,Redis只会处理一条命令,通过串行执行命令保证了数据的一致性。 Redis在内部使用事件驱动(epoll)的非阻塞I/O模型,以提高
阅读全文 »
发表于 2023-09-10 13:36阅读:44评论:0推荐:0
摘要:【一】使用场景 缓存系统:使用最广泛的就是缓存 计数器:网站访问量,转发量,评论数(文章转发,商品销量,单线程模型,不会出现并发问题) 消息队列:发布订阅,阻塞队列实现(简单的分布式,blpop:阻塞队列,生产者消费者) 排行榜:有序集合(阅读排行,点赞排行,推荐(销量高的,推荐))有序集合 社交网
阅读全文 »
发表于 2023-09-10 13:36阅读:84评论:0推荐:0
摘要:【一】Redis是什么 【1】介绍 开源:早起版本2w3千行 基于键值对的存储系统:字典形式 多种数据结构:字符串,hash,列表,集合,有序集合 高性能,功能丰富 Redis(Remote Dictionary Server)是一个开源的,基于键值对的存储系统。 它采用了字典形式进行数据存储,支持
阅读全文 »
发表于 2023-09-10 13:36阅读:33评论:0推荐:0
摘要:【一】redis普通链接和连接池 【1】普通链接 from redis import Redis # 建立redis连接 conn = Redis( host='127.0.0.1', # IP port=6379, # 端口 db=0, # 数据库 decode_responses=True #
阅读全文 »
发表于 2023-09-10 13:36阅读:139评论:0推荐:0
摘要:【一】什么是Redis Redis :软件,存储数据的,速度非常快,redis是一个key-value存储系统(没有表的概念),cs架构的软件 服务端 客户端(python作为客户端,java,go,图形化界面,命令窗口的命令) Redis(Remote Dictionary Server)是一个开
阅读全文 »
发表于 2023-07-13 19:10阅读:65评论:0推荐:0
摘要:# 数据库的范式设计 > 原文链接:[(三)MySQL之库表设计篇:一、二、三、四、五范式、BC范式与反范式详解! - 掘金 (juejin.cn)](https://juejin.cn/post/7146474739018498062?searchId=20230713184928E6591E17
阅读全文 »
发表于 2023-04-25 09:06阅读:325评论:0推荐:0
摘要:Redis 报错总结一 Invalid argument during startup: Failed to open the .conf file: redis.window.conf 【1】cmd运行redis-server.exe redis.windows.conf 报错:提示找不到配置文件
阅读全文 »