您好,登錄后才能下訂單哦!
下面一起來了解下MySQL數據庫5.6.16.主從復制如何搭建及配置,相信大家看完肯定會受益匪淺,文字在精不在多,希望MySQL數據庫5.6.16.主從復制如何搭建及配置這篇短內容是你想要的。
基于虛擬機,所以直接克隆一臺同樣的虛擬機操作
從庫:
[root@slave ~]# ifconfig eth0|awk -F '[ :]+''NR==2{print $4}';ifconfig eth2|awk -F '[ :]+' 'NR==2{print $4}'
192.168.56.42
172.16.1.42
/etc/init.d/iptables stop
或者:
Vim /etc/sysconfig/iptable
-A INPUT -m state --state NEW -m tcp -p tcp --dport3306 -j ACCEPT
主庫:要記錄bin_log,
[root@master ~]# cat -n /etc/my.cnf|sed -n '41p'
41 log_bin = /home/mysql/data/binlog/mysql-bin
保證server_id數值和主庫的不一樣。
[root@slave ~]# cat -n /etc/my.cnf|sed -n '11p'
11 server_id = 101
注意:云服務器的主機名不要隨意變動,否則導致MySQL服務重新啟動會報錯,必須殺當前的MySQL掉進程,然后再restart啟動MySQL服務
mysql 5.6的復制引入了uuid的概念,各個復制結構中的server_uuid得保證不一樣,但是查看到直接copy data文件夾后server_uuid是相同的,show variables like ‘%server_uuid%’;
同時要保證主從數據庫的auto.cnf中數值不一樣,同時必須保證兩臺主從的機器的防火墻都必須是關閉的。
修改兩臺云服務器上的文件/data/mysql/data/auto.cnf然后重啟數據庫服務就ok了
負責會報錯:1593
Last_IO_Error: Fatal error: The slave I/O threadstops because master and slave have equal MySQL server UUIDs; these UUIDs mustbe different for replication to work.
以及報錯:2003原因是防火墻沒有關閉。Change master 時密碼輸入錯誤導致。
Last_IO_Error: error connecting to master 'rep@172.16.1.41:3306' -retry-time: 60 retries: 1
提示:必須保證兩臺的云服務器的時間是一致的,要適時更新時間并且寫入定時任務
Crontab -l
###time sync###by wujianwei at 2016-5-19
*/5 * * * * /usr/sbin/ntpdatentp1.aliyun.com &>/dev/null
搭建一主多從數據庫時報錯:
在從庫操操作:
mysql> start slave;
ERROR 1201 (HY000): Could not initialize masterinfo structure; more error messages can be found in the MySQL error log
mysql> show slave status\G
Last_Errno:1872
Last_Error: Slave failed to initialize relay log info structure from therepository
在一臺主機上增加一個slave,啟動的時候報
[ERROR] Slave SQL: Slave failed toinitialize relay log info structure from the repository, Error_code: 1872
原因:檢查my.cnf,原來沒指定relay_log,mysql默認產生的relay_log名被該server上的另一個mysql slave占用了。
原因是:從庫的my.cnf配置文件中沒有加入參數
relay_log=/data/mysql/data/relay-log/mysql-relay-bin
1.stop slave;
2. reset slave;
mysql>reset slave
3.mysql>change master to
4.start slave
/etc/init.d/iptables stop
或者:
vim /etc/sysconfig/iptable
-A INPUT -m state --state NEW -m tcp -p tcp --dport3306 -j ACCEPT
echo "log_bin =/home/mysql/data/binlog/mysql-bin" /etc/my.cnf
sed -i 's#server_id = 100#server_id = 1#g'/etc/my.cnf
mkdir /home/mysql/data/binlog/ -p
chown mysql.mysql /home/mysql/data/binlog
mysql -uroot -p123456 -e "grant replicationslave on *.* to rep@'172.16.1.%' identified by '111111'; flush privileges "
mysqldump -uroot -p123456 -B -A -F -R -x--master-data=1 --events|gzip>/backup/rep_$(date +%F).sql.gz
mysqldump -uroot -p123456 -B -A -F -R -x--master-data=1 --events|gzip>/backup/rep_$(date +%F).sql.gz
mysql-uroot -p123456 -e "show master status;"
scp -rp -P22 /backup/rep_2016-08-18.sql.gz root@172.16.1.42:/backup/
vim /etc/sysconfig/iptables
-A INPUT -m state --state NEW -m tcp -p tcp--dport 3306 -j ACCEPT
sed -i 's#server_id = 100#server_id = 2#g' /etc/my.cnf
gzip -d /backup/rep_2016-08-18.sql.gz
mysql -uroot -p123456 </backup/rep_2016-08-18.sql
mysql -uroot -p123456 -e "CHANGE MASTERTO MASTER_HOST='172.16.1.41',MASTER_PORT=3306,MASTER_USER='rep',MASTER_PASSWORD='111111';startslave;show slave status\G" |grep -i "yes"
vim /etc/sysconfig/iptables
-A INPUT -m state --state NEW -m tcp -p tcp--dport 3306 -j ACCEPT
sed -i 's#server_id = 100#server_id = 3#g'/etc/my.cnf
vim /data/mysql/data/auto.cnf
/etc/init.d/mysqld restart
gzip -d rep_2016-08-18.sql.gz
mysql -uroot -p123456 </backup/rep_2016-08-18.sql
mysql -uroot -p123456 -e "showdatabases;"
mysql -uroot -p123456 -e "CHANGE MASTERTO MASTER_HOST='172.16.1.41',MASTER_PORT=3306,MASTER_USER='rep',MASTER_PASSWORD='111111';startslave;show slave status\G" |grep -i "yes"
Master:
mysql -uroot -p123456 -e "create databasewjw05"
mysql> use wjw01;
mysql> CREATE table `t1` (`id` bigint(12) NOTNULL auto_increment,`name` varchar(12) NOT NULL,PRIMARY KEY (`id`) );
mysql> INSERT INTO t1(name) values('oldboy');
slave:
mysql -uroot -p123456 -e "showdatabases"|grep wjw05
mysql -uroot -p123456 -e "showdatabases"|grep wjw05
mysql -uroot -p123456 -e "desc wjw01.t1"
mysql -uroot -p123456 -e "select * fromwjw01.t1"
看完MySQL數據庫5.6.16.主從復制如何搭建及配置這篇文章后,很多讀者朋友肯定會想要了解更多的相關內容,如需獲取更多的行業信息,可以關注我們的行業資訊欄目。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。