为什么Redis单线程模型也能效率这么高?
1、C 语言实现。 我们都知道,C 语言的执行速度非常快。 2、纯内存操作。 Redis 为了达到最快的读写速度,将数据都读到内存中,并通过异步的方式将数据写入磁盘。所以 Redis 具有快速和数据持久化的特征。 如果不将数据放在内存中,磁盘 I/O 速度为严重影响 Redis 的性能。 3、基于非阻塞的 IO 多路复用机制。 4、单线程,避免了多线程的频繁上下文切换问题。 R...
1、C 语言实现。 我们都知道,C 语言的执行速度非常快。 2、纯内存操作。 Redis 为了达到最快的读写速度,将数据都读到内存中,并通过异步的方式将数据写入磁盘。所以 Redis 具有快速和数据持久化的特征。 如果不将数据放在内存中,磁盘 I/O 速度为严重影响 Redis 的性能。 3、基于非阻塞的 IO 多路复用机制。 4、单线程,避免了多线程的频繁上下文切换问题。 R...
不同的消息队列,其架构不同,所以实现发送消息的可靠性的方案不同。所以参见如下文章: 不同的消息队列,其架构不同,所以实现发送消息的可靠性的方案不同。所以参见如下文章: RocketMQ 《精尽 RocketMQ 面试题》 的 「RocketMQ 是否会弄丢数据?」 的面试题。 RabbitMQ 《精尽 RabbitMQ 面试题》 的 「RabbitMQ 是否会弄丢数据?」 的面...
🦅 概念 TCP 是以流的方式来处理数据,所以会导致粘包 / 拆包。 拆包:一个完整的包可能会被 TCP 拆分成多个包进行发送。 粘包:也可能把小的封装成一个大的数据包发送。 🦅 原因 应用程序写入的字节大小大于套接字发送缓冲区的大小,会发生拆包现象。而应用程序写入数据小于套接字缓冲区大小,网卡将应用多次写入的数据发送到网络上,这将会发生粘包现象。 待发送数据大...
synchronized是一个关键字,ReentrantLo夏促1. synchronized是一个关键字,ReentrantLockw一个类 synchronized会自动的加锁与释放锁,ReentrantLock需要手动加锁与释放锁 synchronized的底层是JVM层面的锁,ReentrantLock是API层面的锁 synchronized是非公平锁,Reentran...
一、基础 模式定义了数据如何存储、存储什么样的数据以及数据如何分解等信息,数据库和表都有模式。 主键的值不允许修改,也不允许复用(不能使用已经删除的主键值赋给新数据行的主键)。 SQL(Structured Query Language),标准 SQL 由 ANSI 标准委员会管理,从而称为 ANSI SQL。各个 DBMS 都有自己的实现,如 PL/SQL、Transact-SQL ...
第一个版本的 Spring Cloud 面试题,主要把整个文章的大体结构定了,后续在慢慢完善补充~如下是 Eureka + Ribbon + Feign + Hystrix + Zuul 整合后的图: Eureka + Ribbon + Feign + Hystrix + Zuul
本文来自读者 PR。 1 单机版消息中心 一个消息中心,最基本的需要支持多生产者、多消费者,例如下: class Scratch { public static void main(String[] args) { // 实际中会有 nameserver 服务来找到 broker 具体位置以及 broker 主从信息 Broker broker...
如下图所示: RocketMQ 角色 生产者(Producer):负责产生消息,生产者向消息服务器发送由业务应用程序系统生成的消息。 消费者(Consumer):负责消费消息,消费者从消息服务器拉取信息并将其输入用户应用程序。 消息服务器(Broker):是消息存储中心,主要作用是接收来自 Producer 的消息并存储, Consumer 从这里取得消息。 名称服...
艿艿:注意,RocketMQ 是否会丢数据,主要取决于我们如何使用。这点,非常重要噢。 🦅 消费端弄丢了数据? 对于消费端,如果我们在使用 Push 模式的情况下,只有我们消费返回成功,才会异步定期更新消费进度到 Broker 上。 如果消费端异常崩溃,可能导致消费进度未更新到 Broker 上,那么无非是 Consumer 可能重复拉取到已经消费过的消息。关于这个,就需要消费端做好消...
RocketMQ 是阿里巴巴在 2012 年开源的分布式消息中间件,目前已经捐赠给 Apache 软件基金会,并于 2017 年 9 月 25 日成为 Apache 的顶级项目。作为经历过多次阿里巴巴双十一这种“超级工程”的洗礼并有稳定出色表现的国产中间件,以其高性能、低延时和高可靠等特性近年来已经也被越来越多的国内企业使用。 如下是 RocketMQ 产生的原因: 淘宝内部的交易系统使...