Bagaimana untuk mencapai ketersediaan tinggi pangkalan data dan pemulihan bencana dalam MySQL?
Dengan perkembangan pesat Internet, pangkalan data telah menjadi bahagian yang amat diperlukan dalam aplikasi moden. Dari segi keselarasan tinggi, ketersediaan tinggi, dan pemulihan bencana, kestabilan dan kebolehpercayaan pangkalan data telah menjadi lebih penting. MySQL ialah salah satu pangkalan data hubungan yang paling biasa digunakan dan matang Artikel ini akan memperkenalkan cara untuk mencapai ketersediaan tinggi dan pemulihan bencana bagi pangkalan data dalam MySQL.
1. Replikasi Master-Slave
Replikasi Master-Slave ialah penyelesaian biasa dalam MySQL untuk mencapai ketersediaan tinggi pangkalan data. Melalui replikasi tuan-hamba, kita boleh menyalin data pangkalan data induk ke satu atau lebih pangkalan data hamba, dengan itu mencapai sandaran data dan pengasingan membaca dan menulis.
Dalam MySQL, mengkonfigurasi replikasi master-slave terbahagi terutamanya kepada langkah berikut:
Pada pelayan induk, cari fail konfigurasi my.cnf (biasanya terletak di /etc/mysql atau /etc/my.cnf) , tambahkan Konfigurasi berikut: Parameter
[mysqld] log_bin=mysql-bin server_id=1
log_bin
digunakan untuk membolehkan log binari merekodkan semua operasi kemas kini pada pelayan utama. Parameter server_id
digunakan untuk mengenal pasti pelayan induk yang unik. log_bin
参数用于开启二进制日志,用于记录主服务器上的所有更新操作。server_id
参数用于标识唯一的主服务器。
重启MySQL服务,使配置生效。
sudo service mysql restart
创建一个新用户,用于从服务器进行访问主服务器。打开MySQL命令行并执行以下命令:
CREATE USER 'replication'@'%' IDENTIFIED BY 'password'; GRANT REPLICATION SLAVE ON *.* TO 'replication'@'%';
其中,replication
是自定义的用户名,password
是密码。请根据实际情况进行设置。
在主服务器上,执行以下命令,查看主服务器状态,并记录File和Position的值(将会在从服务器配置时使用):
SHOW MASTER STATUS;
在从服务器上,找到my.cnf配置文件,添加以下配置:
[mysqld] server_id=2
server_id
参数用于标识唯一的从服务器。
在从服务器上,打开MySQL命令行并执行以下命令,进行主从复制的配置:
CHANGE MASTER TO MASTER_HOST='主服务器IP地址', MASTER_USER='replication', MASTER_PASSWORD='password', MASTER_LOG_FILE='从步骤4中的File值', MASTER_LOG_POS=从步骤4中的Position值;
其中,主服务器IP地址
需替换为实际的主服务器IP地址,replication
和password
需替换为从步骤3中创建的用户和密码,从步骤4中的File值
和从步骤4中的Position值
分别替换为主服务器状态的File和Position的值。
启动从服务器的复制进程:
START SLAVE;
查看从服务器复制状态:
SHOW SLAVE STATUS G;
如果成功配置,可以通过观察Slave_IO_Running
和Slave_SQL_Running
两个字段来确认状态是否正常。
二、主从切换(Failover)
主从复制可以实现数据的备份和读写分离,但当主服务器宕机时,需要手动切换到从服务器上。为了实现自动切换,我们可以结合其他工具,如MHA(MySQL High Availability)或者ProxySQL来进行主从切换。
MHA是一个专门用于MySQL高可用性和灾备配置的工具。我们可以通过以下步骤来实现主从切换:
安装MHA工具包:
sudo apt-get install mha4mysql-node
创建一个MHA的配置文件,如/etc/mha/app1.cnf
,内容如下:
[server default] manager_workdir=/var/log/masterha/app1 manager_log=/var/log/masterha/app1/manager.log [server1] hostname=主服务器IP地址 candidate_master=1 recovery_user=replication recovery_password=password [server2] hostname=从服务器IP地址 candidate_master=1 recovery_user=replication recovery_password=password
其中,主服务器IP地址
和从服务器IP地址
需替换为实际的IP地址。
执行以下命令,在从服务器上运行MHA的管理工具:
masterha_manager --conf=/etc/mha/app1.cnf --remove_dead_master_conf
该命令将会监听主服务器,并在主服务器宕机时进行主从切换。
三、数据备份和恢复(Backup and Recovery)
除了主从复制和主从切换,定期进行数据备份也是确保数据库可用性和灾备的重要方式。在MySQL中,我们可以使用mysqldump命令进行数据备份和恢复。
备份数据库:
mysqldump -u 用户名 -p 数据库名 > 备份文件.sql
其中,用户名
和数据库名
需替换为实际的用户名和数据库名,备份文件.sql
为备份文件的路径和文件名。
恢复数据库:
mysql -u 用户名 -p 数据库名 < 备份文件.sql
其中,用户名
和数据库名
需替换为实际的用户名和数据库名,备份文件.sql
rrreee
Buat pengguna baharu untuk mengakses pelayan utama dari pelayan. Buka baris arahan MySQL dan laksanakan arahan berikut:replication
ialah nama pengguna yang disesuaikan dan password
ialah kata laluan. Sila tetapkan mengikut keadaan sebenar. server_id
digunakan untuk mengenal pasti pelayan hamba yang unik. 🎜🎜🎜Mulakan semula perkhidmatan MySQL untuk menjadikan konfigurasi berkuat kuasa. 🎜🎜🎜Pada pelayan hamba, buka baris arahan MySQL dan laksanakan arahan berikut untuk mengkonfigurasi replikasi tuan-hamba: 🎜rrreee🎜Antaranya, kata laluan
perlu digantikan dengan pengguna dan kata laluan yang dibuat dalam langkah 3, daripada nilai Fail dalam langkah 4
dan Slave_IO>_Running> Medan Slave_SQL_Running
untuk mengesahkan sama ada status itu normal. . Untuk mencapai pensuisan automatik, kami boleh menggabungkan alat lain, seperti MHA (MySQL High Availability) atau ProxySQL untuk melaksanakan penukaran master-slave. 🎜🎜MHA ialah alat yang digunakan khusus untuk ketersediaan tinggi MySQL dan konfigurasi pemulihan bencana. Kami boleh melaksanakan penukaran tuan-hamba melalui langkah berikut: 🎜🎜🎜🎜Pasang kit alat MHA: 🎜rrreee🎜🎜🎜Buat fail konfigurasi MHA, seperti /etc/mha/app1.cnf
, kandungan Seperti berikut: 🎜rrreee🎜 Antaranya, Atas ialah kandungan terperinci Bagaimana untuk mencapai ketersediaan tinggi pangkalan data dan pemulihan bencana dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!