<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
192.168.1.34 伺服器A(主機) 192.168.1.35 伺服器B(從機)
MySQL版本:
這裡採用Server version: 5.7.35 MySQL Community Server (GPL)
我們把安裝在“伺服器A”的資料庫稱作“主資料庫”、安裝在“伺服器B”的資料庫稱作“從資料庫”。
確保伺服器A與伺服器B上的3306埠可以互訪。
進行下面的設定前,假設你已經在兩臺伺服器AB上安裝成功MySQL服務。
192.168.1.34 伺服器A(主機)
編輯mysql組態檔/etc/my.cnf,新增如下的內容:
[mysqld] log-bin=mysql-bin server-id=1
儲存修改內容並重啟MySQL服務。
所謂複製使用者,即供從資料庫使用的,從主資料庫拷貝二進位制紀錄檔資訊的使用者。
用使用者端連線上MySQL服務,執行以下語句建立一個用於複製的使用者:
mysql> CREATE USER 'repl'@'192.168.1.%' IDENTIFIED BY 'Abc!@#123'; mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.1.%';
這些資訊在後面設定從資料庫時用到。
1、阻塞資料庫寫語句
mysql> FLUSH TABLES WITH READ LOCK;
2、獲取當前二進位制檔案的名稱和位置
mysql> show master status; +------------------+----------+--------------+------------------+-------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | +------------------+----------+--------------+------------------+-------------------+ | mysql-bin.000001 | 1030 | | | | +------------------+----------+--------------+------------------+-------------------+ 1 row in set (0.00 sec)
本指南預設使用
InnoDB
儲存引擎。
如果在啟用主從複製前,主資料庫已存在資料,那麼你就需要先把這些資料拷貝到從資料庫。下面給出一個例子,將所有資料庫備份到一個叫做dbdump.db
的檔案:
shell> mysqldump --all-databases --master-data > dbdump.db
其中--master-data
選項會自動追加 CHANGE MASTER TO
語句,該語句在從資料庫啟動複製程序時需要到。
注意:
如果你沒有使用
--master-data
選項的話,那麼你需要在一個單獨的對談中鎖定所有資料表。詳情見 Section 16.1.2.3, “Obtaining the Replication Source's Binary Log Coordinates”.
192.168.1.35 伺服器B(從機)
編輯mysql組態檔/etc/my.cnf,新增如下的內容:
[mysqld] server-id=2 skip_slave_start=ON
這裡主要解釋一下skip_slave_start
設定,ON表示資料庫啟動時不啟動從機的複製程序,需要通過手動的方式進行啟動。
儲存修改內容並重啟MySQL服務。
這裡主要用到 CHANGE MASTER TO語句,其基本語法如下:
mysql> CHANGE MASTER TO -> MASTER_HOST='source_host_name', -> MASTER_USER='replication_user_name', -> MASTER_PASSWORD='replication_password', -> MASTER_LOG_FILE='recorded_log_file_name', -> MASTER_LOG_POS=recorded_log_position;
我們的例子對應如下(當中的引數見上文[設定主資料庫](#3 設定主資料庫)一節):
mysql> CHANGE MASTER TO -> MASTER_HOST='192.168.1.34', -> MASTER_USER='repl', -> MASTER_PASSWORD='Abc!@#123', -> MASTER_LOG_FILE='mysql-bin.000001', -> MASTER_LOG_POS=1030;
即主庫和備庫都是新建的,不存在舊庫舊錶舊資料,且主庫已經啟用二進位制紀錄檔,備庫已指定主庫及當前位置。這時你想要將其它的資料庫備份下來匯入到當前的主備資料庫中,你只需要在主庫中執行匯入命令即可(不能再備庫執行匯入語句):
shell> mysql -h '192.168.1.34' < fulldb.dump
即主庫在啟用二進位制紀錄檔前已存在資料,你在啟用從庫複製程序前需要把主庫的備份快照匯入到從庫中,然後才能啟用從庫的複製程序。
1、新建主庫快照
shell> mysqldump --all-databases --master-data > dbdump.db
2、匯入到從庫中
shell> mysql -h '192.168.1.35' < fulldb.dump
mysql> START SLAVE;
驗證主從複製是否啟動成功
mysql> show slave statusG *************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Host: 192.168.1.34 Master_User: repl Master_Port: 3306 Connect_Retry: 60 Master_Log_File: mysql-bin.000001 Read_Master_Log_Pos: 2096 Relay_Log_File: 192-relay-bin.000007 Relay_Log_Pos: 320 Relay_Master_Log_File: mysql-bin.000001 Slave_IO_Running: Yes Slave_SQL_Running: Yes Replicate_Do_DB: Replicate_Ignore_DB: Replicate_Do_Table: Replicate_Ignore_Table: Replicate_Wild_Do_Table: Replicate_Wild_Ignore_Table: ......
如上,只有Slave_IO_Running
和Slave_SQL_Running
同時都是Yes
的時候表示主從複製設定成功。
前面兩個章節講了如何設定主從複製,即伺服器A的資料庫作為主庫,伺服器B的資料庫作為從庫;那麼只要按照相反的步驟再設定一遍,即伺服器B的資料庫作為主庫,伺服器A的資料庫作為從庫。這樣就可以使得伺服器A的資料庫和伺服器B的資料庫互為主從了。
到此這篇關於MySQL5.7主從複製詳細設定教學的文章就介紹到這了,更多相關MySQL5.7主從複製 內容請搜尋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