Home System Tutorial LINUX Pika: Supplement applicable scenarios for large-capacity Redis storage

Pika: Supplement applicable scenarios for large-capacity Redis storage

Jan 08, 2024 pm 10:14 PM
linux linux tutorial Red Hat linux system linux command linux certification red hat linux linux video

Introduction We introduced the birth of pika, the characteristics of pika, the core of pika and the use of pika in "Large Capacity Redis Storage - Everything About Pika". The article analyzes the important files in pika synchronization logic in great detail: the data storage method and implementation principle of "write2file", which is very worth reading!
pika

pika is a large-capacity Redis-like storage developed by the DBA of 360 Web Platform Department and the infrastructure team. The emergence of pika is not to replace Redis, but to supplement Redis scenarios. Pika strives to solve the problems of Redis in large-capacity scenarios through persistent storage on the premise of being fully compatible with the Redis protocol and inheriting the convenient operation and maintenance design of Redis, such as slow recovery time, high cost of master-slave synchronization, relatively fragile single thread, and load-bearing capacity. Data is limited, memory cost is high, etc.

pika master-slave replication principle binlog

Binlog related files contain two parts: manifest and write2file. Manifest records log meta information, including the current log file number and current log file offset. write2file num records all redis write commands and parameters received by pika. .

file format

Manifest file format:

Log offset (8 bytes)|con_offset (8 bytes, unused)|Number of elements (4 bytes, unused)|Log file number (4 bytes).

Binlog file format:

The fixed size of the Binlog file is 100MB. Each Binlog file is composed of multiple Blocks. The size of each Block is fixed at 64KB. Each write redis command is called a Record. A Record can be distributed in multiple Blocks, but it will only be distributed in one Binlog file, so the Binlog file may be larger than 100MB.

Record format: Header|Cmd

Header: Record Length (3 bytes) | Timestamp (4 bytes) | Record type (1 byte).

Cmd: part or all of the redis command, depending on whether the remaining space of the current Block can store the Record.

Implementation class

Basic Class

Version: Meta information class, mapped through mmap and manifest files.

Binlog: Log class, mapped through mmap and write2file files.

PikaBinlogSenderThread: Log consumption class, sequentially reads log file contents and consumes logs.

Basic operations

Constructing Binlog

//file_size can be specified in the configuration file, the default is 100MB

Binlog::Binlog(const std::string& binlog_path, const int file_size)

1.1Create the binlog file directory.

1.2 Check whether the manifest file in the log directory exists. If it does not exist, create a new one.

1.3 Initialize the Version class according to the manifest file.

1.4 Find the corresponding log file according to filenum in the manifest, locate the file append position according to pro_offset, initialize the log pointer, record the log content length, and the number of Block blocks.

Update current log production status

//pro_num: Log file number

//pro_offset: log file offset

//Used to update the binlog information corresponding to the slave instance when full synchronization is required

Status Binlog::SetProducerStatus(uint32_t pro_num, uint64_t pro_offset)

2.1 Delete write2file0.

2.2 Delete write2file pro_num.

2.3 Construct a new write2file pro_num file, fill in pro_offset spaces, initialize version->pro_num to pro_num, version->pro_offset to pro_offset, and refresh it to the manifest file.

2.4 Initialize the current filesize and block_offset.

Update current log production status

//filenum: current log number

//pro_offset: current log offset

Status Binlog::GetProducerStatus(uint32_t* filenum, uint64_t* pro_offset)

3.1 Read pro_num and pro_offset in version and return.

Production log

//Put->Produce->EmitPhysicalRecord

Status Binlog::Put(const std::string &item)

4.1 Check whether the current log file meets the cutting conditions, and if so, cut it.

4.1.1 pro_num increases by 1, initializes new log files, version->pro_num=pro_num, version->pro_offset = 0, binlog->filesize = 0, binlog->block_offset = 0.

4.1.2 If the remaining size of the current block is

4.1.3 Produce is a loop, which ensures that when the item size exceeds kBlockSize, EmitPhysicalRecord can be performed multiple times, and all data of the item will be dropped into the binlog file. The condition for the loop to exit normally is left==0.

4.1.3.1 If left

4.1.3.2 If left > avail, it means multiple Blocks are needed to store items, then the first time Type=kFirstType, call EmitPhysicalRecord multiple times.

4.1.3.3 If left > avail, and it is not the first time to EmitPhysicalRecord, then Type=kMiddleType, call EmitPhysicalRecord multiple times.

4.1.4EmitPhysicalRecord.

4.1.4.1 Splice RecordHeader (3-byte length, 4-byte time, 1-byte Type), write data, and update block_offset and pro_offset.

Consumption Log

//scratch: The consumption result returns a complete redis cmd

//Consume->ReadPhysicalRecord, ReadPhysicalRecord reads a complete Record each time, and multiple Records constitute a complete redis cmd

Status PikaBinlogSenderThread::Consume(std::string &scratch)

5.1Consume is a loop, which may call ReadPhysicalRecord multiple times. The condition for loop exit is that the read record_type==kFullType or record_type==kLastType.

5.1.1 If the read kBlockSize-last_record_offset_ <= kHeaderSize means that the end of the Block has been read and it is filled with data, skip it.

5.1.2 Read data, update last_record_offset_, con_offset.

The above is the detailed content of Pika: Supplement applicable scenarios for large-capacity Redis storage. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

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

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

deepseek web version entrance deepseek official website entrance deepseek web version entrance deepseek official website entrance Feb 19, 2025 pm 04:54 PM

DeepSeek is a powerful intelligent search and analysis tool that provides two access methods: web version and official website. The web version is convenient and efficient, and can be used without installation; the official website provides comprehensive product information, download resources and support services. Whether individuals or corporate users, they can easily obtain and analyze massive data through DeepSeek to improve work efficiency, assist decision-making and promote innovation.

How to install deepseek How to install deepseek Feb 19, 2025 pm 05:48 PM

There are many ways to install DeepSeek, including: compile from source (for experienced developers) using precompiled packages (for Windows users) using Docker containers (for most convenient, no need to worry about compatibility) No matter which method you choose, Please read the official documents carefully and prepare them fully to avoid unnecessary trouble.

Ouyi okx installation package is directly included Ouyi okx installation package is directly included Feb 21, 2025 pm 08:00 PM

Ouyi OKX, the world's leading digital asset exchange, has now launched an official installation package to provide a safe and convenient trading experience. The OKX installation package of Ouyi does not need to be accessed through a browser. It can directly install independent applications on the device, creating a stable and efficient trading platform for users. The installation process is simple and easy to understand. Users only need to download the latest version of the installation package and follow the prompts to complete the installation step by step.

BITGet official website installation (2025 beginner's guide) BITGet official website installation (2025 beginner's guide) Feb 21, 2025 pm 08:42 PM

BITGet is a cryptocurrency exchange that provides a variety of trading services including spot trading, contract trading and derivatives. Founded in 2018, the exchange is headquartered in Singapore and is committed to providing users with a safe and reliable trading platform. BITGet offers a variety of trading pairs, including BTC/USDT, ETH/USDT and XRP/USDT. Additionally, the exchange has a reputation for security and liquidity and offers a variety of features such as premium order types, leveraged trading and 24/7 customer support.

Get the gate.io installation package for free Get the gate.io installation package for free Feb 21, 2025 pm 08:21 PM

Gate.io is a popular cryptocurrency exchange that users can use by downloading its installation package and installing it on their devices. The steps to obtain the installation package are as follows: Visit the official website of Gate.io, click "Download", select the corresponding operating system (Windows, Mac or Linux), and download the installation package to your computer. It is recommended to temporarily disable antivirus software or firewall during installation to ensure smooth installation. After completion, the user needs to create a Gate.io account to start using it.

Ouyi Exchange Download Official Portal Ouyi Exchange Download Official Portal Feb 21, 2025 pm 07:51 PM

Ouyi, also known as OKX, is a world-leading cryptocurrency trading platform. The article provides a download portal for Ouyi's official installation package, which facilitates users to install Ouyi client on different devices. This installation package supports Windows, Mac, Android and iOS systems. Users can choose the corresponding version to download according to their device type. After the installation is completed, users can register or log in to the Ouyi account, start trading cryptocurrencies and enjoy other services provided by the platform.

How to automatically set permissions of unixsocket after system restart? How to automatically set permissions of unixsocket after system restart? Mar 31, 2025 pm 11:54 PM

How to automatically set the permissions of unixsocket after the system restarts. Every time the system restarts, we need to execute the following command to modify the permissions of unixsocket: sudo...

Why does an error occur when installing an extension using PECL in a Docker environment? How to solve it? Why does an error occur when installing an extension using PECL in a Docker environment? How to solve it? Apr 01, 2025 pm 03:06 PM

Causes and solutions for errors when using PECL to install extensions in Docker environment When using Docker environment, we often encounter some headaches...

See all articles