配置MySQL5.7主從複製

来源:https://www.cnblogs.com/youbins/archive/2022/11/01/16848783.html
-Advertisement-
Play Games

1 環境準備 192.168.1.34 伺服器A(主機) 192.168.1.35 伺服器B(從機) 2 安裝mysql MySQL版本: 這裡採用Server version: 5.7.35 MySQL Community Server (GPL) 我們把安裝在“伺服器A”的資料庫稱作“主資料庫” ...


1 環境準備

192.168.1.34 伺服器A(主機)
192.168.1.35 伺服器B(從機)

2 安裝mysql

MySQL版本:

這裡採用Server version: 5.7.35 MySQL Community Server (GPL)

我們把安裝在“伺服器A”的資料庫稱作“主資料庫”、安裝在“伺服器B”的資料庫稱作“從資料庫”。

2.1 開放埠

確保伺服器A與伺服器B上的3306埠可以互訪。

3 設置主庫

進行下麵的配置前,假設你已經在兩台伺服器AB上安裝成功MySQL服務。

192.168.1.34 伺服器A(主機)

3.1 修改MySQL配置文件

編輯mysql配置文件/etc/my.cnf,添加如下的內容:

[mysqld]
log-bin=mysql-bin
server-id=1

保存修改內容並重啟MySQL服務。

3.2 創建一個用戶用於複製

所謂複製用戶,即供從資料庫使用的,從主資料庫拷貝二進位日誌信息的用戶。

用客戶端連接上MySQL服務,執行以下語句創建一個用於複製的用戶:

mysql> CREATE USER 'repl'@'192.168.1.%' IDENTIFIED BY 'Abc!@#123';
mysql> GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.1.%';

3.3 獲取二進位文件位置

這些信息在後面配置從資料庫時用到。

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)

3.4 使用mysqldump創建數據快照

本指南預設使用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”.

4 設置從庫

192.168.1.35 伺服器B(從機)

4.1 修改MySQL配置文件

編輯mysql配置文件/etc/my.cnf,添加如下的內容:

[mysqld]
server-id=2
skip_slave_start=ON

這裡主要解釋一下skip_slave_start配置,ON表示資料庫啟動時不啟動從機的複製進程,需要通過手動的方式進行啟動。

保存修改內容並重啟MySQL服務。

4.2 設置從庫對應的主庫

這裡主要用到 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;

4.3 導入全新的數據的情況

即主庫和備庫都是新建的,不存在舊庫舊表舊數據,且主庫已經啟用二進位日誌,備庫已指定主庫及當前位置。這時你想要將其它的資料庫備份下來導入到當前的主備資料庫中,你只需要在主庫中執行導入命令即可(不能再備庫執行導入語句):

shell> mysql -h '192.168.1.34' < fulldb.dump

4.4 主庫已存在數據的情況

即主庫在啟用二進位日誌前已存在數據,你在啟用從庫複製進程前需要把主庫的備份快照導入到從庫中,然後才能啟用從庫的複製進程。

1、新建主庫快照

shell> mysqldump --all-databases --master-data > dbdump.db

2、導入到從庫中

shell> mysql -h '192.168.1.35' < fulldb.dump

4.5 啟用從庫複製進程

mysql> START SLAVE;

驗證主從複製是否啟動成功

mysql> show slave status\G
*************************** 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_RunningSlave_SQL_Running同時都是Yes的時候表示主從複製配置成功。

5 互為主從設置

前面兩個章節講瞭如何配置主從複製,即伺服器A的資料庫作為主庫,伺服器B的資料庫作為從庫;那麼只要按照相反的步驟再設置一遍,即伺服器B的資料庫作為主庫,伺服器A的資料庫作為從庫。這樣就可以使得伺服器A的資料庫和伺服器B的資料庫互為主從了。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 作者:農民工老王 來源:blog.csdn.net/monarch91/article/details/122709576 我是一個非科班出身的程式員,大學本科時的專業和編程無關,畢業後做了幾年事業單位後,才中途轉行做了軟體開發。 我一入行就聽說了35歲危機:程式員到了35歲後,如果沒有進入管理層, ...
  • python爬蟲基本概述 一、爬蟲是什麼 網路爬蟲(Crawler)又稱網路蜘蛛,或者網路機器人(Robots). 它是一種按照一定的規則, 自動地抓取萬維網信息的程式或者腳本。換句話來說,它可以根據網頁的鏈接地址自動獲取網頁 內容。如果把互聯網比做一個大蜘蛛網,它裡面有許許多多的網頁,網路蜘蛛可以 ...
  • Web項目開發中,經常會有一些靜態資源,被放置在resources目錄下,隨項目打包在一起,代碼中要使用的時候,通過文件讀取的方式,載入並使用; 今天總結整理了九種方式獲取resources目錄下文件的方法。 其中公用的列印文件方法如下: 查看代碼 /** * 根據文件路徑讀取文件內容 * * @p ...
  • 1 # 這是一個示例 Python 腳本。 2 3 # 按 ⌃R 執行或將其替換為您的代碼。 4 # 按 雙擊 ⇧ 在所有地方搜索類、文件、工具視窗、操作和設置。 5 import sys 6 import pygame 7 import random 8 9 game = None 10 BOMB ...
  • Shift4 非同步複位同步置數和使能。 module top_module( input clk, input areset, // async active-high reset to zero input load, input ena, input [3:0] data, output reg ...
  • 本章開始`LyShark`將介紹如何在內核中實現`InlineHook`掛鉤這門技術,內核掛鉤的第一步需要實現一個動態計算彙編指令長度的功能,該功能可以使用`LDE64`這個反彙編引擎,該引擎小巧簡單可以直接在驅動中使用,LDE引擎是`BeaEngine`引擎的一部分,後來讓`BeatriX`打包成... ...
  • 今天我們來聊一聊關於JWT授權的事情。 JWT:Json Web Token。顧名思義,它是一種在Web中,使用Json來進行Token授權的方案。 既然沒有找好密碼,token是如何解決信任問題的呢? 解決信任問題,只需要解決兩個問題即可: token是不是來自我信任的機構頒發 token中的信息 ...
  • 操作mysql的命令 cmd命令行中查看mysql版本: mysql -V mysql --version 登陸mysql: mysql -uroot -pluis mysql -uroot -p 在mysql中查看資料庫版本: select version(); 查看所有資料庫: show dat ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...