MySQL内建复制功能来优化可用性_MySQL
MySQL内建复制功能来优化可用性,在Soundbreak我们每天24小时不间断地播放实况音频和视频,所以对于MySQL的新增的复制特性,我们不能做出很令人信服的测试。通过测试我们发现,可以使用这个特性来与备份数据库服务器保持数据同步,这样当主服务器因为某种原因处理失效时,能够使用备份机处理所有的查询。对于这样的要求,配置两台服务器并不困难。我将详细讨论整个处理过程,同时讨论一下当主服务器失效时,如何使用PHP来重定向查询。
MySQL内部复制功能是建立在两个或两个以上服务器之间,通过设定它们之间的主-从关系来实现的。其中一个作为主服务器,其它的作为从服务器。我将详细讨论如何配置两台服务器,将一个设为主服务器,另一个设为从服务器。并且描述一下在它们之间进行切换的处理过程。我是在MySQL的3.23.23版本上进行的配置设置过程,并且也是在这个版本上进行的测试。MySQL开发人员建议最好使用最新版本,并且主-从服务器均使用相同的版本。同时MySQL 3.23版本仍然是beta测试版,而且这个版本可能不能向下兼容。所以因为这个原因,在实际的网站中,我现在还没有使用这个版本。拥有容错能力具有一个好处是,在不需中断任何查询的情况下,对服务器进行升级。
第一步:配置主服务器
在这篇文章的剩下篇幅中,我将指定两台服务器。A(IP为10.1.1.1)作为主服务器(简称为主机)。B(IP为10.1.1.2)作为后备服务器(简称为备机)。
MySQL的复制功能的实现过程为:备机(B)与主机(A)连接,然后读出主机的二进制更新日志,再将发生的变化合并到自已的数据库中。备机需要一个用户帐号来与主机连接,所以在主机上创建一个帐号,并只给它FILE权限,如下操作: GRANT FILE ON *.* TO replicate@10.1.1.2 IDENTIFIED BY ’password’;
为了备机能够与主机连接,要在主机上运行’FLUSH PRIVILEGES’,不过不要担心,因为我们将在下面的步骤中停掉服务器。
现在我们需要主机数据库的一个快照,并且对主机进行配置,允许生成二进制的更新日志。首先编辑’my.cnf’文件,以便允许二进制更新日志,所以在[MySQLd]部分的下面某个地方增加一行:’log-bin’。在下一次服务器启动时,主机将生成二进制更新日志(名为:-bin.)。为了让二进制更新日志有效,关闭MySQL服务程序,然后将主机上的所有数据库目录到另一个目录中,接着重新启动mysqld。
请确定得到了所有数据库,否则在进行复制时,如果一个表在主机上存在但在备机上不存在,将因为出错而退出。现在你已经得到了数据的快照,和一个从建立快照以来的二进制日志,上面记录着任何对数据库的修改。请注意MySQL数据文件(*.MYD,*.MYI和*.frm)是依赖于文件系统的,所以你不能仅仅进行文件传输,如从Solaris到Linux。如果你处于一个异种的服务器环境,你将不得不使用mysqldump实用程序或其它的定制脚本来得到数据快照。
第二步:配置备机
让我们继续。停掉备机上的MySQL服务程序,并且把从主机上拷贝来的数据库目录移到备机上的data目录下。请确认将目录的拥有者和属组改变为MySQL用户相应值,并且修改文件模式为660(只对拥有者和属组可读、可写),目录本身为770(只对拥有者和属组可读、可写和可执行)。
继续。在备机上启动MySQL服务程序,确认MySQL工作正常。运行几个select查询(不要update或insert查询),看一看在第一步中得到的数据快照是否成功。接着,在测试成功后关掉MySQL服务程序。
在备机上配置需要访问的主机,以便接收主机的更改。所以需要编辑务机上的’my.cnf’文件,在[MySQLd]部分中增加下面几行: master-host=10.1.1.1
master-user=replicate
master-password=password
在启动备机服务程序后,备机服务程序将查看在’my.cnf’文件中所指定的主机,查看是否有改变,并且将这些改变合并到自已的数据库中。备机保持了主机的更新记录,这些记录是从主机的’master.info’文件中接收下来的。备机线程的状态可以通过sql命令’SHOW SLAVE-STATUS’看到。在备机上处理二进制日志中如果发生错误,都将导致备机线程的退出,并且在*.err的日志文件中生成一条信息。然后错误可以被改正,接着可以使用sql语句’SLAVE START’来重新启动备机线程。线程将从主机二进制日志处理中断的地方继续处理。
至此,在主机上所发生的数据改变应该已经复制到备机上了,要测试它,你可以在主机上插入或更新一条记录,而在备机上选择这条记录。
现在我们拥有了从A机到B机的这种主-从关系,这样当A机可能当机的时候,允许我们将所有的查询重定向到B机上去,但是当A机恢复时,我们没有办法将发生的改变恢复到A机中去。为了解决这个问题,我们创建从B机到A机的主-从关系。
第三步:创建相互的主从关系
首先在B机上的my.cnf文件中,在[MySQLd]部分中加入’log-bin’,接着重新启动mysqld,然后创建可在
它的上面执行复制功能的用户帐号,使用: GRANT FILE ON *.* TO replicate@10.1.1.1 IDENTIFIED BY ’password’;
在B机上运行’FLUSH PRIVILEGES’命令,以便装入在加入复制用户后的新的授权表,接着回到A机上,在它的’my.cnf’中加入下面几行: master-host=10.1.1.2
master-user=replicate master-password=password
在重启A机的服务程序之后,现在我们一拥有了在A机与B机之间的相互主-从关系。不管在哪个服务器上 更新一条记录或插入一条记录,都将被复制到另一台服务器上。要注意的是:我不敢确定一个备机合并二进 制日志变化的速度有多快,所以用这种方法来进行插入或更新语句的负载平衡可能不是一个好办法。

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

Dalam versi terkini iOS17, Apple telah menyepadukan ciri baharu yang membolehkan anda menggunakan LivePhotos untuk menghiasi latar belakang skrin kunci iPhone anda. Aspek yang menarik ialah foto langsung ini menjadi hidup setiap kali anda menyalakan paparan iPhone anda. Berikut ialah cara menggunakan Live Photos sebagai kertas dinding skrin kunci anda pada iPhone anda yang menjalankan iOS 17. Cara Memohon Foto Langsung sebagai Kertas Dinding Skrin Kunci pada iPhone Diperlukan: Kemas Kini iOS17. (Semak Tetapan > di bawah Umum >Kemas Kini Perisian). Anda boleh menggunakan foto langsung yang anda tangkap pada iPhone anda sebagai kertas dinding skrin kuncinya dalam iOS17. Kunci skrin apabila menggunakan foto langsung sebagai kertas dinding

Apakah pendapat anda tentang furmark? 1. Tetapkan "Mod Jalankan" dan "Mod Paparan" dalam antara muka utama, dan juga laraskan "Mod Ujian" dan klik butang "Mula". 2. Selepas menunggu seketika, anda akan melihat keputusan ujian, termasuk pelbagai parameter kad grafik. Bagaimanakah furmark layak? 1. Gunakan mesin pembakar furmark dan semak hasilnya selama kira-kira setengah jam Ia pada asasnya berlegar sekitar 85 darjah, dengan puncak 87 darjah dan suhu bilik 19 darjah. Casis besar, 5 port kipas casis, dua di hadapan, dua di atas, dan satu di belakang, tetapi hanya satu kipas dipasang. Semua aksesori tidak overclock. 2. Dalam keadaan biasa, suhu biasa kad grafik hendaklah antara "30-85℃". 3. Walaupun suhu ambien terlalu tinggi pada musim panas, suhu biasa ialah "50-85℃"

Pada iPhone 15, jika anda mengambil foto seseorang, kucing atau anjing, kamera akan mengesan mereka dalam bingkai dan secara automatik menangkap maklumat kedalaman yang kaya, membolehkan anda mengubahnya menjadi foto yang menarik perhatian serta-merta atau kemudian dalam Foto. app. Potret keajaiban. Begini caranya. Mod Potret Apple telah menjadi cara popular untuk mengambil gambar yang mengagumkan menggunakan kesan kedalaman medan bokeh, membolehkan pengguna iPhone mengambil gambar di mana subjek kekal tajam walaupun latar belakang kabur. Pada iPhone sebelumnya, mod foto Potret menggunakan sistem yang lebih sukar berbanding foto biasa untuk menangkap peta kedalaman dalam imej, yang mengakibatkan lebih banyak ketinggalan pengatup dan kurang sokongan untuk HDR Pintar. Walau bagaimanapun, pada model iPhone15, generasi baharu Apple

"Ujian Inaction" bagi MMORPG dongeng fantasi baharu "Zhu Xian 2" akan dilancarkan pada 23 April. Apakah jenis kisah pengembaraan dongeng baharu yang akan berlaku di Benua Zhu Xian beribu-ribu tahun selepas karya asal? The Six Realm Immortal World, akademi abadi sepenuh masa, kehidupan abadi percuma, dan semua jenis keseronokan di dunia abadi sedang menunggu rakan-rakan abadi untuk meneroka secara peribadi! Pra-muat turun "Wuwei Test" kini dibuka Rakan-rakan Fairy boleh pergi ke laman web rasmi untuk memuat turun Anda tidak boleh log masuk ke pelayan permainan sebelum pelayan dilancarkan sudah selesai. Waktu pembukaan "Zhu Xian 2" "Inaction Test": 23 April 10:00 - 6 Mei 23:59 Bab pengembaraan dongeng baharu sekuel ortodoks kepada Zhu Xian "Zhu Xian 2" adalah berdasarkan novel "Zhu Xian" sebagai cetak biru Berdasarkan pandangan dunia karya asal, latar belakang permainan ditetapkan

Kemahiran menguji pangkalan data di Golang Pengenalan: Ujian pangkalan data adalah pautan yang sangat penting semasa membangunkan aplikasi. Kaedah ujian yang sesuai boleh membantu kami menemui masalah yang berpotensi dan memastikan ketepatan operasi pangkalan data. Artikel ini akan memperkenalkan beberapa teknik ujian pangkalan data biasa di Golang dan memberikan contoh kod yang sepadan. 1. Menguji menggunakan pangkalan data dalam memori Semasa menulis ujian berkaitan pangkalan data, kita biasanya menghadapi soalan: Bagaimana untuk menguji tanpa bergantung pada pangkalan data luaran? Di sini kita boleh menggunakan memori

Bagaimana untuk menggunakan MTR untuk menjalankan ujian kebolehpercayaan pangkalan data MySQL? Gambaran Keseluruhan: MTR (MySQL Test Runner) ialah alat ujian yang disediakan secara rasmi oleh MySQL, yang boleh membantu pembangun menjalankan ujian fungsian dan prestasi pangkalan data MySQL. Semasa proses pembangunan, untuk memastikan kebolehpercayaan dan kestabilan pangkalan data, kami sering perlu menjalankan pelbagai ujian, dan MTR menyediakan kaedah yang mudah, mudah dan boleh dipercayai untuk menjalankan ujian ini. Langkah: Pasang MySQL test runner: Pertama, anda perlu memuat turunnya dari laman web rasmi MySQL

"Operation Delta" akan melancarkan ujian PC berskala besar yang dipanggil "Codename: ZERO" hari ini (7 Mac). Hujung minggu lalu, permainan ini mengadakan acara pengalaman flash mob luar talian di Shanghai, dan 17173 juga bertuah kerana dijemput untuk mengambil bahagian. Ujian ini hanya tinggal lebih empat bulan lagi daripada kali terakhir, yang membuatkan kami tertanya-tanya, apakah sorotan dan kejutan baharu yang akan dibawa oleh "Operasi Delta" dalam tempoh yang singkat? Lebih empat bulan yang lalu, saya mengalami "Operasi Delta" dalam sesi merasa luar talian dan versi beta pertama. Pada masa itu, permainan hanya membuka mod "Tindakan Berbahaya". Walau bagaimanapun, Operasi Delta sudah mengagumkan pada zamannya. Dalam konteks pengeluar utama yang berpusu-pusu ke pasaran permainan mudah alih, FPS sedemikian yang setanding dengan piawaian antarabangsa

Ujian fungsional mengesahkan kefungsian fungsi melalui ujian kotak hitam dan kotak putih, manakala liputan kod mengukur bahagian kod yang diliputi oleh kes ujian. Bahasa yang berbeza (seperti Python dan Java) mempunyai rangka kerja ujian, alat liputan dan ciri yang berbeza. Kes praktikal menunjukkan cara menggunakan Unittest and Coverage Python dan JUnit dan JaCoCo Java untuk ujian fungsi dan penilaian liputan.
