MySQL5.7主從同步

来源:https://www.cnblogs.com/baiyb/archive/2018/07/13/9306632.html
-Advertisement-
Play Games

性能更好的新伺服器申請下來了,我們決定在2台新伺服器上使用mysql5.7,並且使用主從同步、讀寫分離架構,很不幸這個任務落到了我的頭上。讀寫分離是在業務代碼中實現的,在此不做詳述,介紹一下我搭建MySQL主從的過程。 環境介紹: Master 10.20.66.150 Slave 10.20.66 ...


性能更好的新伺服器申請下來了,我們決定在2台新伺服器上使用mysql5.7,並且使用主從同步、讀寫分離架構,很不幸這個任務落到了我的頭上。讀寫分離是在業務代碼中實現的,在此不做詳述,介紹一下我搭建MySQL主從的過程。

 

環境介紹:

Master 10.20.66.150

Slave    10.20.66.151

埠都是3306

 

一.修改主庫的配置 vi /etc/my.cnf

[client]
default-character-set=utf8mb4

[mysql]
default-character-set=utf8mb4

[mysqld] datadir=/var/lib/mysql socket=/var/lib/mysql/mysql.sock symbolic-links=0 log-error=/var/log/mysqld.log pid-file=/var/run/mysqld/mysqld.pid init_connect='SET collation_connection = utf8mb4_unicode_ci' init_connect='SET NAMES utf8mb4' character-set-server=utf8mb4 collation-server=utf8mb4_unicode_ci skip-character-set-client-handshake server-id=2 log-bin=log binlog-ignore-db=mysql binlog-ignore-db=information_schema binlog-ignore-db=performance_schema binlog-ignore-db=sys

需要註意的點:

1.為了相容emoji等特殊位元組符,配置中使用utf8mb4編碼

2.與主從相關的配置在整個配置的最下邊,主庫和從庫的server-id必須不同

3.binlog-ignore-db設置不需要同步的庫

 

二.創建用於主從同步的賬戶

1.登錄MySQL    mysql -uroot -p

2.create user 'sync'@'%' identified by 'Sync!0000';    (5.7要求密碼必須含有大小寫英文,符號和數字)

3.grant FILe on *.* to 'sync'@'10.20.66.151' identified by 'Sync!0000';   (賦予FILE許可權,允許從從庫ip訪問主庫)

4.grant replication slave on *.* to 'sync'@'10.20.66.151' identified by 'Sync!0000';   (賦予主從同步許可權)

5.flush privileges;

6.重啟mysql

 

三.查看主庫狀態,記錄必要信息

1.登錄MySQL

2.show master status; 記錄File和Position對應的信息,我這裡是log.000006和151

 

四.修改從庫配置

 

[client]
default-character-set=utf8mb4

[mysql]
default-character-set=utf8mb4

[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock

symbolic-links=0

log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

init_connect='SET collation_connection = utf8mb4_unicode_ci'
init_connect='SET NAMES utf8mb4'
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci
skip-character-set-client-handshake

server-id=3
log-bin=mysql-bin
replicate-ignore-db=mysql
replicate-ignore-db=information_schema
replicate-ignore-db=performance_schema
replicate-ignore-db=sys
log-slave-updates
slave-skip-errors=all
slave-net-timeout=60

 

註意事項和主庫配置相同,使用replicate-ignore-db標記出不需要同步的庫

 

五.配置同步賬號

1.systemctl restart mysql    (重啟MySQL),然後進入MySQL

2.stop slave;

3.change master to master_host='10.20.66.150', master_user='sync',master_password='Sync!0000',master_file_log='log.000006',master_log_pos='151'; (最關鍵的一步,將主庫ip,同步賬號的用戶密碼,show master status得到的file、position寫入。在5.7之前的版本這一步的相關參數是寫到配置文件中的,5.7如果再寫進配置文件會報參數錯誤)

4.start slave;

 

如果順利的話,到目前為止主從同步已經搭建完成,在從庫中使用show slave status \G;查看同步狀態

看到以上結果說明生效了,大家可以在主庫上插入數據測試一下主從同步是否生效了~

 

希望對大家有所幫助,祝大家每天開心~


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

-Advertisement-
Play Games
更多相關文章
  • 這次上機實習其實是比較順利的,因為之前在上課時就已經下載安裝好了的,在課後也有自己試驗過。但是在實習時還是有一些小小的麻煩,在查看資料庫,輸入指令show databases時少打了一個‘s’,導致一直錯誤,問了同學也沒解決,後面到網上查閱時才發現了這個問題。另外,在上機時,因為粗心將指令打錯而導致... ...
  • 為什麼要有集群 上一篇隨筆說了基本的主從概念以及搭建,一主可以有多從,如果同時訪問的量過大(1000w)或者發生自然災難,主服務肯定就會掛掉,數據服務就掛掉了 大公司都會有很多的伺服器(華東地區、華南地區、華中地區、華北地區、西北地區、西南地區、東北地區、台港澳地區機房) 集群的概念 集群是一組相互 ...
  • 一、備份namenode的元數據 namenode中的元數據非常重要,如丟失或者損壞,則整個系統無法使用。因此應該經常對元數據進行備份,最好是異地備份。 1、將元數據複製到遠程站點 (1)以下代碼將secondary namenode中的元數據複製到一個時間命名的目錄下,然後通過scp命令遠程發送到 ...
  • HDFS HA Namenode HA 詳解 hadoop2.x 之後,Clouera 提出了 QJM/Qurom Journal Manager,這是一個基於 Paxos 演算法(分散式一致性演算法)實現的 HDFS HA 方案,它給出了一種較好的解決思路和方案,QJM 主要優勢如下: 不需要配置額外 ...
  • NoSQL:一類新出現的資料庫(not only sql) 泛指非關係型的資料庫 不支持SQL語法 存儲結構跟傳統關係型資料庫中的那種關係表完全不同,nosql中存儲的數據都是KV形式 NoSQL的世界中沒有一種通用的語言,每種nosql資料庫都有自己的api和語法,以及擅長的業務場景 NoSQL中 ...
  • 一、增加MariaDB源 cd /etc/yum.repos.d vi MariaDB.repo # MariaDB 10.1 CentOS repository list - created 2017-04-20 03:29 UTC # http://downloads.mariadb.org/m ...
  • 一、為什麼要做Galera集群非同步複製 Galera集群解決了資料庫高可用的問題,但是存在局限性,例如耗時的事務處理可能會導致集群性能急劇下降,甚至出現阻塞現象。而不幸的是,類似報表等業務需求就需要做數據大批量的數據查詢操作,為了不影響Galera的集群效率,需要做數據非同步複製,產生一個從庫來適配耗 ...
  • 安裝Elasticsearch Elasticsearch下載地址:https://www.elastic.co/cn/downloads/elasticsearch 也可以直接使用wget下載到某目錄下, 本文所有下載的包都放在 /home/tools 中, 解壓後移到 /home/apps目錄下 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:本文代碼示例演示瞭如何在WPF中使用LiveCharts庫創建動態條形圖。通過創建數據模型、ViewModel和在XAML中使用`CartesianChart`控制項,你可以輕鬆實現圖表的數據綁定和動態更新。我將通過清晰的步驟指南包括詳細的中文註釋,幫助你快速理解並應用這一功能。 先上效果: 在 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • 概述:本示例演示了在WPF應用程式中實現多語言支持的詳細步驟。通過資源字典和數據綁定,以及使用語言管理器類,應用程式能夠在運行時動態切換語言。這種方法使得多語言支持更加靈活,便於維護,同時提供清晰的代碼結構。 在WPF中實現多語言的一種常見方法是使用資源字典和數據綁定。以下是一個詳細的步驟和示例源代 ...
  • 描述(做一個簡單的記錄): 事件(event)的本質是一個委托;(聲明一個事件: public event TestDelegate eventTest;) 委托(delegate)可以理解為一個符合某種簽名的方法類型;比如:TestDelegate委托的返回數據類型為string,參數為 int和 ...
  • 1、AOT適合場景 Aot適合工具類型的項目使用,優點禁止反編 ,第一次啟動快,業務型項目或者反射多的項目不適合用AOT AOT更新記錄: 實實在在經過實踐的AOT ORM 5.1.4.117 +支持AOT 5.1.4.123 +支持CodeFirst和非同步方法 5.1.4.129-preview1 ...
  • 總說周知,UWP 是運行在沙盒裡面的,所有許可權都有嚴格限制,和沙盒外交互也需要特殊的通道,所以從根本杜絕了 UWP 毒瘤的存在。但是實際上 UWP 只是一個應用模型,本身是沒有什麼許可權管理的,許可權管理全靠 App Container 沙盒控制,如果我們脫離了這個沙盒,UWP 就會放飛自我了。那麼有沒... ...
  • 目錄條款17:讓介面容易被正確使用,不易被誤用(Make interfaces easy to use correctly and hard to use incorrectly)限制類型和值規定能做和不能做的事提供行為一致的介面條款19:設計class猶如設計type(Treat class de ...
  • title: 從零開始:Django項目的創建與配置指南 date: 2024/5/2 18:29:33 updated: 2024/5/2 18:29:33 categories: 後端開發 tags: Django WebDev Python ORM Security Deployment Op ...
  • 1、BOM對象 BOM:Broswer object model,即瀏覽器提供我們開發者在javascript用於操作瀏覽器的對象。 1.1、window對象 視窗方法 // BOM Browser object model 瀏覽器對象模型 // js中最大的一個對象.整個瀏覽器視窗出現的所有東西都 ...