mysql5.6.14主从复制(也称mysql AB复制)环境配置方法
一、mysql主(称master)从(称slave)复制的原理:
(1).master将数据改变记录到二进制日志(binary log)中,也即是配置文件log-bin指定的文件(这些记录叫做二进制日志事件,binary log events)
(2).slave将master的binary log events拷贝到它的中继日志(relay log)
(3).slave重做中继日志中的事件,将改变反映它自己的数据(数据重演)
附简要原理图:
二、mysql主从复制支持的类型:
(1).基于语句的复制:在主服务器上执行的SQL语句,在从服务器上执行同样的语句.MySQL默认采用基于语句的复制,效率比较高
word-spacing: 0px"> (2).基于行的复制:把改变的内容直接复制过去,而不关心到底改变该内容是由哪条语句引发的 . 从mysql5.0开始支持
word-spacing: 0px"> (3).混合类型的复制: 默认采用基于语句的复制,一旦发现基于语句的无法精确的复制时,就会采用基于行的复制.
三、主从配置需要注意的地方:
(1).主DB server和从DB server数据库的版本一致
(2).主DB server和从DB server数据库数据一致[ 这里就会可以把主的备份在从上还原,也可以直接将主的数据目录拷贝到从的相应数据目录]
(3).主DB server开启二进制日志,主DB server和从DB server的server_id都必须唯一
四、主从配置的简要步骤:
附简要示意图:
1.主DB SERVER上的配置
(1).安装数据库
(2).修改数据库配置文件,指明server_id,开启二进制日志(log-bin)
(3).启动数据库,查看当前是哪个日志,position号是多少
(4).登陆数据库,授权用户[ip地址为从机IP地址,如果是双向主从,这里的还需要授权本机的IP地址(此时自己的IP地址就是从IP地址)]
(5).备份数据库[记得加锁和解锁]
(6).传送备份到从DB server上
(7).启动数据库
以下步骤,为单向主从搭建成功,想搭建双向主从需要的步骤:
(1).登陆数据库,指定主DB server的地址,用户,密码等信息[此步仅双向主从时,需要]
(2).开启同步,查看状态
2.从DB SERVER上的配置
(1).安装数据库
(2).修改数据库配置文件,指明server_id[如果是搭建双向主从的话,也要开启二进制日志(log-bin)]
(3).启动数据库,还原备份
(4).查看当前是哪个日志,position号是多少[单向主从此步不需要,双向主从需要]
(5).指定主DB server的地址,用户,密码等信息
(6).开启同步,查看状态
五、单向主从环境[也称 mysql A/B复制]的搭建案例:
1.主DB server和从DB server都安装相应版本的数据库,我的两台DB server都已经安装好(5.6.14版本),都会是双实例,这里就不演示安装,可以参考mysql源码编译安装和mysql多实例配置两篇文章
注:两台机器的的selinux都是disable(永久关闭selinux,请修改/etc/selinux/config,将SELINUX改为disabled),防火墙可以选择关闭,开启的话也行[不行的话,添加防火墙策略]
2.修改主DB server的配置文件(/etc/my.cnf),开启日志功能,设置server_id值,保证唯一[client102为主DB server]
[root@client102 scripts]# vim /etc/my.cnf # 修改配置文件里,下面两个参数: # 设置server_id,一般建议设置为IP,或者再加一些数字 server_id =102 # 开启二进制日志功能,可以随便取,最好有含义 log-bin=mysql3306-bin
3.启动数据库服务器,并登陆数据库,授予相应的用户用于同步
# 我这里是多实例mysql,所以启动是这样的,如果大家是单实例的,就直接启动就可以[/etc/init.d/mysqld start] [root@client102 scripts]# mysqld_multi start 3306 # 登陆mysql 服务器 [root@client102 scripts]# mysql -uroot -S /usr/local/mysql/mysqld3306.sock -p # 授予用户权限用于主从同步 mysql> grant replication slave on *.* to 'kongzhong'@'192.168.1.100' identified by 'kongzhong'; Query OK, 0 rows affected (0.00 sec) # 刷新授权表信息 mysql> flush privileges; Query OK, 0 rows affected (0.00 sec) # 查看position 号,记下position 号(很重要,从机上需要这个position号和现在的日志文件,我这里是414和mysql3306-bin.000001) mysql> show master status; +----------------------+----------+--------------+------------------+-------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | +----------------------+----------+--------------+------------------+-------------------+ | mysql3306-bin.000001 | 414 | | | | +----------------------+----------+--------------+------------------+-------------------+ 1 row in set (0.00 sec)
4.为保证主DB server和从DB server的数据一致,这里采用主备份,从还原来实现初始数据一致
代码如下:
# 临时锁表 mysql> flush tables with read lock; # 我这里实行的全库备份,在实际中,我们可能只同步某一个库,可以只备份一个库 # 新开一个终端,执行如下操作 [root@client102 data] # mysqldump -p3306 -uroot -p -S /usr/local/mysql/mysqld3306.sock --all-databases > /tmp/mysql.sql # 解锁 mysql> unlock tables; # 将备份的数据传送到从机上,用于恢复 [root@client102 data]# scp /tmp/mysql.sql root@192.168.1.100:/tmp
5.从DB server配置文件只需修改一项,其余用命令行做
代码如下:
[root@client100 ~]# vim /etc/my.cnf # 设置server_id,一般建议设置为IP,或者再加一些数字 server_id =100
6.启动数据库,还原备份数据
代码如下:
# 启动数据库 [root@client100 ~]# mysqld_multi start 3306 # 还原主DB server备份的数据 [root@client100 ~]# mysql -uroot -S /usr/local/mysql/mysqld3306.sock -p < /tmp/mysql.sql
7.登陆数据库,添加相关参数(主DBserver的ip/端口/同步用户/密码/position号/读取哪个日志文件)
代码如下:
[root@client100 ~]# mysql -uroot -S /usr/local/mysql/mysqld3306.sock -p mysql> change master to -> master_host='192.168.1.102', -> master_user='kongzhong', -> master_password='kongzhong', -> master_port=3306, -> master_log_file='mysql3306-bin.000001', -> master_log_pos=414; #/* 下面是一部分注解: #/* 指定主DB server的IP地址 master_host='192.168.1.102' #/* 指定用于同步的用户[这个就是我们在主DB server授权的用户] master_user='kongzhong' #/* 指定用于同步的用户的密码 master_password='kongzhong' #/* 指定主DB server的端口[下面一个例子,可以重点看这个] master_port=3306 #/* 指定从DB server 从哪个日志文件开始读[在主DB server上使用show master status查看到日志] master_log_file='mysql3306-bin.000001' #/* 指定 从哪个POSITION号开始读 master_log_pos=414 # 开启主从同步 mysql> start slave; # 查看主从同步状态 mysql> show slave status\G; # 主要看以下两个参数:[这两个参数如果是yes就表示主从同步正常] Slave_IO_Running: Yes Slave_SQL_Running: Yes
8.下面大家就可以在主DB server上新建一个表,看是否能同步到从DB server上,我这里就不测试了
[注:千万不要在从DB server手动插入数据,那样数据就不一致,主从就会断开,需要重新配置了]
如果有问题,可以尝试关闭IPTABLES(/etc/init.d/iptables stop)和selinux(setenforce 0:临时关闭selinux,永久关闭selinux,请修改/etc/selinux/config,将SELINUX改为disabled)
9.上面所搭建的是单向主从,也是用的比较多的,有人想了解双向主从是如何搭建,其实,就是主DB server和从DB sever都开启日志功能,然后在主DB SERVER执行授权用户[这里授权的是自己作为从服务器,也就是这里的IP地址是主DB server的IP地址],然后再在主DB server上进行chang master操作.有不理解的可以留言询问.
以上就是mysql5.6.14主从复制(也称mysql AB复制)环境配置方法的内容,更多相关内容请关注PHP中文网(www.php.cn)!

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

Sistem Win11 ialah sistem pengendalian Windows terkini, dan pengguna mungkin menghadapi beberapa masalah konfigurasi apabila menggunakannya. Antaranya, mengkonfigurasi pembolehubah persekitaran Python adalah keperluan biasa kerana ia membolehkan pengguna menggunakan arahan Python dengan mudah dari mana-mana lokasi. Artikel ini akan memperkenalkan cara mengkonfigurasi pembolehubah persekitaran Python dalam sistem Win11 supaya pengguna boleh menggunakan bahasa pengaturcaraan Python dengan lebih mudah. 1. [Klik kanan] komputer ini pada desktop, dan pilih [Properties] dalam item menu yang terbuka 2. Kemudian, di bawah pautan berkaitan, cari dan klik [Advanced System Settings] 3. Dalam tetingkap sifat sistem, klik [Persekitaran] di bahagian bawah Pembolehubah]; 4. Dalam tetingkap pembolehubah persekitaran, di bawah pembolehubah sistem, pilih [Laluan], dan kemudian klik

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 induk-hamba MySQL merujuk kepada penyalinan data dari satu pelayan pangkalan data MySQL ke pelayan yang lain.

Bahasa Go ialah bahasa pengaturcaraan yang disusun secara statik yang dibangunkan oleh Google. Ia mempunyai kedudukan yang unik di kalangan bahasa pengaturcaraan moden dan digunakan secara meluas dalam pengkomputeran awan, pengaturcaraan rangkaian, data besar dan bidang lain. Apabila bahasa Go menjadi semakin popular, semakin ramai pengaturcara mula mempelajari bahasa Go, dengan harapan dapat menguasai ciri dan kemahiran aplikasi bahasa ini. Walau bagaimanapun, bagi pelajar yang mempunyai asas sifar, konfigurasi persekitaran bahasa Go sering menjadi penghalang pertama kepada pembelajaran mereka. Sebelum mempelajari bahasa Go, kita perlu membina bahasa yang sesuai

Membina Kluster MySQL Sangat Tersedia: Panduan Amalan Terbaik untuk Replikasi Master-Slave dan Pengimbangan Beban Dalam beberapa tahun kebelakangan ini, dengan perkembangan pesat Internet, pangkalan data telah menjadi salah satu enjin penyimpanan dan pemprosesan data teras untuk kebanyakan aplikasi web. Dalam senario ini, ketersediaan tinggi dan pengimbangan beban telah menjadi pertimbangan penting dalam reka bentuk seni bina pangkalan data. Sebagai salah satu pangkalan data hubungan sumber terbuka yang paling popular, penyelesaian penggunaan kluster MySQL telah menarik banyak perhatian. Artikel ini akan memperkenalkan cara untuk melaksanakan kluster pangkalan data yang sangat tersedia melalui replikasi tuan-hamba MySQL dan pengimbangan beban.

Sebagai bahasa pengaturcaraan sumber terbuka, bahasa Go digemari oleh semakin ramai pembangun. Kesederhanaan, kecekapan dan sifat merentas platformnya telah dipuji secara meluas. Sebelum mempelajari dan menggunakan bahasa Go, anda perlu mengkonfigurasi persekitaran terlebih dahulu untuk menjalankan kerja pembangunan dengan lancar. Artikel ini akan memberi anda panduan konfigurasi persekitaran bahasa Go yang komprehensif dan mengajar anda langkah demi langkah cara menyediakan persekitaran pembangunan, yang membolehkan anda memulakan pembangunan bahasa Go dengan mudah. 1. Pasang bahasa Go Mula-mula, kita perlu memuat turun dan memasang versi terkini bahasa Go. Anda boleh menemuinya di laman web rasmi Go

PyCharm ialah persekitaran pembangunan bersepadu (IDE) yang biasa digunakan oleh banyak pembangun Python Ia menyediakan pelbagai fungsi dan alatan untuk memudahkan pembangun menulis, nyahpepijat dan menguji kod Python dengan cekap. Sebelum menggunakan PyCharm untuk pembangunan, langkah penting ialah mengkonfigurasi persekitaran PyCharm. Artikel ini akan menyediakan pemaju Python dengan panduan konfigurasi persekitaran PyCharm, termasuk memasang PyCharm, mengkonfigurasi penterjemah Python, menyediakan persekitaran maya, dll. Ia juga akan disertakan dengan alatan.

Dengan perkembangan pesat Internet, tugas pembangun juga menjadi pelbagai dan kompleks. Khususnya untuk pembangun bahasa PHP, salah satu masalah yang paling biasa dihadapi semasa proses pembangunan adalah ralat ketidakkonsistenan data antara persekitaran pembangunan dan persekitaran pengeluaran. Oleh itu, cara mengendalikan ralat ini merupakan isu penting yang mesti dihadapi oleh pembangun semasa membangunkan aplikasi PHP. Perbezaan antara persekitaran pembangunan dan persekitaran pengeluaran Perkara pertama yang perlu dijelaskan ialah persekitaran pembangunan dan persekitaran pengeluaran adalah berbeza, dan ia mempunyai tetapan dan konfigurasi yang berbeza. dalam persekitaran pembangunan

Tutorial konfigurasi persekitaran Maven: Langkah konfigurasi permulaan pantas Maven ialah alat pengurusan projek yang berkuasa yang boleh membantu pembangun membina projek secara automatik, mengurus kebergantungan, melaksanakan ujian, dsb. Apabila belajar dan menggunakan pembangunan Java, mengkonfigurasi persekitaran Maven adalah kemahiran penting. Artikel ini akan memperkenalkan anda kepada cara mengkonfigurasi persekitaran Maven dengan cepat, termasuk satu siri langkah seperti memasang Maven, mengkonfigurasi pembolehubah persekitaran, mencipta projek, dsb., dan menyediakan contoh kod khusus untuk membantu anda memahami dengan lebih baik. Langkah 1: Muat turun dan pasang Mave
