Rumah pembangunan bahagian belakang tutorial php Bagaimana untuk melaksanakan replikasi tuan-hamba pangkalan data MySQL dalam PHP

Bagaimana untuk melaksanakan replikasi tuan-hamba pangkalan data MySQL dalam PHP

May 17, 2023 am 08:18 AM
mysql php replikasi tuan-hamba

Dengan perkembangan pesat Internet, aplikasi web semakin menyepadukan operasi pangkalan data. MySQL ialah sistem pangkalan data hubungan yang terkenal di dunia yang digunakan secara meluas. Dalam aplikasi web yang sangat serentak, replikasi tuan-hamba MySQL adalah cara penting untuk meningkatkan prestasi dan ketersediaan pangkalan data. Artikel ini akan memperkenalkan cara menggunakan PHP untuk melaksanakan replikasi master-slave pangkalan data MySQL.

1. Apakah replikasi master-slave MySQL

Replikasi master-slave MySQL merujuk kepada menyalin data satu pelayan pangkalan data MySQL ke pelayan lain untuk memastikan data kedua-dua pelayan MySQL konsisten. Salah satu pelayan dipanggil pelayan induk dan bertanggungjawab untuk mengemas kini data dalam masa nyata; pelayan lain dipanggil pelayan hamba dan bertanggungjawab untuk menyegerakkan data daripada pelayan induk. Replikasi tuan-hamba boleh meningkatkan kebolehskalaan dan toleransi kesalahan sistem. Sebagai contoh, apabila pelayan utama turun, pelayan hamba boleh mengambil alih kerja pelayan utama untuk memastikan operasi normal perniagaan.

2. Prinsip pelaksanaan replikasi tuan-hamba

Prinsip pelaksanaan replikasi tuan-hamba adalah seperti berikut:

  1. Pelayan induk merekodkan operasi kemas kini dalam log binari (Binary Log ).
  2. Pelayan hamba bersambung ke pelayan induk, meminta untuk mendapatkan log binari yang perlu disegerakkan dan menyalinnya ke lognya sendiri.
  3. Pelayan hamba melaksanakan operasi kemas kini dalam log binari pelayan induk ke dalam pangkalan datanya sendiri untuk memastikan bahawa data dalam dua pangkalan data adalah konsisten.

3. Bagaimana untuk melaksanakan replikasi tuan-hamba dalam PHP

  1. Konfigurasikan log binari pelayan utama

Pelayan utama memerlukan untuk dikonfigurasikan dalam my.cnf Dayakan pengelogan binari dalam fail. Buka fail my.cnf dan tambah konfigurasi berikut dalam bahagian [mysqld]:

server-id=1
log-bin=/var/log/mysql/mysql-bin.log
Salin selepas log masuk

Antaranya, server-id digunakan untuk mengenal pasti pelayan utama, dan log-bin digunakan untuk menentukan laluan fail log itu.

  1. Konfigurasikan maklumat pelayan induk pelayan hamba

Pelayan hamba perlu menambah maklumat sambungan pelayan induk dalam fail konfigurasi my.cnf. Buka fail my.cnf dan tambahkan konfigurasi berikut dalam bahagian [inisd_client]:

server-id=2
master-host=10.0.0.1
master-user=repl_user
master-password=repl_password
master-port=3306
Salin selepas log masuk

Antaranya, server-id digunakan untuk mengenal pasti pelayan hamba, tuan-tuan menentukan alamat IP pelayan induk , master-user dan master -password menentukan nama pengguna dan kata laluan pelayan induk, dan master-port menentukan nombor port pelayan induk.

  1. Buat pengguna replikasi

Buat pengguna pada pelayan induk untuk data replikasi dan benarkan pengguna membaca log binari. Buka klien MySQL dan laksanakan arahan berikut:

mysql> CREATE USER 'repl_user'@'%' IDENTIFIED BY 'repl_password';
mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl_user'@'%';
Salin selepas log masuk
  1. Mulakan proses replikasi dalam pelayan hamba

Jalankan arahan berikut dalam klien MySQL pelayan hamba untuk mulakan proses replikasi :

mysql> CHANGE MASTER TO MASTER_HOST='10.0.0.1', 
  MASTER_USER='repl_user', MASTER_PASSWORD='repl_password', 
  MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=107;
mysql> START SLAVE;
Salin selepas log masuk

Antaranya, MASTER_LOG_FILE dan MASTER_LOG_POS boleh didapati dalam Binary Log pelayan utama.

Selepas melengkapkan langkah di atas, pelayan hamba akan menyalin data daripada pelayan induk untuk memastikan data dalam dua pangkalan data konsisten.

4. Ringkasan

Replikasi master-slave MySQL ialah teknologi penting untuk meningkatkan prestasi dan ketersediaan sistem. Ia adalah sangat mudah untuk melaksanakan replikasi induk-hamba MySQL menggunakan PHP Anda hanya perlu mendayakan log binari pada pelayan induk, mengkonfigurasi maklumat pelayan induk pada pelayan hamba, mencipta pengguna replikasi, dan memulakan proses replikasi. Dalam persekitaran pengeluaran sebenar, perhatian harus diberikan untuk menggunakan cara teknikal yang sesuai untuk membantu operasi dan penyelenggaraan pangkalan data untuk memastikan kestabilan dan keselamatan perkhidmatan pangkalan data.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan replikasi tuan-hamba pangkalan data MySQL dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

PHP dan Python: Membandingkan dua bahasa pengaturcaraan yang popular PHP dan Python: Membandingkan dua bahasa pengaturcaraan yang popular Apr 14, 2025 am 12:13 AM

PHP dan Python masing -masing mempunyai kelebihan mereka sendiri, dan memilih mengikut keperluan projek. 1.PHP sesuai untuk pembangunan web, terutamanya untuk pembangunan pesat dan penyelenggaraan laman web. 2. Python sesuai untuk sains data, pembelajaran mesin dan kecerdasan buatan, dengan sintaks ringkas dan sesuai untuk pemula.

Status Semasa PHP: Lihat trend pembangunan web Status Semasa PHP: Lihat trend pembangunan web Apr 13, 2025 am 12:20 AM

PHP tetap penting dalam pembangunan web moden, terutamanya dalam pengurusan kandungan dan platform e-dagang. 1) PHP mempunyai ekosistem yang kaya dan sokongan rangka kerja yang kuat, seperti Laravel dan Symfony. 2) Pengoptimuman prestasi boleh dicapai melalui OPCACHE dan NGINX. 3) Php8.0 memperkenalkan pengkompil JIT untuk meningkatkan prestasi. 4) Aplikasi awan asli dikerahkan melalui Docker dan Kubernet untuk meningkatkan fleksibiliti dan skalabiliti.

Relevannya PHP: Adakah ia masih hidup? Relevannya PHP: Adakah ia masih hidup? Apr 14, 2025 am 12:12 AM

PHP masih dinamik dan masih menduduki kedudukan penting dalam bidang pengaturcaraan moden. 1) kesederhanaan PHP dan sokongan komuniti yang kuat menjadikannya digunakan secara meluas dalam pembangunan web; 2) fleksibiliti dan kestabilannya menjadikannya cemerlang dalam mengendalikan borang web, operasi pangkalan data dan pemprosesan fail; 3) PHP sentiasa berkembang dan mengoptimumkan, sesuai untuk pemula dan pemaju yang berpengalaman.

Tujuan PHP: Membina Laman Web Dinamik Tujuan PHP: Membina Laman Web Dinamik Apr 15, 2025 am 12:18 AM

PHP digunakan untuk membina laman web dinamik, dan fungsi terasnya termasuk: 1. Menjana kandungan dinamik dan menghasilkan laman web secara real time dengan menyambung dengan pangkalan data; 2. Proses Interaksi Pengguna dan Penyerahan Bentuk, Sahkan Input dan Menanggapi Operasi; 3. Menguruskan sesi dan pengesahan pengguna untuk memberikan pengalaman yang diperibadikan; 4. Mengoptimumkan prestasi dan ikuti amalan terbaik untuk meningkatkan kecekapan dan keselamatan laman web.

Cara menyambung ke pangkalan data Apache Cara menyambung ke pangkalan data Apache Apr 13, 2025 pm 01:03 PM

Apache menyambung ke pangkalan data memerlukan langkah -langkah berikut: Pasang pemacu pangkalan data. Konfigurasikan fail web.xml untuk membuat kolam sambungan. Buat sumber data JDBC dan tentukan tetapan sambungan. Gunakan API JDBC untuk mengakses pangkalan data dari kod Java, termasuk mendapatkan sambungan, membuat kenyataan, parameter mengikat, melaksanakan pertanyaan atau kemas kini, dan hasil pemprosesan.

PHP dalam Tindakan: Contoh dan aplikasi dunia nyata PHP dalam Tindakan: Contoh dan aplikasi dunia nyata Apr 14, 2025 am 12:19 AM

PHP digunakan secara meluas dalam e-dagang, sistem pengurusan kandungan dan pembangunan API. 1) e-dagang: Digunakan untuk fungsi keranjang belanja dan pemprosesan pembayaran. 2) Sistem Pengurusan Kandungan: Digunakan untuk penjanaan kandungan dinamik dan pengurusan pengguna. 3) Pembangunan API: Digunakan untuk Pembangunan API RESTful dan Keselamatan API. Melalui pengoptimuman prestasi dan amalan terbaik, kecekapan dan pemeliharaan aplikasi PHP bertambah baik.

PHP dan Python: Contoh dan perbandingan kod PHP dan Python: Contoh dan perbandingan kod Apr 15, 2025 am 12:07 AM

PHP dan Python mempunyai kelebihan dan kekurangan mereka sendiri, dan pilihannya bergantung kepada keperluan projek dan keutamaan peribadi. 1.PHP sesuai untuk pembangunan pesat dan penyelenggaraan aplikasi web berskala besar. 2. Python menguasai bidang sains data dan pembelajaran mesin.

PHP: Pengendalian pangkalan data dan logik sisi pelayan PHP: Pengendalian pangkalan data dan logik sisi pelayan Apr 15, 2025 am 12:15 AM

PHP menggunakan sambungan MySQLI dan PDO untuk berinteraksi dalam operasi pangkalan data dan pemprosesan logik sisi pelayan, dan memproses logik sisi pelayan melalui fungsi seperti pengurusan sesi. 1) Gunakan MySQLI atau PDO untuk menyambung ke pangkalan data dan laksanakan pertanyaan SQL. 2) Mengendalikan permintaan HTTP dan status pengguna melalui pengurusan sesi dan fungsi lain. 3) Gunakan urus niaga untuk memastikan atomik operasi pangkalan data. 4) Mencegah suntikan SQL, gunakan pengendalian pengecualian dan sambungan penutup untuk debugging. 5) Mengoptimumkan prestasi melalui pengindeksan dan cache, tulis kod yang sangat mudah dibaca dan lakukan pengendalian ralat.

See all articles