Redis内部原理主从

https://www.cnblogs.com/laohanshuibi/p/15078291.html
StringBuffer key = new StringBuffer(CacheKeyConstant.CECHE_MANAGE_PERMISSION).append(platform);
Object dbRoles = redisService.hget(key.toString(), path);

  • 客户端:键值对的增删改查操作。

  • 磁盘:生成RDB快照、记录AOF日志、AOF日志重写。

  • 主从节点:主库生成、传输RDB文件,从库接受RDB文件、清空数据库、加载RDB文件。

2.和磁盘交互时的阻塞点。

    Redis是采用后台子进程的方式生成RDB快照文件,以及执行AOF日志重写操作。所以这两个操作由子进程负责执行,因此不会成为Redis的阻塞点。

但是Redis直接记录AOF日志时,会根据不同的写回策略对数据做落盘保存。

如果有大量的写操作需要记录在AOF日志中,并写回策略设置成同步写回的话,就会阻塞主线程了。所以AOF日志同步写也是Redis的一个阻塞点。

 

3.主从节点交互时的阻塞点

    在主从集群中,主库需要生成RDB文件,并传输给从库。主库在复制的过程中,创建和传输 RDB 文件都是由后台子进程来完成的,不会阻塞主线程的执行。但是,对于从库来说,它在接收了RDB 文件后,需要使用 FLUSHDB 命令清空当前数据库,然后需要把 RDB 文件加载到内存,这个过程的快慢和 RDB 文件的大小密切相关,RDB 文件越大,加载过程越慢,所以,加载 RDB 文件就成为了 Redis 又一个阻塞点。

     所以总结一下,Redis中阻塞主线程的操作主要有以下五种。

  • 集合全量查询和聚合操作。

  • bigkey 删除。

  • 清空数据库。

  • AOF 日志同步写。

  • 从库加载 RDB 文件。

 

posted @ 2021-07-06 10:53  小蚊子大人KN  阅读(37)  评论(0编辑  收藏  举报