Home Database Mysql Tutorial Thoughts on architecture optimization caused by master-slave replication problem

Thoughts on architecture optimization caused by master-slave replication problem

Feb 07, 2017 am 11:22 AM

Existing problems

The master-slave replication architecture has many replication stagnation problems such as 1032 errors and 1062 errors. Among them, the 1032 errors are caused by the update or update of the slave database after the master database is successfully executed. When deleting, it was found that this record could not be found on the slave library. The 1062 error was caused by a primary key conflict that occurred when the slave library was executed after the main library insert was completed and the insert could not be successful. These problems can be fixed by skipping the error and the previous copy data verification. Solved, but the direct cause of these problems is the inconsistency of the master-slave database data. In addition to possible data inconsistencies in the logical replication itself, this inconsistency is also caused by illegal additions, deletions, and modifications on the standby database by the business side or developers.

In the master-slave replication architecture, the master-slave library implements VIP binding to specify the library as the master library, providing reading and writing, and the slave library plays the role of backup. When a problem occurs in the master library, the VIP switches to the slave library. The slave library provides reading and writing, otherwise the slave library is just a backup. Under normal circumstances, we do not allow developers to directly log in to the slave database through a fixed IP, but in actual work it is often difficult to avoid it. So how to prevent developers from operating in the slave database from a technical perspective? How to avoid this without affecting the normal operation and failover of the high-availability architecture?

2. Architecture configuration optimization

(1) Direct solution

The direct way to solve the above problems is to consider Optimize the architecture configuration, that is, configure the read-write state of the slave library to the read-only state.

The MySQL official website has the following description about read-only:

1.Whenthe read_only system variable is enabled, the server permits no client updatesexcept from users who have the SUPER privilege. 
只读情况下,super权限可读写。
2.Updates performed by slave threads, if theserver is a replication slave. In replication setups, 
it can be useful toenable read_only on slave servers to ensure that slaves accept updates only from themaster server and not from clients.
不影响主从复制线程的读写。
Copy after login

After turning on read-only, except for super privilege accounts and replication threads, etc., business-side developers and other personnel will not be affected even if they log in to the backup server. The database cannot also operate the standby database data.

MySQL [db1]> show global variables like'read_only%';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| read_only     | ON   |
+---------------+-------+
1 row in set (0.00 sec)
 
MySQL [test]> insert child values('1','12');
ERROR 1290 (HY000): The MySQL server is running withthe --read-only option so it cannot execute thisstatement
Copy after login

(2) How to perform perfect failover after configuring it as read-only?

Read-only from the slave library can avoid illegal operations, but the problem is that if a problem occurs in the main library, the VIP needs to switch to the slave library, but at this time, read-only from the slave library will cause the database External services are not available, so when switching, it is necessary to cancel the read-only function of the slave library and set the read-only function of the main library.

Taking the Keepalived+MySQL dual master (master-slave) architecture as an example, during normal operation, the VIP is on Master1, Master1 is in the read-write state, and Master2 is in the readonly state. Once a problem occurs with Master1, the VIP will automatically switch to Master2 , two steps need to be completed before switching: 1. Set Master1 to readonly; 2. Cancel Master2's readonly.

3. Automated implementation ideas

For a master-slave architecture, failover needs to be done manually, so the above two steps can also be done manually; but Keepalived+MySQL dual master ( In the master-slave architecture, automatic fault monitoring and automatic VIP switching have been implemented. The above two steps should also be embedded in scripts to achieve automation.

We mainly need to embed functions for opening and closing readonly on the database in the automatic monitoring and switching scripts. We mainly write the statements "set global read_only=ON" and "set globalread_only=OFF". At the same time, pay attention to Before setting the status, first determine the existing status. The shell calls the statement "show variables like 'read_only';" to get the read and write status. After confirming the read and write status, set the readonly parameter to the required status. Note that the trigger customization of these status settings is in Before a failure is detected and a switchover is performed.

The above ideas have now been automatically converted, and the personal test has been successful, indicating that the ideas are correct.

The above is the content of the architecture optimization thinking caused by the master-slave replication problem. For more related content, please pay attention to the PHP Chinese website (www.php.cn)!


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)

How to implement master-slave replication of MySQL database in PHP How to implement master-slave replication of MySQL database in PHP May 17, 2023 am 08:18 AM

With the rapid development of the Internet, Web applications are increasingly integrating database operations. MySQL is a world-renowned relational database system that is widely used. In highly concurrent web applications, MySQL master-slave replication is an important way to improve database performance and availability. This article will introduce how to use PHP to implement master-slave replication of MySQL database. 1. What is MySQL master-slave replication? MySQL master-slave replication refers to copying data from one MySQL database server to another server.

Building a Highly Available MySQL Cluster: Best Practice Guide for Master-Slave Replication and Load Balancing Building a Highly Available MySQL Cluster: Best Practice Guide for Master-Slave Replication and Load Balancing Sep 09, 2023 am 10:57 AM

Building a Highly Available MySQL Cluster: Best Practice Guide for Master-Slave Replication and Load Balancing In recent years, with the rapid development of the Internet, the database has become one of the core data storage and processing engines for most web applications. In this scenario, high availability and load balancing have become important considerations in database architecture design. As one of the most popular open source relational databases, MySQL's cluster deployment solution has attracted much attention. This article will introduce how to implement a highly available database cluster through MySQL master-slave replication and load balancing.

Data master-slave replication technology in MySQL Data master-slave replication technology in MySQL Jun 14, 2023 pm 02:10 PM

MySQL database is a very popular relational database management system that supports a variety of data replication technologies, among which the more commonly used is master-slave replication technology. This article will introduce the data master-slave replication technology in MySQL, including principles, implementation methods, common problems and countermeasures. 1. Principle of master-slave replication technology The master-slave replication technology in MySQL can copy the data of a MySQL database to other servers to achieve data backup, load balancing, read-write separation and other functions. Its basic principle is to convert the main database

Detailed explanation of the master-slave replication function of Redis Detailed explanation of the master-slave replication function of Redis May 11, 2023 am 10:00 AM

Redis is an open source memory-based key-value storage system that is commonly used in scenarios such as caching, queuing, and real-time data processing. In large-scale applications, in order to improve the availability and performance of Redis, it is often necessary to adopt a distributed architecture, in which master-slave replication is a commonly used mechanism. This article will introduce the master-slave replication function of Redis, including definition, principle, configuration and application scenarios. 1. Definition of Redis master-slave replication refers to automatically synchronizing the data of one Redis node (i.e. master node) to other nodes (i.e. slave node).

How to configure master-slave replication of MySQL database? How to configure master-slave replication of MySQL database? Jul 13, 2023 pm 10:05 PM

How to configure master-slave replication of MySQL database? Master-slave replication of MySQL database is a common data backup and high availability solution. By configuring master-slave replication, you can synchronize data from one MySQL server (master server) to another (slave server), thereby improving database availability and performance. The following describes how to configure master-slave replication in a MySQL database and provides corresponding code examples. Make sure the MySQL server is installed and started. First, make sure MySQL is installed on your system.

Architecture optimization of PHP and database Architecture optimization of PHP and database Jun 21, 2023 am 09:01 AM

With the rapid development of the Internet and mobile Internet, Web applications are playing an increasingly important role in our daily lives. In these web applications, PHP and databases are widely used. However, as the number of users increases, the performance problems of Web applications become more and more prominent. Therefore, PHP and database schema optimization become very important in web applications. Using Caching MySQL caching is a technique that saves data across requests. PHP can be accessed by using memcached

Load balancing and disaster recovery in cluster mode: in-depth analysis and practice of MySQL master-slave replication Load balancing and disaster recovery in cluster mode: in-depth analysis and practice of MySQL master-slave replication Sep 11, 2023 pm 05:51 PM

Load balancing and disaster recovery in cluster mode: in-depth analysis and practice of MySQL master-slave replication. With the rapid development of the Internet industry, the demand for data storage and processing is getting higher and higher. In response to high concurrent access and massive data storage, cluster mode has become a common solution. Load balancing and disaster recovery are important components of the cluster system, and MySQL master-slave replication is a widely used method. This article will delve into load balancing and disaster recovery in cluster mode, focusing on the principle of MySQL master-slave replication.

Achieving data redundancy and expansion: application cases of MySQL master-slave replication technology in cluster environments Achieving data redundancy and expansion: application cases of MySQL master-slave replication technology in cluster environments Sep 08, 2023 pm 04:36 PM

Realizing data redundancy and expansion: Application cases of MySQL master-slave replication technology in cluster environments Introduction: With the development of the Internet, the increasing amount of data and the increasing number of users, traditional stand-alone databases can no longer meet the requirements of high concurrency and high availability. need. In this context, distributed databases have become one of the popular solutions. As one of the most commonly used relational databases, MySQL's master-slave replication technology has also received widespread attention in distributed databases. This article will introduce MySQL master-slave replication technology in a cluster environment

See all articles