search
HomeDatabaseRedisDetailed analysis of the data structure and data operations of Redis
Detailed analysis of the data structure and data operations of RedisFeb 08, 2021 pm 04:20 PM
redisData operationsdata structure

Detailed analysis of the data structure and data operations of Redis

Recommended (free): redis

The speed of Redis to complete data operations can reach the microsecond level, Redis can There are two main reasons for such outstanding performance:

  • Redis is an in-memory database, all operations are completed in memory, and the memory access speed itself is very fast;
  • Redis Have efficient data types and data structures.

In order to achieve fast access from key to value, Redis uses a hash table to store key-value pairs. The entry in the hash bucket saves pointers to the actual key and value, even if the value is A collection can also be found through the value pointer.

When there is more and more data in the hash table, hash conflicts will occur, that is, the hash values ​​of multiple keys may correspond to the same hash bucket. Redis uses chained hashing to resolve hash conflicts, which means that multiple elements in the same hash bucket are stored in a linked list, and the elements are linked by pointers in turn.

If there are more and more hash conflicts, the hash conflict chain will be too long, which will lead to long time and low efficiency in finding elements. In order to solve this problem, Redis will perform a rehash operation on the hash table to store multiple entry elements in a dispersed manner, reducing the number of elements in a single hash bucket, thereby reducing conflicts in a single bucket.

Redis uses two global hash tables by default for efficient rehash. Hash table 1 is used by default at the beginning, and hash table 2 does not allocate space. When the data continues to increase, redis performs rehash through the following steps:

  1. Allocate more space to hash table 2
  2. Copy the data in hash table 1 to hash table 2
  3. Release the hash table 1 space is reserved for the next rehash expansion

However, if a large amount of data is copied at one time in step 2, it may cause the Redis thread to be blocked and unable to serve other requests, so Redis adopts a gradual approach. Rehash means that every time a request is processed, all entries at this index position are copied.

For String type value, you can directly perform CRUD operations after finding the hash bucket. For sets, after finding the corresponding hash bucket through the global hash table, in the set Then perform CRUD. The operation efficiency of a collection is related to the underlying data structure and operation complexity.

  1. Single element operation is the basis, and the operation complexity is O(1);
    • Hash: HGET, HSET, HDEL;
    • Set type SADD, SREM, SRANDMEMBER, etc.
  2. Range operations are very time-consuming and the operation complexity is O(N).
    • Hash:HGETALL;
    • Set:SMEMBERS;
    • List:LRANGE
    • ZSet:ZRANGE
  3. Statistical operations are usually efficient, with operation complexity O(1).
  4. There are only a few exceptions, and the operation complexity is O(1).
    • List: LPOP, RPOP, LPUSH, RPUSH

The above is the detailed content of Detailed analysis of the data structure and data operations of Redis. For more information, please follow other related articles on the PHP Chinese website!

Statement
This article is reproduced at:CSDN. If there is any infringement, please contact admin@php.cn delete
es和redis区别es和redis区别Jul 06, 2019 pm 01:45 PM

Redis是现在最热门的key-value数据库,Redis的最大特点是key-value存储所带来的简单和高性能;相较于MongoDB和Redis,晚一年发布的ES可能知名度要低一些,ES的特点是搜索,ES是围绕搜索设计的。

一起来聊聊Redis有什么优势和特点一起来聊聊Redis有什么优势和特点May 16, 2022 pm 06:04 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于redis的一些优势和特点,Redis 是一个开源的使用ANSI C语言编写、遵守 BSD 协议、支持网络、可基于内存、分布式存储数据库,下面一起来看一下,希望对大家有帮助。

实例详解Redis Cluster集群收缩主从节点实例详解Redis Cluster集群收缩主从节点Apr 21, 2022 pm 06:23 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis Cluster集群收缩主从节点的相关问题,包括了Cluster集群收缩概念、将6390主节点从集群中收缩、验证数据迁移过程是否导致数据异常等,希望对大家有帮助。

Redis实现排行榜及相同积分按时间排序功能的实现Redis实现排行榜及相同积分按时间排序功能的实现Aug 22, 2022 pm 05:51 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis实现排行榜及相同积分按时间排序,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,希望对大家有帮助。

详细解析Redis中命令的原子性详细解析Redis中命令的原子性Jun 01, 2022 am 11:58 AM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于原子操作中命令原子性的相关问题,包括了处理并发的方案、编程模型、多IO线程以及单命令的相关内容,下面一起看一下,希望对大家有帮助。

实例详解Redis实现排行榜及相同积分按时间排序功能的实现实例详解Redis实现排行榜及相同积分按时间排序功能的实现Aug 26, 2022 pm 02:09 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了Redis实现排行榜及相同积分按时间排序,本文通过实例代码给大家介绍的非常详细,下面一起来看一下,希望对大家有帮助。

一文搞懂redis的bitmap一文搞懂redis的bitmapApr 27, 2022 pm 07:48 PM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了bitmap问题,Redis 为我们提供了位图这一数据结构,位图数据结构其实并不是一个全新的玩意,我们可以简单的认为就是个数组,只是里面的内容只能为0或1而已,希望对大家有帮助。

一起聊聊Redis实现秒杀的问题一起聊聊Redis实现秒杀的问题May 27, 2022 am 11:40 AM

本篇文章给大家带来了关于redis的相关知识,其中主要介绍了关于实现秒杀的相关内容,包括了秒杀逻辑、存在的链接超时、超卖和库存遗留的问题,下面一起来看一下,希望对大家有帮助。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Hot Tools

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use