


How to configure high-availability database master-slave replication monitoring on Linux
How to configure high-availability database master-slave replication monitoring on Linux
Introduction:
In the modern technology environment, the database is a key component, and many applications rely on them. For availability and data protection considerations, database high availability and master-slave replication are very important features. This article will introduce how to configure high-availability database master-slave replication monitoring on Linux, and demonstrate the steps through sample code.
How master-slave replication works:
Master-slave replication is a common database replication method, in which one database server acts as the master server (Master), and other servers act as slave servers (Slave). Write operations received by the master server will be copied to the slave server. This architecture provides the benefits of data redundancy, read-write separation, and failure recovery.
Configure the main server:
First, we need to install the database server. This article takes MySQL as an example.
-
Install MySQL server:
sudo apt update sudo apt install mysql-server
-
Configure the main server:
Edit the MySQL configuration file:sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
In the file Find the following line in and modify it:
bind-address = 0.0.0.0 server-id = 1 log_bin = /var/log/mysql/mysql-bin.log
-
Restart the MySQL service:
sudo systemctl restart mysql
Configure the slave server:
-
Install the MySQL server:
sudo apt update sudo apt install mysql-server
-
Configure the slave server:
Edit the MySQL configuration file:sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
Find the following lines in the file and proceed Modification:
bind-address = 0.0.0.0 server-id = 2 log_bin = /var/log/mysql/mysql-bin.log relay_log = /var/log/mysql/mysql-relay-bin.log
-
Restart the MySQL service:
sudo systemctl restart mysql
Set the master-slave relationship:
-
In Create a user for replication on the master server:
mysql -u root -p GRANT REPLICATION SLAVE ON *.* TO 'replication_user'@'%' IDENTIFIED BY 'password'; FLUSH PRIVILEGES; EXIT;
-
Configure the master server information on the slave server:
mysql -u root -p CHANGE MASTER TO MASTER_HOST='主服务器的IP地址', MASTER_USER='replication_user', MASTER_PASSWORD='password'; START SLAVE; EXIT;
- Verify that master-slave replication is working properly :
Create a database and table on the main server and insert some data. Then, verify whether the corresponding data can be seen on the slave server.
Configuration monitoring:
In order to ensure the high availability of database master-slave replication, we need to monitor its status and detect and handle failures in a timely manner. Below is a simple monitoring script written in Python.
-
Install the required Python packages:
sudo apt update sudo apt install python3-pip pip3 install mysql-connector-python pip3 install smtplib
-
Create the monitor.py file and copy the following code into the file:
import smtplib import mysql.connector from email.mime.text import MIMEText def send_email(message): sender = "your_email@gmail.com" receiver = "recipient_email@gmail.com" subject = "Database Replication Alert" msg = MIMEText(message) msg['Subject'] = subject msg['From'] = sender msg['To'] = receiver try: with smtplib.SMTP_SSL('smtp.gmail.com', 465) as smtp: smtp.login(sender, "your_password") smtp.sendmail(sender, receiver, msg.as_string()) print("Email sent successfully!") except Exception as e: print("Email failed to send: " + str(e)) def monitor_replication(): try: connection = mysql.connector.connect(host="localhost", user="replication_user", password="password", database="test") cursor = connection.cursor() cursor.execute("SELECT COUNT(*) FROM my_table") result = cursor.fetchone() cursor.close() connection.close() print("Replication is working fine, number of records: " + str(result[0])) except mysql.connector.Error as error: message = "Replication failed: " + str(error) print(message) send_email(message) if __name__ == "__main__": monitor_replication()
- Modify the configuration information in monitor.py, including the email addresses of the sender and recipient, and the sender's email password.
- Run the monitor.py script and add it to the scheduled task to regularly monitor the status of the database master-slave replication.
Conclusion:
Through the above steps, we can configure highly available database master-slave replication monitoring on Linux. Continuous monitoring of the status of the database is critical for failure recovery and availability. Using the sample code, we can detect and handle database master-slave replication problems in time to ensure the smooth operation of the business.
The above is the detailed content of How to configure high-availability database master-slave replication monitoring on Linux. For more information, please follow other related articles on the PHP Chinese website!

MaintenanceModeinLinuxisaspecialbootenvironmentforcriticalsystemmaintenancetasks.Itallowsadministratorstoperformtaskslikeresettingpasswords,repairingfilesystems,andrecoveringfrombootfailuresinaminimalenvironment.ToenterMaintenanceMode,interrupttheboo

The core components of Linux include kernel, file system, shell, user and kernel space, device drivers, and performance optimization and best practices. 1) The kernel is the core of the system, managing hardware, memory and processes. 2) The file system organizes data and supports multiple types such as ext4, Btrfs and XFS. 3) Shell is the command center for users to interact with the system and supports scripting. 4) Separate user space from kernel space to ensure system stability. 5) The device driver connects the hardware to the operating system. 6) Performance optimization includes tuning system configuration and following best practices.

The five basic components of the Linux system are: 1. Kernel, 2. System library, 3. System utilities, 4. Graphical user interface, 5. Applications. The kernel manages hardware resources, the system library provides precompiled functions, system utilities are used for system management, the GUI provides visual interaction, and applications use these components to implement functions.

Linux maintenance mode can be entered through the GRUB menu. The specific steps are: 1) Select the kernel in the GRUB menu and press 'e' to edit, 2) Add 'single' or '1' at the end of the 'linux' line, 3) Press Ctrl X to start. Maintenance mode provides a secure environment for tasks such as system repair, password reset and system upgrade.

The steps to enter Linux recovery mode are: 1. Restart the system and press the specific key to enter the GRUB menu; 2. Select the option with (recoverymode); 3. Select the operation in the recovery mode menu, such as fsck or root. Recovery mode allows you to start the system in single-user mode, perform file system checks and repairs, edit configuration files, and other operations to help solve system problems.

The core components of Linux include the kernel, file system, shell and common tools. 1. The kernel manages hardware resources and provides basic services. 2. The file system organizes and stores data. 3. Shell is the interface for users to interact with the system. 4. Common tools help complete daily tasks.

The basic structure of Linux includes the kernel, file system, and shell. 1) Kernel management hardware resources and use uname-r to view the version. 2) The EXT4 file system supports large files and logs and is created using mkfs.ext4. 3) Shell provides command line interaction such as Bash, and lists files using ls-l.

The key steps in Linux system management and maintenance include: 1) Master the basic knowledge, such as file system structure and user management; 2) Carry out system monitoring and resource management, use top, htop and other tools; 3) Use system logs to troubleshoot, use journalctl and other tools; 4) Write automated scripts and task scheduling, use cron tools; 5) implement security management and protection, configure firewalls through iptables; 6) Carry out performance optimization and best practices, adjust kernel parameters and develop good habits.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

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

Hot Article

Hot Tools

SublimeText3 English version
Recommended: Win version, supports code prompts!

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SublimeText3 Mac version
God-level code editing software (SublimeText3)

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

Atom editor mac version download
The most popular open source editor