主從復制原理及操作

主從復制的概念

主從復制是一種在數據庫系統中常用的數據備份和讀取擴展技術,通過將一個數據庫服務器(主服務器)上的數據變更自動同步到一個或多個數據庫服務器(從服務器)上,以此來實現數據的冗余備份、讀寫分離以及負載均衡等目的。

主從復制的原理

  1. 首先在Master上開啟二進制日志。
  2. 當Master上數據發生變化,進行DML操作時,會產生二進制日志。
  3. Master上dump線程會通知Slave上的I/O線程來拿二進制日志。
  4. I/O線程拿到日志后會寫入到Slave上的中繼日志。
  5. 然后SQL線程會去讀取新產生的中繼日志,重演二進制日志里的操作,從而達到Slave和Master上的數據一模一樣,實現數據的一致性

主從復制的原理如上,在Slave服務器上還存在master-info文件和relay-log.info文件。master-info文件記錄I/O線程從Master服務器上獲取二進制日志結束的pos位置號和日志文件的名字。relay-log.info文件記錄當前中繼日志的文件名和位置點。

主從復制的操作

1、環境準備

準備兩臺服務器,一臺作為master服務器(192.168.2.117),一臺作為slave服務器(192.168.2.118),確保兩臺服務器上的mysql服務是啟動的,mysql版本為5.x。

修改主機名,便于辨識:

// master服務器上
[root@localhost ~] hostnamectl set-hostname master// slave服務器上
[root@localhost ~] hostnamectl set-hostname slave

2、修改mysql配置文件

在master服務器上開啟二進制日志,server_id=1,在slave服務器上也可以開啟二進制日志,server_id=2

// master服務器上
[root@master ~] vim /etc/my.cnf
# 找到[mysqld]位置添加以下內容
[mysqld]
log_bin
server_id=1// 重啟服務
[root@master ~] service mysqld restart// slave服務器上
[root@slave ~] vim /etc/my.cnf
# 找到[mysqld]位置添加以下內容
[mysqld]
log_bin
server_id=2// 重啟服務
[root@slave ~] service mysqld restart

3、統一兩臺服務器的基礎數據

// master服務器導出所有數據
[root@master ~] mysqldump -uroot -p'123456' --all-databases >all_db.SQL// 上傳slave服務器
[root@master ~] scp all_db.SQL root@192.168.2.118:/root// slave服務器執行SQL文件
[root@slave ~] mysql -uroot -p'123456' <all_db.SQL

4、master服務器初始化二進制日志

清除master服務器上所有的二進制日志,因為上一步已經做了一次全部備份了。

root@(none) mysql> reset master;// 查看二進制文件名和位置點POS
root@(none) mysql> show master status;

5、新建授權用戶

在master服務器上新建一個授權用戶,給slave來復制二進制日志。

// master服務器上操作
root@(none) mysql> reset master;
root@(none) mysql> grant replication slave on *.* to 'slave-1'@'192.168.2.118';

6、配置master-info信息

在slave服務器上配置master-info信息,master-info文件記錄I/O線程從master服務器上獲取二進制日志結束的pos位置號和日志文件的名字。當master服務器通知slave服務器來讀取二進制日志時,slave服務器通過master-info信息才能得知從哪里開始讀取。

// slave服務器上操作
root@(none) mysql> CHANGE MATER TO MASTER_HOST='192.168.2.137',
> MASTER_USER='slave-1',
> MASTER_PASSWORD='123456',
> MASTER_PORT=3306,
> MASTER_LOG_FILE='master-bin.000001',
> MASTER_LOG_POS=154;

7、查看slave是否配置成功

// slave服務器上操作
// 啟動slave
root@(none) mysql> start slave;root@(none) mysql> show slave status\G;// 下面這兩個為yes則表示啟動成功
Slave_IO_Running: Yes
Slave_SQL_Running: Yes

常見問題

  1. 查看服務器防火墻3306端口是否開放。
  2. 配置時是否出現拼寫錯誤。
  3. 兩天服務器是否為克隆產生,是克隆產生則需要修改uuid。修改mysql數據目錄下auto.cnf文件(vim /data/mysql/auto.cnf)中server-uuid的值,隨便修改幾個字符即可。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/40707.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/40707.shtml
英文地址,請注明出處:http://en.pswp.cn/web/40707.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

解決video.js在demo中可以播放,在已有項目中無限waiting的問題

video.js的是有推薦的和react一起使用的寫法的&#xff1a;https://videojs.com/guides/react/ 但是這個寫法在demo中可以正常播放&#xff0c;在放在現有的項目中則播不出來&#xff0c;也不報錯&#xff0c;就是log里顯示on waiting后就什么動靜都沒有了&#xff0c;頁面顯示…

貝葉斯學習中先驗分布的詳細解釋

在貝葉斯學習中&#xff0c;先驗分布&#xff08;Prior Distribution&#xff09;是一個非常重要的概念。它代表了在觀察到任何數據之前&#xff0c;對未知參數的初始信念或知識。先驗分布的選擇通常基于領域知識、歷史數據或者純粹的假設。 文章目錄 先驗分布的含義先驗分布的…

dtpay聚合支付系統在跨境支付場景中技術及業務方案

1 什么是跨境支付 我們從兩個維度來分析什么是跨境支付&#xff0c;第一個維度我們從資金流向分析&#xff0c;國內的消費者在境外進行消費對于國內資金流來說這屬于資金流出&#xff0c;這是跨境支付的第一種應用場景。第二個場景國外游客在國內進行消費&#xff0c;這屬于資…

昇思25天學習打卡營第11天 | LLM原理和實踐:基于MindSpore實現BERT對話情緒識別

1. 基于MindSpore實現BERT對話情緒識別 1.1 環境配置 # 實驗環境已經預裝了mindspore2.2.14&#xff0c;如需更換mindspore版本&#xff0c;可更改下面mindspore的版本號 !pip uninstall mindspore -y !pip install -i https://pypi.mirrors.ustc.edu.cn/simple mindspore2.2…

js的作用域鏈

function test(){} 運行期上下文&#xff1a;當函數執行時&#xff0c;會創建一個稱為執行期上下文的內部對象。一個執行期上下文定義了一個函數執行時的環境&#xff0c;函數每次執行時對應的執行上下文都是 獨一無二的&#xff0c;所以多次調用一個函數對導致創建多個執行上下…

Linux 安裝pdfjam (PDF文件尺寸調整)

跟Ghostscript搭配使用&#xff0c;這樣就可以將不同尺寸的PDF調整到相同尺寸合并了。 在 CentOS 上安裝 pdfjam 需要安裝 TeX Live&#xff0c;因為 pdfjam 是基于 TeX Live 的。以下是詳細的步驟來安裝 pdfjam&#xff1a; ### 步驟 1: 安裝 EPEL 倉庫 首先&#xff0c;安…

springboot集成tika解析word,pdf,xls文件文本內容

介紹 Apache Tika 是一個開源的內容分析工具包&#xff0c;用于從各種文檔格式中提取文本和元數據。它支持多種文檔類型&#xff0c;包括但不限于文本文件、HTML、PDF、Microsoft Office 文檔、圖像文件等。Tika 的主要功能包括內容檢測、文本提取和元數據提取。 官網 https…

python入門詳細介紹

Python 是一種廣泛使用的高級編程語言&#xff0c;以其清晰的語法和代碼可讀性而聞名。它支持多種編程范式&#xff0c;包括面向對象、命令式、函數式和過程式編程。Python 由 Guido van Rossum 于1989年底發明&#xff0c;第一個公開發行版發行于1991年。 Python 的特點&…

java-初始化Map快捷裝數據

*單個Map創建 Map<String, String> stringStringMap Collections.singletonMap("reason", "同意");使用匿名類初始化Map List<Map<String,Object>> mapListnew ArrayList<>();mapList.add(new HashMap<String, Object>() {…

基于STM32F407ZG的FreeRTOS移植

1.從FreeRTOS官網中下載源碼 2、簡單分析FreeRTOS源碼目錄結構 2.1、簡單分析FreeRTOS源碼根目錄 &#xff08;1&#xff09;Demo&#xff1a;是官方為一些單片機移植FreeRTOS的例程 &#xff08;2&#xff09;License&#xff1a;許可信息 &#xff08;3&#xff09;Sourc…

《中國品牌網》揭秘格行品牌崛起之路:如何從混亂市場中殺出重圍,領跑未來?

在隨身WiFi行業亂象叢生的背景下&#xff0c;格行品牌憑借其獨特的經營理念和長期主義的精神&#xff0c;逐漸嶄露頭角&#xff0c;成為行業的領跑者。近日&#xff0c;《中國品牌網》記者專訪了格行品牌的創始人劉永先先生&#xff0c;就他的經營理念、市場策略以及未來展望進…

如何在 Odoo 16 中對 Many2Many 字段使用 Group by

Many2many 字段與 Many2one 字段類似,因為它們在模型之間建立了新的關系。在Odoo 16中,您無法按 many2many 字段分組,因為可以使用 many2many 記錄選擇任何記錄。當您使用 many2many 字段給出 group by 過濾器時,您將遇到斷言錯誤。 介紹如何在 Odoo 16 中使用 Many2Many…

AIGC | 為機器學習工作站安裝NVIDIA 4070 Ti Super顯卡驅動

[ 知識是人生的燈塔&#xff0c;只有不斷學習&#xff0c;才能照亮前行的道路 ] 0x00 前言簡述 話接上篇《AIGC | Ubuntu24.04桌面版安裝后必要配置》文章&#xff0c;作為作者進行機器學習的基礎篇&#xff08;筑基期&#xff09;&#xff0c;后續將主要介紹機器學習環境之如何…

6-google::protobuf命名空間下常用的C++ API----repeated_field.h

#include <google/protobuf/repeated_field.h> namespace google::protobuf 所生成的協議消息類使用RepeatedField和RepeatedPtrField來操作重復字段。 這些類與STL的vector非常相似&#xff0c;但包含了許多優化&#xff0c;這些優化被發現特別適用于協議緩沖區的情況。…

【優化論】基本概念與細節

優化論&#xff08;Optimization Theory&#xff09;是數學和計算機科學中一個重要的分支&#xff0c;旨在尋找給定問題的最優解。這個領域的應用非常廣泛&#xff0c;從經濟學、工程學到機器學習、金融等各個領域都有其蹤跡。我們可以通過一系列直觀的比喻來理解優化論的基本概…

Python編譯器的選擇

了解如何使用一個集成開發環境&#xff08;IDE&#xff09;對于 Python 編程是非常重要的。IDE 提供了代碼編輯、運行、調試、版本控制等多種功能&#xff0c;可以極大地提升開發效率。以下是一些流行的 Python IDE 和代碼編輯器的介紹&#xff0c;以及如何開始使用它們&#x…

Python + 在線 + 文生音,音轉文(中文文本轉為英文語音,語音轉為中文文本)

開源模型 平臺&#xff1a;https://huggingface.co/ars-語言轉文本: pipeline("automatic-speech-recognition", model"openai/whisper-large-v3", device0 ) hf: https://huggingface.co/openai/whisper-large-v3 github: https://github.com/openai/wh…

kettle中調用restful接口時的SSL信任證書問題

1、找第三方獲取SSL證書&#xff0c;&#xff08;本案例為自簽名證書&#xff09; C:\Program Files\Java\jdk1.8.0_241\jre\lib\security>keytool -import -alias aliyun-maven -keystore cacerts -file E:\entSoftware\aliyun-maven.cer 輸入密鑰庫口令: …………一堆證…

ubuntu系統盤擴容

目錄 1 介紹 2 步驟 2.1 關閉虛擬機 2.2 編輯虛擬機設置 2.3 設置擴展大小 2.4 打開虛擬機 2.5 找到磁盤管理 2.6 擴展 1 介紹 本部分主要記述怎么給ubuntu系統盤擴展存儲容量&#xff0c;整個過程相對簡單&#xff0c;擴容方式輕松、容易。 2 步驟 2.1 關閉虛擬機 2…

前端面試題(CSS篇三)

一、簡單介紹使用圖片 base64 編碼的優點和缺點。 base64是一種圖片處理格式&#xff0c;通過特定的算法將圖片編碼為一長串字符串&#xff0c;在頁面顯示的時候&#xff0c;可以使用該字符串來代替圖片的url屬性。 使用base64的優點: 減少一個圖片的http請求 使用base64的缺點…