目录前言解决方案关闭程序时的异常参考前言用 Redisson + Redis做了个延迟队列,但是我重启之后居然不消费到期的数据了,非要我再往队列新增一条才开始消费。blockingDeque.take()一直阻塞状态。解决方案之前是这样写的。public boolean delayOffer(RedisDelayQueueMessage msg, long time, TimeUnit timeU
转载 2023-06-08 14:36:15
522阅读
分布式锁1)阻塞锁:尝试在redis中创建一个字符串结构缓存,方法传入的key,value为锁的过期时间timeout的时间戳。 若redis中没有这个key,则创建成功(即抢到锁),然后立即返回。 若已经有这个key,则先watch,然后校验value中的时间戳是否已经超过当前时间。 若已超过,则尝试使用提交事务的方式覆盖新的时间戳,事务提交成功(即抢到锁),然后立即返回; 若未超过当前时间或事
转载 2023-07-10 19:19:16
162阅读
# Redis Proxy: A Guide to Building and Implementing ## Introduction Redis is an open-source, in-memory data structure store. It is widely used for caching, session management, real-time analytics, a
原创 2023-07-29 13:51:02
73阅读
一、AOF(Append Only File)1、AOF是什么以日志的形式来记录每个写操作(增量保存),将Redis执行过的所有写指令记录下来(读操作不记录), 只许追加文件但不可以改写文件,redis启动之初会读取该文件重新构建数据,换言之,redis 重启的话就根据日志文件的内容将写指令从前到后执行一次以完成数据的恢复工作。 2、AOF默认不开启  可以在redis.conf中配置文
转载 2023-08-27 16:48:35
68阅读
前言:参照 《redis深度历险-核心原理与应用实践》一、线程IO模型概述:redis是一个单线程程序,它将所有的数据存储于内存中,所有运算都是内存级别的运算。正因为redis是单线程程序,对于时间复杂度为O(n)的指令需要小心使用。redis使用多路复用来处理客户端连接1. 非阻塞IO阻塞IO: 当我们调用socket读写套接字时,默认是阻塞的,例如read方法需要传递参数n,表示最多读取n个字
转载 2023-08-15 09:33:12
69阅读
redis的网络io和键值对读写都是在主线程中完成,如果主线程上的某个操作耗时很长的话就会导致主线程堵塞。下面这张图列出了可能会导致redis堵塞的几个点。 redis是如何处理这几种场景避免堵塞呢?初略总结大概有这几种种方案:多线程,多进程,io多路复用,渐进式处理。方案场景多线程大键删除,AOF磁盘同步,文件删除,网络io(7.0版本)多进程RDB,AOF重写IO多路复用网络IO渐进式处理哈希
转载 2023-06-14 22:15:07
111阅读
Redis学记笔记 —— (13)阻塞Redis是典型的单线程架构,所有的读写操作都是在一条主线程中完成的。当Redis用于高并发场景时,这条线程就变成了它的生命线。如果出现阻塞,哪怕是很短时间,对于我们的应用来说都是噩梦。导致阻塞问题的场景大致分为内在原因和外在原因:内在原因包括:不合理地使用API或数据结构、CPU饱和、持久化阻塞 等。外在原因包括:CPU竞争、内存交换、网络问题等。1.1 发
转载 2023-08-30 08:50:45
99阅读
作者:鸭血粉丝哎,最近阿粉又双叒叕犯事了。事情是这样的,前一段时间阿粉公司生产交易偶发报错,一番排查下来最终原因是因为 Redis 命令执行超时。可是令人不解的是,生产交易仅仅使用 Redis set 这个简单命令,这个命令讲道理是不可能会执行这么慢。那到底是什么导致这个问题那?为了找出这个问题,我们查看分析了一下 Redis 最近的慢日志,最终发现耗时比较多命令为 keys XX*
Redis是典型的单线程架构,所有的读写操作都是在一条主线程中完成的。当Redis用于高并发场景时,这条线程就变成了它的生命线。如果出现阻塞,哪怕是很短时间,对于应用来说都是噩梦。导致阻塞问题的原因:内在原因:不合理地使用API或数据结构、CPU饱和、持久化阻塞等外在原因:CPU竞争、内存交换、网络问题等一、发现阻塞应用方加入异常监控,如日志系统,比如Java语言中的logback或log4jRe
转载 2023-06-15 22:08:22
178阅读
redis remote dictionary service  远程字典服务Redis是一个开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及   zset(sorted se
转载 2023-07-07 01:16:47
38阅读
目录 一、普通队列使用redis的命令来模拟普通队列使用lpush命令生产消息:使用rpop命令消费消息:使用Java代码来实现普通队列:生产者SingleProducer消费者SingleConsumer:二、Redis阻塞队列使用redis的brpop命令来模拟阻塞队列Java阻塞队列生产者实现如下:Java阻塞队列消费者实现如下:三、Redis延迟队列下面使用redis的zset来
Redis中的阻塞Redis作为一个高性能的缓存中间件,在进行网络IO以及键值对读写时仅仅使用的单线程,如果产生阻塞将无法正常响应客户端,所以我们需要了解Redis中到底存在哪些阻塞操作,我们可以按照Redis的关联对象分为如下四种大类。客户端:键值对的增删改查、网络IO、数据库级别的操作(FLUSHALL、FLUSHDB)。磁盘:持久化操作RDB快照、AOF追加日志、AOF日志重写。主从节点:
转载 2023-06-15 21:57:58
191阅读
Redis是典型的单线程架构,所有的读写操作都是在一条主线程中完成的。当Redis用于高并发场景时,这条线程就变成了它的生命线。如果出现阻塞,哪怕是很短时间,对于应用来说都是噩梦。导致阻塞问题的场景大致分为内在原因和外在原因: 内在原因包括:不合理地使用API或数据结构、CPU饱和、持久化阻塞等。外在原因包括:CPU竞争、内存交换、网络问题等。1、发现阻塞Redis阻塞时,线上应用服务应该最先感
转载 2023-06-25 22:09:06
0阅读
Redis服务端对于命令的处理是单线程的,但是在I/O层面却可以同时面对多个客户端并发的提供服务,并发到内部单线程的转化通过多路复用框架实现一个IO操作的完整流程是数据请求先从用户态到内核态,也就是操作系统层面,然后再调用操作系统提供的API,调用相应的设备去获取相应的数据。当相应的设备准备好数据后,会将数据复制到内核态。数据从相应的设备到内核态的处理方式分为:阻塞和非阻塞阻塞:用户请求会等待数
转载 2023-09-17 18:27:05
82阅读
Redis阻塞主线程的问题Hi,我是阿昌,今天学习记录的内容是Redis阻塞主线程的问题。Redis 之所以被广泛应用,很重要的一个原因就是它支持高性能访问。也正因为这样,我们必须要重视所有可能影响 Redis 性能的因素(例如命令操作、系统配置、关键机制、硬件配置等),不仅要知道具体的机制,尽可能避免性能异常的情况出现,还要提前准备好应对异常的方案。影响 Redis 性能的 5 大方面的潜在因素
转载 2023-07-13 14:42:58
72阅读
1.什么是RedisRedis是一种使用C语言编写的高性能键值对key-value形式存储的非关系型数据库,Redis支持五种数据类型:字符串、列表、集合、散列表、有序集合,Redis中的键类型只能是字符串类型。 Redis的数据存储在缓存中,所以读写速度快,每秒可以处理10万次读写操作,Redis经常用来做分布式锁,除此之外Redis支持事务、持久化、LUA脚本、LRU驱动事件、多种集群
转载 2023-08-31 10:13:50
121阅读
 前言Redis是一种基于键值对(Key-Value)的NoSQL数据库,Redis的Value可以由String,hash,list,set,zset,Bitmaps,HyperLogLog等多种数据结构和算法组成。Redis还提供了键过期,发布订阅,事务,Lua脚本,哨兵,Cluster等功能。Redis执行命令的速度非常快,根据官方给的性能可以达到10w+qps。那么本文主要介绍到
转载 2023-08-22 17:16:14
32阅读
redis的简介:     redis是一种非关系型数据库,采用k-v键值对的形式存储,也可以做缓存,是一种基于内存的数据库,因此,redis的存储数据很快,官方数据每秒读速度达到11万次,写8万次,所以读写速度不是redis的瓶颈,redis采用了单线程。redis的基本用法 5中基本类型:string list set  sortse
作者:Haiger最近一位朋友问到:既然Redis是单线程的工作模式,那像BLPOP这样的阻塞操作又是然后实现的呢?接下来分别从服务端和客户端来阐述这一逻辑的实现原理。Redis Server: redis实现了一套事件触发模型,主要处理两种事件:I/O事件(文件事件)和定时事件。而处理它们的就靠一个EventLoop线程。同时redis还提供了丰富的数据结构,今天我们要分析的主要是List数据结
转载 2023-08-24 20:58:28
249阅读
## 实现Redis Cluster Proxy的步骤 为了教会新人如何实现Redis Cluster Proxy,我们需要按照以下步骤进行操作。首先,让我们来看一下整个实现过程的流程图: | 步骤 | 操作 | | ---- | ---- | | 1 | 连接到Redis集群 | | 2 | 接受客户端请求 | | 3 | 解析请求 | | 4 | 路由请求 | | 5 | 转发请求到对应的
原创 2023-07-28 07:25:10
185阅读
  • 1
  • 2
  • 3
  • 4
  • 5