


Bagaimana untuk melaksanakan replikasi tuan-hamba pangkalan data MySQL dalam PHP
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:
- Pelayan induk merekodkan operasi kemas kini dalam log binari (Binary Log ).
- Pelayan hamba bersambung ke pelayan induk, meminta untuk mendapatkan log binari yang perlu disegerakkan dan menyalinnya ke lognya sendiri.
- 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
- 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
Antaranya, server-id digunakan untuk mengenal pasti pelayan utama, dan log-bin digunakan untuk menentukan laluan fail log itu.
- 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
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.
- 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'@'%';
- 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;
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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

PHP 8.4 membawa beberapa ciri baharu, peningkatan keselamatan dan peningkatan prestasi dengan jumlah penamatan dan penyingkiran ciri yang sihat. Panduan ini menerangkan cara memasang PHP 8.4 atau naik taraf kepada PHP 8.4 pada Ubuntu, Debian, atau terbitan mereka

Salah satu perubahan utama yang diperkenalkan dalam MySQL 8.4 (keluaran LTS terkini pada 2024) ialah pemalam "Kata Laluan Asli MySQL" tidak lagi didayakan secara lalai. Selanjutnya, MySQL 9.0 mengalih keluar pemalam ini sepenuhnya. Perubahan ini mempengaruhi PHP dan apl lain

Kod Visual Studio, juga dikenali sebagai Kod VS, ialah editor kod sumber percuma — atau persekitaran pembangunan bersepadu (IDE) — tersedia untuk semua sistem pengendalian utama. Dengan koleksi sambungan yang besar untuk banyak bahasa pengaturcaraan, Kod VS boleh menjadi c

Tutorial ini menunjukkan cara memproses dokumen XML dengan cekap menggunakan PHP. XML (bahasa markup extensible) adalah bahasa markup berasaskan teks yang serba boleh yang direka untuk pembacaan manusia dan parsing mesin. Ia biasanya digunakan untuk penyimpanan data

Rentetan adalah urutan aksara, termasuk huruf, nombor, dan simbol. Tutorial ini akan mempelajari cara mengira bilangan vokal dalam rentetan yang diberikan dalam PHP menggunakan kaedah yang berbeza. Vokal dalam bahasa Inggeris adalah a, e, i, o, u, dan mereka boleh menjadi huruf besar atau huruf kecil. Apa itu vokal? Vokal adalah watak abjad yang mewakili sebutan tertentu. Terdapat lima vokal dalam bahasa Inggeris, termasuk huruf besar dan huruf kecil: a, e, i, o, u Contoh 1 Input: String = "TutorialSpoint" Output: 6 menjelaskan Vokal dalam rentetan "TutorialSpoint" adalah u, o, i, a, o, i. Terdapat 6 yuan sebanyak 6

Jika anda seorang pembangun PHP yang berpengalaman, anda mungkin merasakan bahawa anda telah berada di sana dan telah melakukannya. Anda telah membangunkan sejumlah besar aplikasi, menyahpenyahpepijat berjuta-juta baris kod dan mengubah suai sekumpulan skrip untuk mencapai op

CMS bermaksud Sistem Pengurusan Kandungan. Ia adalah aplikasi perisian atau platform yang membolehkan pengguna mencipta, mengurus dan mengubah suai kandungan digital tanpa memerlukan pengetahuan teknikal lanjutan. CMS membolehkan pengguna membuat dan menyusun kandungan seperti teks, imej, video dan dokumen dengan mudah serta menerbitkannya di tapak web atau platform digital lain.

Array adalah struktur data linear yang digunakan untuk memproses data dalam pengaturcaraan. Kadang -kadang apabila kita sedang memproses tatasusunan kita perlu menambah unsur -unsur baru ke array yang sedia ada. Dalam artikel ini, kami akan membincangkan beberapa cara untuk menambah unsur -unsur ke akhir array dalam PHP, dengan contoh kod, output, dan analisis kerumitan masa dan ruang untuk setiap kaedah. Berikut adalah cara yang berbeza untuk menambah elemen ke array: Gunakan kurungan persegi [] Dalam PHP, cara untuk menambah unsur -unsur ke akhir array adalah menggunakan kurungan persegi []. Sintaks ini hanya berfungsi dalam kes -kes di mana kita mahu menambah hanya satu elemen. Berikut adalah sintaks: $ array [] = nilai; Contoh
