1. Use optimized query methods

2. Master/slave replication, read/write separation, and load balancing

At present, most of the mainstream relational databases provide the master-slave replication function. By configuring the master-slave relationship between two (or more) databases, data updates from one database server can be synchronized to another server. Websites can make use of this function of database to achieve read and write separation of database, so as to improve the load pressure of database. A system has far more reads than writes, so writes are addressed to Slaves and reads are addressed to Slaves (a simple round-robin algorithm to determine which slave to use).

Using the read-write separation of databases, the Web server accesses the Master database when writing data, and the Master database synchronizes data updates to the Slave database through the master-slave replication mechanism. In this way, when the Web server reads data, it can obtain data from the Slave database. This solution makes it easy to read data in a Web application with a lot of read operations, while the primary database only receives a small amount of write operations and can also achieve hot backup of data, which is a two-stone solution.

Principle of master-slave replication

Operations that affect the MySQL-A database are written to the local log system A after the database is executed. Suppose, in real time, the database event operations in the changed logging system are sent over the network to mysql-B. Mysql-b receives the data, writes it to the local log system B, and then writes the database events to the database one by one. So, if mysql-A changes, mysql-b will change, so that is called MYSQL copy.

In the above model, mysql-a is the master server, and mysql-b is the slave server.

Log system A, in fact, it is A binary log in the log type of MYSQL, that is, it is specially used to save all actions of modifying the database table, that is, bin log. Note that MYSQL writes binary logs after executing statements and before releasing locks to ensure transaction security.

Log system B is not A binary log, because it is copied from the binary log of mysql-A and is not generated by its own database changes. It is called A relay log, i.e. A relay log. Can be found by the above mechanism, can guarantee and MYSQL MYSQL – A – B database data is consistent, there must be some delay, but time is MYSQL data – B is lagging.

Mysql master (master) and slave (slave) replication principle

(1) The master logs the changes to the binary log specified by the log-bin configuration file.

PS: As can be seen from the figure, there is an I/O Thread in the Slave server constantly listening for the update of the Binary Log of the Master. If there is no I/O Thread, the Slave server will sleep and wait for the Master to generate new Log events. If new Log Events occur, they are copied to the Relay Log on the Slave server.

Slave copies the binary log events of the master to its relay log

(3). Slave rewrites events in the relay log to reflect changes made on the Master to its own database. , so the data at both ends are exactly the same.

PS: As can be seen from the figure, there is an SQL Thread in the Slave server (SQL Thread) reading events from the Slave log and redoing the events, so as to update the data of the Slave and make it consistent with that of the Master. As long as the thread is consistent with the I/O thread, the relay log is usually in the OS cache, so the overhead of the relay log is minimal.

Master/slave replication mode

1. Synchronous replication

After writing the updated data to its binary log file, the master server must wait to verify that all the updated data from the slave server has been copied to it before it is free to process other incoming transaction requests

2. Asynchronous replication

After writing the updated data to its binary log file, the master server is free to process other incoming transaction requests without waiting to verify that the updated data has been copied to the slave server.

3. Semi-synchronous replication

After writing the updated data to its binary log file, the master server waits only to verify that the updated data from one of the slave servers has been copied to it and is free to process other incoming transaction requests, leaving the other slave servers alone.

3. Database sub-table, partition and sub-library

table

The access efficiency of table can be improved by splitting table. There are two ways to split it

1. Vertical split puts the primary key and some columns in one table, and the primary key and other columns in another table. If some columns in a table are frequently used and others are not, vertical splitting can be used.

Split the rows into two separate tables based on the values of one or more columns of data.

partition

Partition is to make a list of data into multiple blocks, the blocks can be on a disk, can also be on a different disk, partition, a list or on the surface, but the data hash in multiple locations, so that more disk processing different requests at the same time, thus improve the disk I/O read and write performance, implementation is simple. This includes both horizontal and vertical partitions.

depots

Sub-database is based on different business related tables into different databases, such as Web, BBS, blog and other libraries.