mysql主從備份配置

来源:https://www.cnblogs.com/MartyCode/archive/2020/03/17/12512253.html
-Advertisement-
Play Games

MySQL主從複製原理 主伺服器資料庫的每次操作都會記錄在其二進位文件mysql bin.xxx(該文件可以在mysql目錄下的data目錄中看到)中,從伺服器的I/O線程使用專用賬號登錄到主伺服器中讀取該二進位文件,並將文件內容寫入到自己本地的中繼日誌relay log文件中,然後從伺服器的SQL ...


MySQL主從複製原理
主伺服器資料庫的每次操作都會記錄在其二進位文件mysql-bin.xxx(該文件可以在mysql目錄下的data目錄中看到)中,從伺服器的I/O線程使用專用賬號登錄到主伺服器中讀取該二進位文件,並將文件內容寫入到自己本地的中繼日誌relay-log文件中,然後從伺服器的SQL線程會根據中繼日誌中的內容執行SQL語句。

原理

準備工作
主從伺服器需要有相同的初態

將主伺服器要同步的資料庫枷鎖,避免同步時數據發生改變

mysql>use db;
mysql>flush tables with read lock;
將主伺服器資料庫中數據導出(其中db為示例)

mysql>mysqldump -uroot -pxxxx db > db.sql;
mysql>mysqldump -R -ndt db -uroot -pxxxx > db.sql
備份完成後,解鎖主伺服器資料庫

mysql>unlock tables;
將初始數據導入從伺服器資料庫

mysql>create database db;
mysql>use db;
mysql>source db.sql;
至此,主從資料庫保持一致。下麵配置主從同步。

上述命令是導出資料庫中所有表結構和數據,如果要導出函數和存儲過程的話使用

主伺服器配置
修改MySQL配置

vi /etc/my.cnf
在[mysqld]中添加:

#主資料庫端ID號
server_id = 1
#開啟二進位日誌
log-bin = mysql-bin
#需要複製的資料庫名,如果複製多個資料庫,重覆設置這個選項即可
binlog-do-db = db
#將從伺服器從主伺服器收到的更新記入到從伺服器自己的二進位日誌文件中
log-slave-updates
#控制binlog的寫入頻率。每執行多少次事務寫入一次(這個參數性能消耗很大,但可減小MySQL崩潰造成的損失)
sync_binlog = 1
#這個參數一般用在主主同步中,用來錯開自增值, 防止鍵值衝突
auto_increment_offset = 1
#這個參數一般用在主主同步中,用來錯開自增值, 防止鍵值衝突
auto_increment_increment = 1
#二進位日誌自動刪除的天數,預設值為0,表示“沒有自動刪除”,啟動時和二進位日誌迴圈時可能刪除
expire_logs_days = 7
#將函數複製到slave
log_bin_trust_function_creators = 1
重啟MySQL,創建允許從伺服器同步數據的賬戶

#創建slave賬號sync_account,密碼password
mysql>grant replication slave on . to 'sync_account'@'slave_db_ip' identified by 'password';
#更新資料庫許可權
mysql>flush privileges;
查看主伺服器狀態

記住以下結果值:File以及Position,在從庫配置時會用到。

mysql>show master status\G;
***************** 1. row ****************
File: mysql-bin.000033 #當前記錄的日誌
Position: 337523 #日誌中記錄的位置
Binlog_Do_DB:
Binlog_Ignore_DB:
執行完這個步驟後不要再操作主伺服器資料庫了,防止其狀態值發生變化

從伺服器配置
修改MySQL配置

vi /etc/my.cnf
在[mysqld]中添加

server_id = 2
log-bin = mysql-bin
log-slave-updates
sync_binlog = 0
#log buffer將每秒一次地寫入log file中,並且log file的flush(刷到磁碟)操作同時進行。該模式下在事務提交的時候,不會主動觸發寫入磁碟的操作
innodb_flush_log_at_trx_commit = 0
#指定slave要複製哪個庫
replicate-do-db = db
#MySQL主從複製的時候,當Master和Slave之間的網路中斷,但是Master和Slave無法察覺的情況下(比如防火牆或者路由問題)。Slave會等待slave_net_timeout設置的秒數後,才能認為網路出現故障,然後才會重連並且追趕這段時間主庫的數據
slave-net-timeout = 60
log_bin_trust_function_creators = 1
重啟從伺服器。

執行同步命令

#執行同步命令,設置主伺服器ip,同步賬號密碼,同步位置
mysql>change master to master_host='10.10.20.111',master_user='sync_account',master_password='password',master_log_file='mysql-bin.000033',master_log_pos=337523;
#開啟同步功能
mysql>start slave;
查看從伺服器狀態

mysql>show slave status\G;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 10.10.20.111
Master_User: account
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000033
Read_Master_Log_Pos: 337523
Relay_Log_File: db2-relay-bin.000002
Relay_Log_Pos: 337686
Relay_Master_Log_File: mysql-bin.000033
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB:
Slave_IO_Running及Slave_SQL_Running進程必須正常運行,即Yes狀態,否則說明同步失敗。 若失敗查看mysql錯誤日誌中具體報錯詳情來進行問題定位。 最後可以去主伺服器上的資料庫中創建表或者更新表數據來測試同步。


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

-Advertisement-
Play Games
更多相關文章
  • 場景 MD5加密登錄密碼效果 註: 博客主頁: https://blog.csdn.net/badao_liumang_qizhi 關註公眾號 霸道的程式猿 獲取編程相關電子書、教程推送與免費下載。 實現 新建Winform程式並添加System.Web引用 然後新建一個登錄頁面,並設計登錄頁面佈局 ...
  • 一 Controller Manager原理 1.1 Controller Manager概述 一般來說,智能系統和自動系統通常會通過一個“控制系統”來不斷修正系統的工作狀態。在Kubernetes集群中,每個Controller都是這樣的一個“控制系統”,它們通過API Server提供的(Lis ...
  • 什麼是信號量?通過對這個量的訪問和修改,讓大家有序推進 1. 共同修改信號量引出的問題 2. 競爭條件 3. 解決競爭條件的直觀想法 4. 臨界區 臨界區:臨界區是指進程中的一段需要訪問共用資源並且另一個進程處於相應代碼區域時便不會被執行的代碼區域 互斥:當一個進程處於臨界區並訪問共用資源時,沒有其 ...
  • 過去的三天里我花了一些時間做了一個基於 PyQt5 的 GUI 工具,可以幫助檢查你的代碼風格是否符合恩智浦 SDK 驅動開發規範,如今這個工具的第一個預覽版(v0.4)出來了 ...
  • 一. Linux簡介 1.Linux是一套可免費使用和自由傳播的類UNIX操作系統。1991年,芬蘭赫爾辛基大學學生Linus開發了Linux內核。此後,一大批程式愛好者、軟體技術專家對Linux進行修改和完善。Linux操作系統從誕生到現在,其開放、安全、穩定的特性得到越來越多用戶的認可,又由於其 ...
  • 01PARTCoreWebApi教程本地演示環境 Visual Studio2019 Vsersion:16.4.4 + NetCore3.1.2 02PARTNginx快速搭建配置負載均衡 Nginx是一款輕量級的Web 伺服器/反向代理伺服器及電子郵件(IMAP/POP3)代理伺服器,在BSD- ...
  • !/bin/sh 本文原內容來自:https://github.com/judasn/Linux Tutorial/blob/master/CentOS Extra Packages.md 可能額外需要移除/etc/yum.repos.d/mirrors rpmforge中失效的源,以及移除對應的. ...
  • 背景:測試伺服器 MySQL 資料庫不知何種原因宕機,且無法啟動,而原先的資料庫並沒有備份,重新搭建一個新伺服器把原data 複製出來 進行恢復 1 儘量把原data複製出來(一個都不要少以防意外 其實真正需要的是 你要恢復的庫 和ibdata1 innodb引擎適用) 2 在其他伺服器上 搭建一個 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...