<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
檢視主庫(master)和從庫(slave)的ip地址,並檢測是否可以通訊
保證master和slave之間網路是互通的,用ping命令檢測
到這裡我們知道,master的ip為192.168.131.129,slave的ip為192.168.0.6,並且可以相互通訊。保證3306埠開放
檢視防火牆狀態systemctl status firewalld.service
臨時手動啟動防火牆systemctl start firewalld.service
臨時手動停止防火牆systemctl stop firewalld.service
持久開啟防火牆(重啟服務生效)systemctl enable firewalld.service
持久關閉防火牆(重啟服務生效)systemctl disable firewalld.service
檢視當前開放的埠列表firewall-cmd --list-ports
設定log_bin和全域性唯一的server-id,和slave區分開,不能設定成一樣的(如果是my.cnf新新增設定,一定要重啟MySQL服務)
vim /etc/my.cnf
開啟my.cnf檔案
即在master中建立一個賬號,用於slave登入master讀取binlog
雖然我們在Linux上檢視的ip地址是192.168.131.129,但我們建立賬戶登入時不寫這個ip,寫的是192.168.131.1。因為我這裡虛擬機器器用的是NAT模式(如果是橋接模式就可以直接用了),虛擬機器器(master)和物理機(slave)通訊的時候,虛擬機器器先把資料傳送到閘道器192.168.131.1(預設與VMnet8通訊),192.168.131.1再轉發到物理機,所以物理機接收到的是192.168.131.1的資料,故我們在master上為slave建立賬戶的時候,應該寫192.168.131.1
如果給slave設定的不是閘道器192.168.131.1地址,vim + /var/log/mysqld.log
開啟錯誤紀錄檔會有如下資訊:
這說的就是從192.168.131.1的mslave許可權不夠,那是因為我們在master設定的是允許從其他地方登入,並不允許從192.168.131.1地址登入,導致許可權不夠。
由於master這邊收到的是來自192.168.131.1的請求,所以錯誤紀錄檔顯示的是192.168.131.1
建立使用者的命令:
//如果嫌麻煩可以用%代替192.168.131.1,,它就可以匹配任何ip mysql> CREATE USER 'mslave'@'192.168.131.1' IDENTIFIED BY '1qaz@WSX'; //啟動主從,在主庫上給當前的mslave使用者開啟REPLICATION SLAVE主從複製的許可權,從庫就可以通過1qaz@WSX賬戶密碼 //從192.168.131.1 IP地址來請求存取這臺主庫上的任意庫裡面的任意表*.*,同步這個主庫的任意庫裡的任意表 mysql> GRANT REPLICATION SLAVE ON *.* to 'mslave'@'192.168.131.1' IDENTIFIED BY '1qaz@WSX'; mysql> FLUSH PRIVILEGES;
show master status
設定全域性唯一的server-id
涉及修改組態檔,需要重啟MySQL服務
這一步設定主要是給IO執行緒讀取binlog使用:
mysql> CHANGE MASTER TO MASTER_HOST='192.168.131.129', MASTER_PORT=3306, MASTER_USER='mslave', MASTER_PASSWORD='1qaz@WSX', MASTER_LOG_FILE='mysql-bin.000006', MASTER_LOG_POS=1262;
通過show slave status
命令檢視主從複製狀態,show processlist
檢視master和salve相關執行緒的執行狀態
通過show slave status命令檢視主從複製狀態
連線connection錯粗,先考慮網路是否互通,ping一下:
然後再檢查從庫裡面的設定資訊是否正確
如果都正確,檢查主庫所在機器的3306埠是否正常
telnet xxx.xxx.xxx.xxx 3306
如果發現3306埠不能連通,就需要懷疑主庫對埠有限制嗎,也就是防火牆限制,就需要在防火牆把3306埠開放出來。
如果這個錯誤還沒解決,就檢視一個主庫的錯誤紀錄檔/var/log/mysql/mysqld.log
,檢視錯誤紀錄檔中提示的ip是否和自己允許slave登入的ip一致
這說的就是從192.168.131.1的mslave許可權不夠,自己玩的時候,如果虛擬機器器是NAT模式,則需要寫成VMnet8閘道器ip。如果都是物理機通訊,那直接寫正確的ip即可
可以在MySQL資料庫下的mysql庫的user表中更改允許登入的ip
然後重新賦予許可權:
mysql> GRANT REPLICATION SLAVE ON *.* to 'mslave'@'xxx.xxx.xxx.xxx' IDENTIFIED BY '1qaz@WSX';
在master中檢視show master status一下binlog紀錄檔檔名以及position,然後用命令重新設定slave,比如:
mysql> CHANGE MASTER TO MASTER_HOST='192.168.131.129',MASTER_PORT=3306,MASTER_USER='mslave',MASTER_PASSWORD='1qaz@WSX', MASTER_LOG_FILE='mysql-bin.000006',MASTER_LOG_POS=1262;
設定slave前需要stop slave,設定完成再start slave
錯誤原因:首先設定主從複製的時候,slave的mytest庫中沒有user表,而master的mytest庫已經有user表了。設定好主從複製後直接drop table mytest.user,這就會寫到binlog裡面,然後在通過dump執行緒和IO執行緒將這個操作傳送到從庫的relay log,然後從庫的SQL執行緒從relay log裡把drop table mytest.user撈出來在從庫執行這個SQL,可從庫的mytest根本就沒有user表,這就是刪除一個不存在的表,於是出現錯誤了。
一般我們是不會做這樣的操作的,我們一般都是主庫設定以後,slave從資料開始增量進行同步,不會同步以後一開始就刪主庫裡的東西,如果真的出現這樣的問題了,隨時可以通過show slave status
來檢視主從庫的狀態來解決錯誤,如果是上圖這個錯誤,
(1)可以在從庫stop slave
,然後把位置重新設定一下,然後再start slave
,相當於重新開始主從同步的位置。
(2)可以在從庫stop slave
,然後set global sql_slave_skip_counter=1;
(跳過一個錯誤),然後再start slave
重啟從庫的執行緒,相當於把錯誤跳過了,異常操作。
可以通過show slave status檢視以下標識,IO執行緒出錯一般是網路問題,SQL執行緒出錯一般是SQL在slave庫執行出現了問題
到此這篇關於MySQL 設定主從複製實踐分享的文章就介紹到這了,更多相關MySQL 設定主從複製 內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45