Table of Contents
Sub-library ideas" >Sub-library ideas
Home Topics php mysql PHP combined with MySQL completes tens of millions of data processing

PHP combined with MySQL completes tens of millions of data processing

Dec 22, 2020 pm 05:55 PM
data processing

PHP MySQL column explains how to achieve tens of millions of data processing

PHP combined with MySQL completes tens of millions of data processing

Recommended (free): PHP MySQL

mysql sub-table ideas


An order table of 100 million can be divided into five tables, so that each table only has 20 million data, which shares the pressure of the original table. The sub-tables need to be divided according to certain conditions. Here you can divide it according to To divide tables by region, a middleware is needed to control which table to go to to find the data you want.
Middleware: Use the auto-incremented id of the main table as middleware (what fields are suitable for middleware? It must be unique)
How to distribute? After inserting into the main table, an id is returned, and the modulo is taken based on this id and the number of tables. The data is inserted into whichever table the remainder is.
Note: The id in the sub-table must be consistent with the id of the main table.
In the future, only insert operations will use the main table. Modification, deletion, and reading do not need to use the main table.

PHP 结合 MySQL 千万级数据处理

redis message queue

1. What is a message queue?
Container that saves messages during the message propagation process
2, the historical reasons for the generation of message queue

PHP 结合 MySQL 千万级数据处理

The characteristics of message queue: first in, first out
The executed SQL statements are first saved in the message queue, and then sequentially inserted into the database smoothly and asynchronously.
Application: Sina, put the instant comments into the message queue first, and then insert the SQL statements in the message queue sequentially through scheduled tasks. Go to the database

Modify

Operation sub-table to modify

PHP 结合 MySQL 千万级数据处理

Modify like this There is a problem. The data in the main table and the sub-table will be inconsistent. How to make the data in the main table and the sub-table consistent?

The redis queue keeps the main table and sub-table data consistent

After the modification is completed, the data of the main table will be modified and stored in the redis queue

PHP 结合 MySQL 千万级数据处理

Then the linux scheduled task (contble) loops to execute the sql statement in the redis queue and synchronously updates the contents of the main table

PHP 结合 MySQL 千万级数据处理

mysql distributed table (query, delete)

The query only needs to query the sub-table, not the main table

PHP 结合 MySQL 千万级数据处理

To delete, first find the subtable to be deleted based on the ID, then delete it, and then push a sql statement to delete the total table data into the message queue
Then execute a scheduled task to delete the total table data

PHP 结合 MySQL 千万级数据处理

Scheduled tasks:

PHP 结合 MySQL 千万级数据处理

##mysql distributed sub-library

PHP 结合 MySQL 千万级数据处理

Sub-library schematic:

PHP 结合 MySQL 千万级数据处理

PHP 结合 MySQL 千万级数据处理

mysql distributed branch library (increased)

PHP 结合 MySQL 千万级数据处理
Note: After one operation The database must close the database connection, otherwise mysql will think that it is always connected to the same database

It will still take the modulus to determine which configuration file to load and connect to which database

PHP 结合 MySQL 千万级数据处理

mysql distributed branch library (modification)

The principle is the same as the new one

PHP 结合 MySQL 千万级数据处理

mysql distributed database (check, delete)

The principle is similar

PHP 结合 MySQL 千万级数据处理
Delete

PHP 结合 MySQL 千万级数据处理
Execution queue

##Mysql distributed cache (memcache) application

Put data into the cache to save database overhead. First Go to the cache to check, if there is any, take it out directly. If not, go to the database to check, and then store it in the cache.

PHP 结合 MySQL 千万级数据处理

After editing the information, you need to delete the cache, otherwise it will keep reading. It is cached data rather than modified data

PHP 结合 MySQL 千万级数据处理

The above is the detailed content of PHP combined with MySQL completes tens of millions of data processing. 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

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

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)

How to use iterators and recursive algorithms to process data in C# How to use iterators and recursive algorithms to process data in C# Oct 08, 2023 pm 07:21 PM

How to use iterators and recursive algorithms to process data in C# requires specific code examples. In C#, iterators and recursive algorithms are two commonly used data processing methods. Iterators can help us traverse the elements in a collection, and recursive algorithms can handle complex problems efficiently. This article details how to use iterators and recursive algorithms to process data, and provides specific code examples. Using Iterators to Process Data In C#, we can use iterators to iterate over the elements in a collection without knowing the size of the collection in advance. Through the iterator, I

Pandas easily reads data from SQL database Pandas easily reads data from SQL database Jan 09, 2024 pm 10:45 PM

Data processing tool: Pandas reads data in SQL databases and requires specific code examples. As the amount of data continues to grow and its complexity increases, data processing has become an important part of modern society. In the data processing process, Pandas has become one of the preferred tools for many data analysts and scientists. This article will introduce how to use the Pandas library to read data from a SQL database and provide some specific code examples. Pandas is a powerful data processing and analysis tool based on Python

How to implement real-time data push function in MongoDB How to implement real-time data push function in MongoDB Sep 21, 2023 am 10:42 AM

How to implement real-time data push function in MongoDB MongoDB is a document-oriented NoSQL database, which is characterized by high scalability and flexible data model. In some application scenarios, we need to push data updates to the client in real time in order to update the interface or perform corresponding operations in a timely manner. This article will introduce how to implement the real-time push function of data in MongoDB and give specific code examples. There are many ways to implement real-time push functionality, such as using polling, long polling, Web

How does Golang improve data processing efficiency? How does Golang improve data processing efficiency? May 08, 2024 pm 06:03 PM

Golang improves data processing efficiency through concurrency, efficient memory management, native data structures and rich third-party libraries. Specific advantages include: Parallel processing: Coroutines support the execution of multiple tasks at the same time. Efficient memory management: The garbage collection mechanism automatically manages memory. Efficient data structures: Data structures such as slices, maps, and channels quickly access and process data. Third-party libraries: covering various data processing libraries such as fasthttp and x/text.

Use Redis to improve data processing efficiency of Laravel applications Use Redis to improve data processing efficiency of Laravel applications Mar 06, 2024 pm 03:45 PM

Use Redis to improve the data processing efficiency of Laravel applications. With the continuous development of Internet applications, data processing efficiency has become one of the focuses of developers. When developing applications based on the Laravel framework, we can use Redis to improve data processing efficiency and achieve fast access and caching of data. This article will introduce how to use Redis for data processing in Laravel applications and provide specific code examples. 1. Introduction to Redis Redis is a high-performance memory data

How do the data processing capabilities in Laravel and CodeIgniter compare? How do the data processing capabilities in Laravel and CodeIgniter compare? Jun 01, 2024 pm 01:34 PM

Compare the data processing capabilities of Laravel and CodeIgniter: ORM: Laravel uses EloquentORM, which provides class-object relational mapping, while CodeIgniter uses ActiveRecord to represent the database model as a subclass of PHP classes. Query builder: Laravel has a flexible chained query API, while CodeIgniter’s query builder is simpler and array-based. Data validation: Laravel provides a Validator class that supports custom validation rules, while CodeIgniter has less built-in validation functions and requires manual coding of custom rules. Practical case: User registration example shows Lar

Data processing tool: efficient techniques for reading Excel files with pandas Data processing tool: efficient techniques for reading Excel files with pandas Jan 19, 2024 am 08:58 AM

With the increasing popularity of data processing, more and more people are paying attention to how to use data efficiently and make the data work for themselves. In daily data processing, Excel tables are undoubtedly the most common data format. However, when a large amount of data needs to be processed, manually operating Excel will obviously become very time-consuming and laborious. Therefore, this article will introduce an efficient data processing tool - pandas, and how to use this tool to quickly read Excel files and perform data processing. 1. Introduction to pandas pandas

Using Pandas to rename column names for efficient data processing Using Pandas to rename column names for efficient data processing Jan 11, 2024 pm 05:14 PM

Efficient data processing: Using Pandas to modify column names requires specific code examples. Data processing is a very important part of data analysis, and during the data processing process, it is often necessary to modify the column names of the data. Pandas is a powerful data processing library that provides a wealth of methods and functions to help us process data quickly and efficiently. This article will introduce how to use Pandas to modify column names and provide specific code examples. In actual data analysis, the column names of the original data may have inconsistent naming standards and are difficult to understand.

See all articles