Mysql實現主從復制(一主雙從)

一、環境介紹

LNMP(centos7,mysql5.6)

vmware workstation pro配置了3個虛擬機,均安裝了LNMP環境:

master:? 192.168.0.105? ? ? ?

slave:? ? ?192.168.0.106?、192.168.0.107

?

二、原理

(1)主數據庫進行增刪改操作后,相應操作記錄的語句(比如 create database test)會記錄到binlog日志文件中(binlog日志文件一般和數據庫data文件夾在一起)。

(2)從數據庫會請求主數據庫的binlog日志文件,獲取到新的操作語句,然后在自己的從數據庫上自動執行相同的操作語句,進而實現主從的同步。
?

注:這里,我們所需要配置的只是主從環境以及開啟binlog日志,其他的mysql會自動完成。

使用場景:http://baijiahao.baidu.com/s?id=1598186201849829616&wfr=spider&for=pc

?

三、詳細主從復制過程

(1)Master開啟bin-log功能,binlog日志文件用于記錄數據庫的增刪改操作。

(2)需要開啟三個線程,Master:I/O線程;Slave:I/O線程,SQL線程。

(3)Slave start;通過I/O線程連接Master,并且請求某個bin-log,position之后的內容。

(4)Master服務器收到Slave I/O線程發過來的日志請求信息,然后Master I/O線程將bin-log內容、position返回給Slave IO線程。

(5)Slave服務器收到bin-log日志內容,將bin-log日志內容寫入到relay-log中繼日志,創建一個master.info文件,該文件記錄master IP、用戶名、密碼、master bin-log名稱、bin-log position。
?

(6)Slave已經開啟了sql線程,由sql線程實時監測relay-log日志內容是否有更新,如果有更新,則解析文件中的sql語句,并在Slave數據庫中執行相同的操作語句。

注:可以通過show slave status \G? 來查看具體的中繼日志路徑以及連接的master的其他信息。

?

?

四、主從復制的實現

?

1、master機器上的配置

(1)vim /etc/my.cnf? ?#修改mysql的配置文件

(2)配置bind-address (配置成master-ip)和 server-id (改成ip后三位即可,也可以改為其他,比如5)以及開啟bin-log(默認是已經開啟),如下:

bind-address = 0.0.0.0
server-id = 105

注:此處允許所有ip地址可以遠程登錄此mysql,出于安全考慮,可以配置防火墻規則進行mysql遠程登錄的ip的限制。

配置防火墻規則鏈接:https://blog.csdn.net/m_nanle_xiaobudiu/article/details/81070480

?

(3)創建用于slave機器獲取master機器上binlog文件的賬號(從機器復制用戶)

grant replication slave on *.* to 'xiaobudiu'@'%' identified by 'xiaobudiu123';

(4)?flush privileges;? #刷新數據庫

(5)show master status; #查看master狀態,并記錄下binlog日志文件名以及position

?

2、slave機器上的配置

(1)在兩臺從機器上分別配置mysql配置文件中的bind-address 和 server-id

192.168.0.106機器上:

bind-address = 0.0.0.0
server-id = 106

192.168.0.107機器上:

bind-address = 0.0.0.0
server-id = 107

(2)分別在兩臺從庫上操作

change master to master_host='192.168.0.105', master_port=3306, master_user='xiaobudiu', master_password='xiaobudiu123', master_log_file='mysql-bin.000045', master_log_pos=402;

(3)分別開啟兩臺從庫

(4)驗證從庫狀態

當從庫的 IO線程和SQL線程的狀態都是yes時,說明主從模式配置成功。

?

五、實現Mysql讀寫分離

https://blog.csdn.net/m_nanle_xiaobudiu/article/details/81048538

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

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

相關文章

Elasticsearch學習筆記-04.3批處理

除了創建、更新和刪除個別文檔,Elasticsearch還提供了使用_bulk API的上述操作的批量操作方法。這個功能很重要,因為他提供了一種有效的機制來在盡可能少的網絡傳輸過程中執行多次操作。 作為一個快速示例,下面的命令在一次批量操作中索引了兩…

接口文檔神器Swagger(下篇)

本文來自網易云社區作者:李哲二、Swagger-springmvc原理解析上面介紹了如何將springmvc和springboot與swagger結合,通過簡單配置生成接口文檔,以及介紹了swagger提供的一些注解。下面將介紹swagger是如何做到與springmvc結合,自動…

php實現mysql分表

一、場景說明 1、為什么要進行分表 隨著數據量的不斷增大,一張表中的數據肯定也會越來越多,甚至達到百萬甚至千萬級。我們通常會通過搭建mysql集群(主從同步),讀寫分離來實現優化數據庫查詢執行效率。 但是由于數據…

利用python進行數據分析D1——ch02引言

基礎的課程還沒學完,就來這本了,因為我平時的研究還是以數據的處理為主。把自己的事做好做細致讀了一下介紹部分,下載書里用到的數據,下載地址:https://github.com/wesm/pydata-book 如果你需要完成以下幾大類任務&…

記一次Memory Leak分析

起因:最近公司的一個web產品遇到了內存溢出,于是開始著手調查。調查:首先當務之急是找到那個或那些API導致Memory Leak,這個應該不難,根據監控分析,在內存上升時間段內有哪些API被訪問,再就是根…

【t057】任務分配

Time Limit: 1 second Memory Limit: 128 MB 【問題描述】 現有n個任務,要交給A和B完成。每個任務給A或給B完成,所需的時間分別為ai和bi。問他們完成所有的任務至少要多少時間。 【輸入格式】 第一行一個正整數n,表示有n個任務。 接下來有n行&#xf…

LeetCode 366. Find Leaves of Binary Tree

實質就是求每個節點的最大深度。用一個hash表記錄&#xff0c;最后輸出。 class Solution { public:unordered_map<TreeNode *,int> hash; // record the level from bottomvector<vector<int>> findLeaves(TreeNode* root) {vector<vector<int>>…

C#比較對象的相等性

對于相等的機制全部不同&#xff0c;這取決于比較的是引用類型還是值類型。以下分別介紹引用類型和值類型的相等性。1.比較引用類型的相等性 System.Object定義了三種不同的方法&#xff0c;來比較對象的相等性&#xff1a;ReferenceEquals()和兩個版本號的Equals()。再加上比較…

WebSocket教程

一、為什么需要 WebSocket&#xff1f; 初次接觸 WebSocket 的人&#xff0c;都會問同樣的問題&#xff1a;我們已經有了 HTTP 協議&#xff0c;為什么還需要另一個協議&#xff1f;它能帶來什么好處&#xff1f; 答案很簡單&#xff0c;因為 HTTP 協議有一個缺陷&#xff1a…

C# WPF十個美觀的界面設計展示

概述很多時候&#xff0c;我們設計的界面總是感覺缺乏美感&#xff0c;不是我們不會開發好看的界面&#xff0c;而是不知道怎么才算美觀&#xff0c;這時候我們不妨看看別人好的頁面是怎么做的.下面展示一些我覺得做的比較好的cs界面&#xff0c;希望能給大家在平時做界面設計時…

BZOJ3172: [Tjoi2013]單詞

【傳送門&#xff1a;BZOJ3172】 簡要題意&#xff1a; 給出n個單詞&#xff0c;你可以理解為將這些單詞變成一個個段落&#xff0c;然后求出每個單詞在所有段落中出現的次數 題解&#xff08;一&#xff09;&#xff1a; 剛開始不是很懂題目&#xff0c;結果發現將所有單詞看成…

MySQL5.6二進制軟件包編譯安裝詳解(三)

一、軟件環境 [rootlocalhost ~]# uname -r 3.10.0-862.el7.x86_64 [rootlocalhost ~]# cat /etc/redhat-release CentOS Linux release 7.5.1804 (Core) 二、安裝部署過程詳解 MySQL安裝3種方式&#xff1a;1>rpm包安裝應用文件默認安裝在/usr/local 目錄下2>源碼編譯需…

Java反射學習總結五(Annotation(注解)-基礎篇)

Annotation(注解)簡單介紹&#xff1a; 注解大家印象最深刻的可能就是JUnit做單元測試,和各種框架里的使用了。本文主要簡介一下注解的用法&#xff0c;下篇文章再深入的研究。 annotation并不直接影響代碼語義。可是它可以被看作類似程序的工具或者類庫。它會反過來對正在執行…

使用autok3s 安裝k3s 集群 和 kuboard 管理集群

一、k3s介紹1.1 什么是k3s?k3s 是經過 CNCF 認證的由 Rancher 公司開發維護的一個輕量級的 Kubernetes 發行版&#xff0c;內核機制還是和 k8s 一樣&#xff0c;但是剔除了很多外部依賴以及 K8s 的 alpha、beta 特性&#xff0c;同時改變了部署方式和運行方式&#xff0c;目的…

Nginx—— Rewrite規則的使用

一、使用場景 1、URL訪問跳轉 &#xff08;1&#xff09;頁面跳轉 &#xff08;2&#xff09;兼容性支持&#xff08;比如新老版本交替時&#xff0c;給老版本一條訪問道路&#xff09; &#xff08;3&#xff09;展示效果&#xff08;比如縮短前臺界面的地址欄的url&#…

java對象實例化的方式

java對象實例化的方式有以下幾種&#xff1a;1、使用new2、工廠模式3、反射4、clone()方法5、反序列化方式 /** 實現Cloneable和Serializable接口 */public class Book implements Cloneable, Serializable {private static final long serialVersionUID 1L; private Integer …

iOS-生成二維碼圖片【附中間帶有小圖標二維碼】(QRCode)

生成二維碼圖片也是項目中常用到的&#xff0c;二維碼的掃描Git上有很多好用的&#xff0c;這里主要說下二維碼的生成 1.普通二維碼 方法 /**生成二維碼QRStering&#xff1a;字符串imageFloat&#xff1a;二維碼圖片大小*/ (UIImage *)createQRCodeWithString:(NSString *)QRS…

libubox

lbubox是openwrt的一個核心庫&#xff0c;封裝了一系列基礎實用功能&#xff0c;主要提供事件循環&#xff0c;二進制格式處理&#xff0c;linux鏈表實現和一些JSON輔助處理。 它的目的是以動態鏈接庫方式來提供可重用的通用功能&#xff0c;給其他模塊提供便利和避免再造輪子。…

社區糾紛不斷:程序員何苦為難程序員

出品 | OSC開源社區&#xff08;ID&#xff1a;oschina2013)今年年初&#xff0c;我們報道“因為被多人侮辱大吼&#xff0c;Swift 之父正式退出 Swift 核心團隊”。諸如此類的“語言暴力”、“網絡暴力”事件在開源社區乃至整個 IT 社區屢見不鮮。多個技術社區&#xff0c;都出…

PHP 分布式集群中session共享問題以及session有效期的設置

一、Session的原理 以下以默認情況舉例&#xff1a; session_start();之后&#xff0c;會生成一個唯一的session_id&#xff0c;每一個用戶對應唯一一個session_id&#xff0c;每一個session_id對應服務器端的一個session文件。這個session文件存儲著當前session_id的信息&am…