MySQL dan PostgreSQL: Petua Pemulihan Replikasi dan Kegagalan Pangkalan Data
Pengenalan:
Dalam era maklumat hari ini, pangkalan data memainkan peranan yang sangat penting. Sama ada anda syarikat atau pengguna individu, anda memerlukan pangkalan data yang cekap dan boleh dipercayai untuk menyimpan dan mengurus data. MySQL dan PostgreSQL adalah dua sistem pengurusan pangkalan data hubungan (DBMS) yang digunakan secara meluas. Semasa operasi pangkalan data, replikasi dan pemulihan kegagalan adalah dua teknologi utama. Artikel ini membincangkan replikasi pangkalan data dan teknik pemulihan kegagalan dalam MySQL dan PostgreSQL serta menyediakan contoh kod.
1. Kemahiran replikasi pangkalan data MySQL
Replikasi pangkalan data MySQL merujuk kepada proses menyalin kandungan satu pangkalan data ke pangkalan data yang lain. Teknologi replikasi ini meningkatkan ketersediaan dan prestasi pangkalan data. Berikut adalah beberapa teknik biasa untuk melaksanakan replikasi pangkalan data MySQL:
- Replikasi hamba-tuan MySQL
Replikasi hamba-hamba MySQL ialah teknologi replikasi pangkalan data biasa yang secara automatik menyalin data daripada pangkalan data induk kepada satu atau lebih pangkalan data hamba. Pangkalan data induk digunakan untuk operasi tulis dan pangkalan data hamba digunakan untuk operasi baca. Replikasi tuan-hamba boleh meningkatkan prestasi baca dan tulis pangkalan data dan mencapai ketersediaan yang tinggi. Berikut ialah contoh konfigurasi replikasi tuan-hamba MySQL yang mudah:
(contoh kod 1):
Konfigurasi pelayan induk (nama hos: tuan):
[mysqld]
server-id=1
log-bin=mysql-bin
Salin selepas log masuk
Salin selepas log masuk
Konfigurasi pelayan hamba (nama hos: hamba):
[mysqld]
server-id=2
replicate-do-db=mydb
Salin selepas log masuk
- MySQL Dual -Master Replication
MySQL dwi-master replication ialah teknologi replikasi pangkalan data biasa di mana dua pangkalan data induk mereplikasi data antara satu sama lain. Teknologi ini menyediakan ketersediaan dan prestasi yang lebih tinggi. Berikut ialah contoh konfigurasi replikasi dwi-induk MySQL yang mudah:
(contoh kod 2):
Konfigurasi Master 1 (nama hos: master1):
[mysqld]
server-id=1
log-bin=mysql-bin
auto_increment_offset=1
auto_increment_increment=2
Salin selepas log masuk
Konfigurasi Master 2 (nama hos: master2):
[mysqld]
server-id=2
log-bin=mysql-bin
auto_increment_offset=2
auto_increment_increment=2
Salin selepas log masuk
- MySQL multi -replikasi tuan-hamba peringkat
Replikasi tuan-hamba berbilang peringkat MySQL ialah teknologi replikasi pangkalan data yang kompleks tetapi berkuasa di mana berbilang pangkalan data induk menyalin data antara satu sama lain. Teknologi ini menyediakan tahap ketersediaan dan prestasi yang lebih tinggi. Berikut ialah contoh konfigurasi replikasi tuan-hamba berbilang peringkat MySQL yang mudah:
(contoh kod 3):
Konfigurasi pelayan induk 1 (nama hos: master1):
[mysqld]
server-id=1
log-bin=mysql-bin
Salin selepas log masuk
Salin selepas log masuk
Konfigurasi pelayan induk 2 (nama hos: master2) :
[mysqld]
server-id=2
log-bin=mysql-bin
replicate-do-db=mydb
Salin selepas log masuk
Konfigurasikan daripada pelayan 1 (nama hos: slave1):
[mysqld]
server-id=3
log-bin=mysql-bin
replicate-do-db=mydb
Salin selepas log masuk
2. Kemahiran pemulihan kegagalan pangkalan data PostgreSQL
PostgreSQL ialah sistem pengurusan pangkalan data hubungan sumber terbuka yang berkuasa yang menyediakan pelbagai teknik pemulihan kegagalan. Berikut ialah pengenalan ringkas kepada beberapa teknik pemulihan kegagalan PostgreSQL biasa:
- PostgreSQL pemulihan berasaskan titik dalam masa
PostgreSQL menyokong pemulihan berasaskan titik dalam masa, iaitu pangkalan data boleh dipulihkan ke titik tertentu dalam masa. Teknik pemulihan ini membantu pengguna menghapuskan operasi yang salah atau data yang rosak. Berikut ialah contoh kod pemulihan berasaskan titik dalam masa yang mudah:
(Contoh Kod 4):
pg_restore --create --dbname=mydb --host=myhost --username=myuser --no-owner mydb.bak
Salin selepas log masuk
- PostgreSQL Logical Backup and Restore
PostgreSQL menyokong sandaran dan pemulihan logik, yang boleh mengeksport pangkalan data ke satu atau lebih fail , dan memulihkan data daripada fail ini. Berikut ialah contoh kod sandaran dan pemulihan logik yang mudah:
(contoh kod 5):
Sandaran logik:
pg_dump --dbname=mydb --username=myuser --file=mydb.backup
Salin selepas log masuk
Pemulihan logik:
pg_restore --dbname=mydb --username=myuser --no-owner mydb.backup
Salin selepas log masuk
- PostgreSQL sandaran fizikal dan pemulihan
Sandaran fizikal dan pemulihan semula PostgreSQL yang juga menyokong boleh Salin keseluruhan fail fizikal pangkalan data ke lokasi lain dan memulihkan data daripada fail ini. Berikut ialah contoh kod sandaran dan pemulihan fizikal yang mudah:
(contoh kod 6):
Sandaran fizikal:
pg_basebackup -D /path/to/backup
Salin selepas log masuk
Pemulihan fizikal:
pg_ctl stop -D /path/to/data
rm -rf /path/to/data/*
pg_basebackup -x -D /path/to/data -P
pg_ctl start -D /path/to/data
Salin selepas log masuk
Kesimpulan: Replikasi pangkalan data dan petua pemulihan dan data kegagalan adalah untuk memastikan ketersediaan pangkalan data integriti cara penting seks. Kedua-dua MySQL dan PostgreSQL menyediakan pelbagai teknologi untuk replikasi pangkalan data dan pemulihan kegagalan. Artikel ini memperkenalkan replikasi tuan-hamba, replikasi dwi-tuan dan teknik replikasi tuan-hamba berbilang peringkat dalam MySQL, serta pemulihan titik dalam masa, sandaran dan pemulihan logik, sandaran fizikal dan teknik pemulihan dalam PostgreSQL, dan menyediakan contoh kod yang sepadan. Semoga petua ini akan membantu pembaca menghadapi cabaran replikasi pangkalan data dan pemulihan kegagalan dengan lebih baik. 🎜
Atas ialah kandungan terperinci MySQL dan PostgreSQL: Petua Pemulihan Replikasi dan Kegagalan Pangkalan Data. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!