Rumah >Tutorial sistem >LINUX >Pangkalan data MariaDB dipasang dan dikonfigurasikan berdasarkan replikasi segerak induk-hamba GTID

Pangkalan data MariaDB dipasang dan dikonfigurasikan berdasarkan replikasi segerak induk-hamba GTID

PHPz
PHPzasal
2024-08-09 13:32:441121semak imbas

Sistem pengendalian: CentOS Linux keluaran 7.3.1611 (Teras)

Pangkalan data:MariaDB-10.2.6-linux-glibc_214-x86_64

Pelayan utama:10.10.10.56

Pelayan hamba:10.10.10.163

Pangkalan data MariaDB dipasang dan dikonfigurasikan berdasarkan replikasi segerak induk-hamba GTID

1. Apa yang perlu kita lakukan hari ini ialah penyegerakan tuan-hamba sehala

Untuk maklumat tentang pemasangan pangkalan data MariaDB (MySQL), sila rujuk "Pemasangan perduaan Centos7.3 x64-bit (MySQL) pengeluaran pangkalan data MariaDB 10.1.20 Seterusnya, proses konfigurasi kluster pelayan MariaDB (MySQL) bermula.

2 Ubah suai atau tambah maklumat berikut dalam fail konfigurasi MariaDB (MySQL)

vim /etc/my.cnf

主从通用配置

binlog-format = mixed #二进制日志记录的模式(高版本默认开启)
binlog-checksum = CRC32 #可使主机为写入二进制日志的事件写入校验(高版本默认开启)
sync-master-info = 1 #MariaDB依靠操作系统将master.info文件刷新到磁盘。
sync_relay_log_info = 1 #MariaDB依靠操作系统将relay-log.info文件刷新到磁盘。
expire_logs_days = 7 #日志文件过期天数,默认是 0,表示不过期 
master-verify-checksum = 1 #主服务器效验
slave-sql-verify-checksum = 1 #从服务器效验

3 Selain konfigurasi umum, Master pelayan utama juga perlu menambah kod berikut

server-id = 56 #MySQL服务器ID,不重复
log-bin = mysql-bin #二进制日志(默认开启)
sync-binlog = 1 #主服务器进行设置,用于事务安全
log-bin-index = mysql-bin

4 Selain konfigurasi umum, pelayan hamba juga perlu menambah kod berikut

server-id = 163
relay-log = relay-bin #中继日志
slave-parallel-threads = 2 #设定从服务器的SQL线程数
#replicate-do-db = renwoleblogdb#复制指定的数据库,多个写多行
replicate-ignore-db = mysql #不备份的数据库,多个写多行
relay_log_recovery = 1 #从站崩溃后可以使用,防止损坏的中继日志处理。
log-slave-updates = 1 #slave将复制事件写进自己的二进制日志
relay-log-index = relay-bin

Selain itu, ia tidak perlu untuk membolehkan log binari pada pelayan hamba Mysql, tetapi dalam beberapa kes, ia mesti ditetapkan Sebagai contoh, jika hamba adalah tuan hamba lain, bin_log mesti ditetapkan. Saya biarkan ia hidup secara lalai di sini.

5. Di atas hanyalah pengenalan ringkas kepada peranan setiap parameter Tetapan khusus parameter ini perlu dilaraskan mengikut situasi sebenar pengguna

《复制和二进制日志服务器系统变量》
https://mariadb.com/kb/en/mariadb/replication-and-binary-log-server-system-variables/

关于系统变量的兼容性,可参阅官方

《MariaDB与MySQL兼容性》
https://mariadb.com/kb/en/mariadb/mariadb-vs-mysql-compatibility/
6. Konfigurasi kebenaran induk pelayan utama

Buat akaun khusus pada pelayan MariaDB utama dan benarkan kebenaran pangkalan data, serta akses jauh dari IP pelayan

# mysql -uroot -p
Enter password:【输入你的MySQL密码回车】
MariaDB [(none)]> GRANT REPLICATION SLAVE ON *.* TO 'renwoleuseracc'@'%' IDENTIFIED BY 'renwoleuserpass'; //创建Slave专用备份账号
MariaDB [(none)]> flush privileges; //刷新MySQL权限
MariaDB [(none)]> SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM mysql.user; //查看授权情况
MariaDB [(none)]> flush tables with read lock; //锁定数据库防止master值变化
MariaDB [(none)]> show master status; //获取master状态值
+-----------------+----------+------------+-----------------+
| File |Position |Binlog_Do_DB|Binlog_Ignore_DB |
+-----------------+----------+------------+-----------------+
| mysql-bin.000006| 627 | | |
+-----------------+----------+------------+-----------------+
1 row in set (0.00 sec)
7 Setelah anda memperoleh lokasi Binlog yang betul (nama fail dan offset) semasa sandaran, anda boleh menggunakan fungsi BINLOG_GTID_POS() untuk mengira GTID

.

MariaDB [(none)]> SELECT BINLOG_GTID_POS("mysql-bin.000006", 627);
+------------------------------------------+
| BINLOG_GTID_POS('mysql-bin.000006', 627) |
+------------------------------------------+
| 0-56-4 |
+------------------------------------------+
1 row in set (0.01 sec)
8. Konfigurasikan daripada pelayan Hamba

Seperti kata pegawai itu, bermula dari versi MariaDB 10.0.13, mysqldump akan melengkapkan kerja ini secara automatik dan menulis GTID dalam fail eksport Hanya tetapkan –master-data atau –dump-slave dan tetapkan –gtid pada masa yang sama.

Dalam kes ini, SLAVE baharu boleh menetapkan kedudukan permulaan replikasi dengan menetapkan nilai @@gtid_slave_pos, gunakan CHANGE MASTER untuk menghantar nilai ini ke perpustakaan utama, dan kemudian mulakan replikasi:

# mysql -uroot -p
Enter password:【输入你的MySQL密码】
MariaDB [(none)]> SET GLOBAL gtid_slave_pos = "0-56-4";
MariaDB [(none)]> change master to master_host='10.10.10.56',MASTER_PORT = 3306,master_user='renwoleuseracc',master_password='renwoleuserpass',master_use_gtid=slave_pos; //进行主从授权
MariaDB [(none)]> START SLAVE; //启动Slave
MariaDB [(none)]> show slave status\G
*************************** 1. row ***************************
 Slave_IO_State: Waiting for master to send event
 Master_Host: 10.10.10.56
 Master_User: renwoleuseracc
 Master_Port: 3306
 Connect_Retry: 60
 Master_Log_File: mysql-bin.000006
 Read_Master_Log_Pos: 627
 Relay_Log_File: relay.000035
 Relay_Log_Pos: 537
 Relay_Master_Log_File: mysql-bin.000006
 Slave_IO_Running: Yes
 Slave_SQL_Running: Yes
 ...
 ...
 ...
 Using_Gtid: Slave_pos
 Gtid_IO_Pos: 0-56-4
9 Jika kedua-dua Slave_IO_Running dan Slave_SQL_Running adalah YA, ini menunjukkan bahawa perkhidmatan hamba sedang berjalan Lajur Using_Gtid menentukan sama ada nilai GTID adalah konsisten.

Penerangan:

master_host 表示master授权地址
MASTER_PORT MySQL端口
master_user 表示master授权账号
master_password 表示密码
master_use_gtid GTID变量值
10 Seterusnya buka kunci jadual pangkalan data pelayan utama

MariaDB [(none)]> unlock tables; //解锁数据表
MariaDB [(none)]> show slave hosts; //查看从服务器连接状态
MariaDB [(none)]> show global status like "rpl%"; //查看客户端
11 Lihat semua parameter geganti yang berkaitan daripada pelayan Hamba

MariaDB [(none)]> show variables like '%relay%';
12 Konfigurasi tuan-hamba telah selesai. Sekarang, tidak kira apa yang ditambah, diubah suai, dipadam atau diperiksa pada pelayan induk, ia akan disegerakkan ke pelayan hamba Anda boleh melakukan ujian yang berkaitan mengikut keperluan anda sendiri.

Mengenai sintaks set semula hamba tuan

Tetapkan semula sintaks teras master

RESET MASTER; bermakna melaksanakan RESET MASTER akan memadam semua fail log binari dan mencipta fail log binari kosong dengan akhiran angka .000001 tidak akan menjejaskan status kerja pelayan SLAVE, jadi melaksanakan arahan ini akan menyebabkan Slave Binlog Master tidak ditemui, menyebabkan penyegerakan gagal.

Tetapkan semula sintaks teras hamba

SET SEMULA HAMBA bermaksud; TETAP SEMULA HAMBA akan mengosongkan kedudukan penyegerakan pada hamba dan memadam semua fail log penyegerakan lama, tetapi perkhidmatan hamba mesti dihentikan sebelum menetapkan semula (HENTIKAN HAMBA)

Atas ialah kandungan terperinci Pangkalan data MariaDB dipasang dan dikonfigurasikan berdasarkan replikasi segerak induk-hamba GTID. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn