注意事項(xiàng):
主庫(kù)全庫(kù)備份完查看該文件binlog pos標(biāo)記位
文件名為:binlog_pos_innodb 記錄當(dāng)時(shí)mysql備份時(shí)主庫(kù)的標(biāo)記為
環(huán)境說(shuō)明:
兩臺(tái)安裝在CentOS7.4的MySQL5.7.22服務(wù)器:master 和 slave
Master服務(wù)器:
IP:192.168.80.51
Port:3306
Slave 服務(wù)器:
IP:192.168.80.52
Port:3306
配置步驟:
1、 修改master的my.cnf配置文件,開啟記錄日志并設(shè)置server-id。
2、 修改slave的my.cnf配置文件,開啟讀取二進(jìn)制日志并設(shè)置server-id。
3、 在slave上啟動(dòng)slave與master的連接。
4、 檢查是否配置成功與排錯(cuò)。
1、 master 庫(kù)my.cnf配置文件,在[mysqld]下添加如下配置:
A SERVER:
[client]
user = pmostc
password = pmostc
port = 3306
socket = /tmp/mysql.sock
[mysqld]
user = mysql
port = 3306
socket = /tmp/mysql.sock
basedir = /workspace/app/mysql/
datadir = /workspace/data/mysql/
tmpdir = /tmp
pid-file = /workspace/data/mysql/mysql.pid
bind-address = 127.0.0.1
log-bin=mysql-bin
server-id=1
log-error=mysqld.log
replicate-ignore-table=database.table
log-slave-updates = 1
說(shuō)明:
log-bin 配置的是開啟二進(jìn)制日志,并將日志寫在配置的路徑上。記錄的日志將以master-bin.000001 的方式進(jìn)行記錄。
log-bin-index 配置的是二進(jìn)制日志記錄文件的目錄。該文件中每一行都是二進(jìn)制日志文件的路徑。
server-id是該MySQL服務(wù)器的服務(wù)ID,用于區(qū)分在主從配置中的其他服務(wù)器。
配置成功后,重啟mysqld服務(wù)。
注意:如果不定義log-bin的文件名,則會(huì)以hostname主機(jī)名命名,一旦主機(jī)名修改,則會(huì)因?yàn)檎也灰姸M(jìn)制文件報(bào)錯(cuò)。所以最好還是顯示指定文件名。
2、 slave 從my.cnf配置文件,在[mysqld]下添加如下配置:
[client]
user = pmostc
password = pmostc
port = 3306
socket = /tmp/mysql.sock
[mysqld]
user = root
port = 3306
socket = /tmp/mysql.sock
basedir = /workspace/app/mysql/
datadir = /workspace/data/mysql/
tmpdir = /tmp
pid-file = /workspace/data/mysql/mysql.pid
bind-address = 127.0.0.1
server_id = 1921688052
binlog_format=mixed
relay-log = relay-bin
relay-log-index = relay-bin.index
report-host=
report-port=22988
log-bin=mysql-bin
log-error=mysqld.log
replicate-ignore-table=database.table
log-slave-updates = 1
server-id和master意義一樣,用于區(qū)分不同的mysql服務(wù)器。
relay-log用以記錄收到的中繼二進(jìn)制日志。relay-log-index用以保存收到的日志路徑索引。如果不顯示指定文件名,則以hostname值命名。
保存后可以重啟mysqld服務(wù)。
3、全量備份主數(shù)據(jù)庫(kù)
mysqldump -uroot -p123456 database > database.sql
4、在從庫(kù)恢復(fù)主庫(kù)全量備份數(shù)據(jù)
mysqldump -uroot -p123456 database < database.sql
恢復(fù)完數(shù)據(jù)庫(kù)并重啟mysql服務(wù)
5、 在slave上啟動(dòng)slave與master的連接。
在slave上登錄到mysql,在mysql>:下進(jìn)行操作。
3.1、mysql>stop slave; //停止slave。
配置標(biāo)記為同步
mysql> CHANGE MASTER TO MASTER_HOST='192.168.80.51',
-> MASTER_USER='repl',
-> MASTER_PASSWORD='123456',
-> MASTER_LOG_FILE='mysql-bin.000001',
-> MASTER_LOG_POS=0;
3.3、mysql>start slave;
4、檢查是否配置成功與排錯(cuò)
mysql>show slave status \G;
在打印出來(lái)的狀態(tài)下,查看以下兩個(gè)參數(shù)的值:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
如果這兩個(gè)參數(shù)的值都是yes,則運(yùn)行正常,可以在master數(shù)據(jù)庫(kù)上添加一個(gè)數(shù)據(jù)庫(kù)或者添加一張表,檢查slave數(shù)據(jù)庫(kù)上是否存在。
如果 這兩個(gè)參數(shù)有任何一個(gè)不是 Yes,則說(shuō)明存在問(wèn)題??梢圆榭磗lave上的數(shù)據(jù)庫(kù)錯(cuò)誤日志文件查看錯(cuò)誤原因。
Slave_IO_State, Slave_IO_Running, 和Slave_SQL_Running表明slave還沒有開始復(fù)制過(guò)程。
常見的錯(cuò)誤原因:
1、 server-id 一致。
2、 用戶權(quán)限不夠。需要的權(quán)限包括:
REPLICATION SLAVE,RELOAD,CREATE USER,SUPER。
GRANT REPLICATION SLAVE,RELOAD,CREATE USER,SUPER ON . TO {USER}@{IP_ADDR} WITH GRANT OPTION;
grant replication slave,replication client on . to slave@'192.168.80.52' identified by "123456";
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
分享文章:mysql5.7主從復(fù)制-創(chuàng)新互聯(lián)
本文網(wǎng)址:http://aaarwkj.com/article30/cccdso.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google、網(wǎng)站設(shè)計(jì)公司、網(wǎng)站策劃、網(wǎng)站建設(shè)、ChatGPT、手機(jī)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容