上一页 1 2 3 4 5 6 7 ··· 12 下一页
摘要: 消息堆积问题 当生产者发送消息的速度超过了消费者处理消息的速度,就会导致队列中的消息堆积,直到队列存储消息达到上限。之后发送的消息就会成为死信,可能会被丢弃,这就是消息堆积问题。 ![](https://img2023.cnblogs.com/blog/3120037/202306/3120037- 阅读全文
posted @ 2023-06-28 23:18 xycccode 阅读(22) 评论(0) 推荐(0) 编辑
摘要: 当一个队列中的消息满足下列情况之一时,可以成为死信(dead letter): 消费者使用basic.reject或 basic.nack声明消费失败,并且消息的requeue参数设置为false 消息是一个过期消息,超时无人消费 要投递的队列消息满了,无法投递 如果这个包含死信的队列配置了`dea 阅读全文
posted @ 2023-06-28 20:54 xycccode 阅读(16) 评论(0) 推荐(0) 编辑
摘要: 我们都知道消息在消费者端消费的时候,如果消费端出现异常,那么它会依据spring的重试机制进行重试,达到最大重试次数后,消息会被丢弃,这是由Spring内部机制决定的。 在开启重试模式后,重试次数耗尽,如果消息依然失败,则需要有MessageRecovery接口来处理,它包含三种不同的实现: Rej 阅读全文
posted @ 2023-06-28 18:13 xycccode 阅读(403) 评论(0) 推荐(0) 编辑
摘要: 默认的失败重试机制是有问题的。 当消费者出现异常后,消息会不断requeue(重入队)到队列,再重新发送给消费者,然后再次异常,再次requeue,无限循环,导致mq的消息处理飙升,带来不必要的压力: 怎么办呢? 我们可以利用Spring的retry机制,在消费者出现异常时利用本地重试,而不是无限制 阅读全文
posted @ 2023-06-28 17:44 xycccode 阅读(41) 评论(0) 推荐(0) 编辑
摘要: RabbitMQ是**阅后即焚**机制,RabbitMQ确认消息被消费者消费后会立刻删除。 而RabbitMQ是通过消费者回执来确认消费者是否成功处理消息的:消费者获取消息后,应该向RabbitMQ发送ACK回执,表明自己已经处理消息。 设想这样的场景: - 1)RabbitMQ投递消息给消费者- 阅读全文
posted @ 2023-06-28 17:28 xycccode 阅读(68) 评论(0) 推荐(0) 编辑
摘要: 我们看下之前启动idea测试消息发送的时候在后台生成的一条消息,现在已经在消息队列里面还没有被消费。 现在我们重启下RabbitMQ,执行linux命令:docker restart mq 看上图实时显示的错误信息,失去连接了,接下来刷新这个页面,可以发现这个对象没有了。 说明rabbit消息并不会 阅读全文
posted @ 2023-06-28 17:06 xycccode 阅读(187) 评论(0) 推荐(1) 编辑
摘要: 消息队列在使用过程中,面临着很多实际问题需要思考: 消息从发送,到消费者接收,会经理多个过程: 其中的每一步都可能导致消息丢失,常见的丢失原因包括: 发送时丢失: 生产者发送的消息未送达exchange 消息到达exchange后未到达queue MQ宕机,queue将消息丢失 consumer接收 阅读全文
posted @ 2023-06-27 18:28 xycccode 阅读(15) 评论(0) 推荐(0) 编辑
摘要: Canal [kə'næl],译意为水道/管道/沟渠,canal是阿里巴巴旗下的一款开源项目,基于Java开发。基于数据库增量日志解析,提供增量数据订阅&消费。GitHub的地址:https://github.com/alibaba/canal Canal是基于mysql的主从同步来实现的,MySQ 阅读全文
posted @ 2023-06-27 18:23 xycccode 阅读(68) 评论(0) 推荐(0) 编辑
摘要: 大多数情况下,浏览器查询到的都是缓存数据,如果缓存数据与数据库数据存在较大差异,可能会产生比较严重的后果。 所以我们必须保证数据库数据、缓存数据的一致性,这就是缓存与数据库的同步。 数据同步策略 缓存数据同步的常见方式有三种: 设置有效期:给缓存设置有效期,到期后自动删除。再次查询时更新 优势:简单 阅读全文
posted @ 2023-06-27 17:01 xycccode 阅读(45) 评论(0) 推荐(0) 编辑
摘要: nginx本地缓存需要在nginx.conf文件里面开启本地缓存 lua_shared_dict,用它来设置缓存变量和大小 比如: lua_shared_dict item_cache 150m; 这段代码表示lua_shared_dict允许开启本地缓存,item_cache 为缓存变量名,150 阅读全文
posted @ 2023-06-27 16:42 xycccode 阅读(126) 评论(0) 推荐(0) 编辑
上一页 1 2 3 4 5 6 7 ··· 12 下一页