Rumah > Artikel > pembangunan bahagian belakang > Bagaimana untuk melaksanakan sandaran pembezaan sandaran pangkalan data dalam PHP
Apabila jumlah data terus meningkat, sandaran pangkalan data menjadi lebih penting. Sandaran tetap pangkalan data boleh memastikan keselamatan data, tetapi sandaran penuh tradisional mengambil banyak ruang storan dan mengambil masa yang lama untuk membuat sandaran Cara melaksanakan sandaran pembezaan telah menjadi masalah yang perlu diselesaikan semasa proses sandaran. Dalam aplikasi PHP, cara untuk melaksanakan sandaran pembezaan sandaran pangkalan data adalah dengan menggunakan sandaran tambahan dan sandaran kebezaan.
Prinsip sandaran tambahan adalah untuk menyandarkan hanya data yang diubah. Mula-mula lakukan sandaran penuh, dan kemudian hanya sandarkan data yang telah berubah sejak sandaran penuh pada setiap sandaran. Apabila jumlah data bertambah, sandaran hanya akan menyandarkan data yang baru ditambah Jumlah data sandaran boleh dikurangkan dengan banyak, mengurangkan kos masa dan ruang sandaran.
Sandaran pembezaan adalah untuk menyandarkan data yang diubah antara titik masa tertentu dan titik masa sandaran terakhir. Sandaran pembezaan hanya menyandarkan perbezaan antara dua titik dalam masa Berbanding dengan sandaran penuh, sandaran pembezaan boleh menyandarkan kandungan data dengan lebih pantas dan menggunakan ruang storan dengan lebih berkesan. Sandaran pembezaan juga membantu sandaran tunggal tidak terlalu besar, menjadikan pemulihan dan pengurusan lebih mudah.
Sebagai bahasa back-end Internet, PHP sendiri tidak menyokong fungsi sandaran pangkalan data, tetapi PHP menyediakan beberapa antara muka operasi pangkalan data dan fungsi yang melaluinya fungsi sandaran pangkalan data boleh dilaksanakan. Berikut ialah cara PHP melaksanakan sandaran berbeza bagi sandaran pangkalan data:
Dalam PHP, sandaran tambahan boleh dicapai dalam dua cara:
1.1 Gunakan binlog MySQL
MySQL menyediakan binlog untuk merekod rekod operasi pangkalan data, termasuk operasi seperti penambahan, pemadaman, pengubahsuaian dan pertanyaan. Sandaran tambahan boleh dicapai dengan membaca binlog menggunakan PHP. Langkah-langkahnya adalah seperti berikut:
1) Dayakan binlog dan tambah maklumat berikut pada fail konfigurasi MySQL my.cnf:
[mysqld] log-bin=mysql-bin
Operasi ini akan membolehkan binlog dan menyimpan binlog dalam direktori data daripada laluan pemasangan MySQL.
2) Sambungkan ke pangkalan data MySQL dalam PHP, dan kemudian lakukan operasi berikut:
$conn = mysqli_connect('host', 'user', 'password'); $rs = mysqli_query($conn,"SHOW MASTER STATUS"); $row = mysqli_fetch_array($rs); $filename = $row['File']; $position = $row['Position']; $mysqlbinlog = 'mysqlbinlog -u root -p$pass --base64-output=decode-rows '; $cmd = $mysqlbinlog.' '.$filename.' --start-position='.$position; $data = shell_exec($cmd);
Operasi membaca di sini dilaksanakan melalui fungsi sistem dan arahan shell, dan data baca adalah binlog data. Daripada data binlog ini, kita boleh menganalisis pengubahsuaian sejak sandaran terakhir.
1.2 Gunakan cap masa
Kaedah ini agak mudah langkah-langkahnya adalah seperti berikut:
1) Semasa membuat sandaran pangkalan data, rekodkan cap masa semasa membuat sandaran.
2) Keluarkan cap masa sandaran terakhir sebelum membuat sandaran, dan bandingkan data antara dua cap masa untuk sandaran.
3) Kemas kini cap waktu selepas sandaran.
Kaedah ini memerlukan beberapa rakaman dan penyimpanan sebelum dan selepas sandaran, dan ia juga lebih menyusahkan untuk dikendalikan.
Kaedah biasa sandaran pembezaan ialah merekodkan cap masa sandaran berdasarkan sandaran penuh, dan kemudian keluarkan cap masa sandaran sebelumnya semasa setiap sandaran, dan bandingkan dua Data antara cap waktu disandarkan. Langkah-langkah pengendalian adalah seperti berikut:
1) Apabila melakukan sandaran penuh, rekodkan cap waktu sandaran pada masa yang sama.
2) Apabila membuat sandaran perbezaan, tanya data baharu dan dikemas kini selepas cap waktu sandaran terakhir dan sandarkannya.
3) Kemas kini cap waktu sandaran selepas sandaran.
Apabila melaksanakan sandaran pembezaan, anda juga boleh merekodkan semua kemas kini dan operasi memadam berdasarkan binlog MySQL. Berdasarkan rekod operasi, data yang diubah bagi setiap jadual boleh dikira dan disandarkan.
Dua kaedah sandaran yang disediakan dalam artikel ini, sandaran tambahan dan sandaran pembezaan, kedua-duanya boleh mencapai matlamat, tetapi situasi berkenaan masing-masing adalah berbeza. Jika kemas kini data adalah kerap, sandaran tambahan adalah kaedah yang lebih sesuai Sebaliknya, jika kemas kini data kurang kerap, sandaran pembezaan harus dipilih. Dalam aplikasi sebenar, adalah perlu untuk membuat pertimbangan berdasarkan situasi sebenar dan memilih kaedah sandaran yang lebih sesuai.
Atas ialah kandungan terperinci Bagaimana untuk melaksanakan sandaran pembezaan sandaran pangkalan data dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!