mysql5.6搭建主從複製

来源:https://www.cnblogs.com/accident/archive/2018/04/18/8871743.html
-Advertisement-
Play Games

使用MySQL 5.6,搭建主從複製。關於5.6的安裝,可以參考《MySQL 5.6 rpm安裝方法和碰見的問題》。 主庫創建slave用戶,設置複製許可權, mysql> create user 'slave'@'1.1.1.2' identified by 'root'; Query OK, 0 ...


使用MySQL 5.6,搭建主從複製。關於5.6的安裝,可以參考《MySQL 5.6 rpm安裝方法和碰見的問題》。

 

主庫創建slave用戶,設置複製許可權,

 

mysql> create user 'slave'@'1.1.1.2' identified by 'root';

 

Query OK, 0 rows affected (0.00 sec)

 

    1. mysql> grant replication slave on *.* to 'slave'@'1.1.1.2' identified by 'root';
    2. Query OK, 0 rows affected (0.00 sec)

 

  1. 編輯my.cnf配置文件,設置主庫server-id=1,定義需要複製的庫為test,忽略mysql資料庫
  1. [root@vm-kvm10000-app mysql]# vi /etc/my.cnf
  2. [mysqld]
  3. server-id=1
  4. log-bin=mysql-bin
  5. binlog_do_db=test
  6. binlog_ignore_db=mysql

 

  1. 重啟主庫MySQL服務,
  1. [root@vm-kvm10000-app mysql]# service mysql restart
  2. Shutting down MySQL.. SUCCESS!
  3. Starting MySQL. SUCCESS!

 

  1. 看一下主庫狀態,
  1. mysql> show master status;
  2. +------------------+----------+--------------+------------------+-------------------+
  3. | File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
  4. +------------------+----------+--------------+------------------+-------------------+
  5. | mysql-bin.000002 |      120 | test         | mysql            |                   |
  6. +------------------+----------+--------------+------------------+-------------------+
  7. 1 row in set (0.00 sec)

 

  1. 或者
  2. mysql> show master status \G
  3. *************************** 1. row ***************************
  4. File: mysql-bin.000002
  5. Position: 120
  6. Binlog_Do_DB: test
  7. Binlog_Ignore_DB: mysql
  8. Executed_Gtid_Set:
  9. 1 row in set (0.00 sec)

 

  1. 從庫,編輯my.cnf配置,設置server-id=2,區別於主庫,
  1. [root@vm-kvm10001-app mysql]# vi /etc/my.cnf
  2. [mysqld]
  3. server-id=2

 

  1. 重啟MySQL服務,
  1. [root@vm-kvm10001-app mysql]# service mysql restart
  2. Shutting down MySQL.. SUCCESS!
  3. Starting MySQL. SUCCESS!

 

  1. 設置主庫信息,
  1. mysql> change master to master_host='1.1.1.1',master_user='slave',master_password='root',master_log_file='mysql-bin.000001',master_log_pos=120,master_connect_retry=10;
  2. Query OK, 0 rows affected, 2 warnings (0.03 sec)

 

  1. 檢索從庫狀態,
  1. mysql> show slave status \G;
  2. *************************** 1. row ***************************
  3. Slave_IO_State:
  4. Master_Host: 10.221.3.129
  5. Master_User: slave
  6. Master_Port: 3306
  7. Connect_Retry: 10
  8. Master_Log_File: mysql-bin.000001
  9. Read_Master_Log_Pos: 120
  10. Relay_Log_File: vm-kvm11853-app-relay-bin.000001
  11. Relay_Log_Pos: 4
  12. Relay_Master_Log_File: mysql-bin.000001
  13. Slave_IO_Running: No
  14. Slave_SQL_Running: No
  15. Replicate_Do_DB:
  16. Replicate_Ignore_DB:
  17. Replicate_Do_Table:
  18. Replicate_Ignore_Table:
  19. Replicate_Wild_Do_Table:
  20. Replicate_Wild_Ignore_Table:
  21. Last_Errno: 0
  22. Last_Error:
  23. Skip_Counter: 0
  24. Exec_Master_Log_Pos: 120
  25. Relay_Log_Space: 120
  26. Until_Condition: None
  27. Until_Log_File:
  28. Until_Log_Pos: 0
  29. Master_SSL_Allowed: No
  30. Master_SSL_CA_File:
  31. Master_SSL_CA_Path:
  32. Master_SSL_Cert:
  33. Master_SSL_Cipher:
  34. Master_SSL_Key:
  35. Seconds_Behind_Master: NULL
  36. Master_SSL_Verify_Server_Cert: No
  37. Last_IO_Errno: 0
  38. Last_IO_Error:
  39. Last_SQL_Errno: 0
  40. Last_SQL_Error:
  41. Replicate_Ignore_Server_Ids:
  42. Master_Server_Id: 0
  43. Master_UUID:
  44. Master_Info_File: /var/lib/mysql/master.info
  45. SQL_Delay: 0
  46. SQL_Remaining_Delay: NULL
  47. Slave_SQL_Running_State:
  48. Master_Retry_Count: 86400
  49. Master_Bind:
  50. Last_IO_Error_Timestamp:
  51. Last_SQL_Error_Timestamp:
  52. Master_SSL_Crl:
  53. Master_SSL_Crlpath:
  54. Retrieved_Gtid_Set:
  55. Executed_Gtid_Set:
  56. Auto_Position: 0
  57. 1 row in set (0.00 sec)

 

  1. 其中最重要的就是,這兩個參數,要求YES,但此處為NO,
  1. Slave_IO_Running: No
  2. Slave_SQL_Running: No

 

  1. 檢索錯誤日誌,提示無法找見./performance_schema/cond_instances.frm文件,
  1. [root@vm-kvm10001-app mysql]# vm-kvm10001-app.err
  2. 2017-08-29 16:10:37 22933 [ERROR] /usr/sbin/mysqld: Can't find file: './performance_schema/cond_instances.frm' (errno: 13 - Permission denied)

 

  1. 看一下其目錄,發現performance_schema文件夾,是root許可權,mysql用戶無法訪問,因此需要修改一下其許可權,
  1. [root@vm-kvm10001-app mysql]# ls -rlht
  2. total 109M
  3. ...
  4. drwx------ 2 root  root  4.0K Aug 29 15:05 performance_schema
  5. ...

 

  1. [root@vm-kvm10001-app mysql]# chown -R mysql:mysql *

 

  1. [root@vm-kvm10001-app mysql]# ls -rlht
  2. total 109M
  3. ...
  4. drwx------ 2 mysql mysql 4.0K Aug 29 15:05 performance_schema
  1. ...

 

  1. 重啟服務,
  1. [root@vm-kvm10001-app mysql]# service mysql restart
  2. Shutting down MySQL.... SUCCESS!
  3. Starting MySQL. SUCCESS!

 

  1. 再看從庫狀態,
  1. mysql> show slave status \G
  2. *************************** 1. row ***************************
  3. ...
  4. Slave_IO_Running: Yes
  5. Slave_SQL_Running: Yes
  6. ...

 

  1. 主庫導出數據,用於導入從庫,首先需要設置讀鎖,避免數據不一致,
  1. mysql> flush tables with read lock;

 

  1. mysql> show master logs;
  2. +------------------+-----------+
  3. | Log_name         | File_size |
  4. +------------------+-----------+
  5. | mysql-bin.000001 |       143 |
  6. | mysql-bin.000002 |       222 |
  7. | mysql-bin.000003 |       545 |
  8. +------------------+-----------+
  9. 3 rows in set (0.00 sec)

 

  1. 執行mysqldump將test庫,導出test.sql文件,
  1. [root@vm-kvm10000-app mysql]# mysqldump -uroot -p -B test > test.sql

 

  1. 然後解鎖表,
  1. mysql> unlock tables;

 

  1. 從庫執行導入,
  1. [root@vm-kvm10001-app mysql]# mysql -uroot -p < test.sql

 

  1. 要確保從庫,這兩個值正確,
  1. Slave_IO_Running: Yes    
  2. Slave_SQL_Running: Yes

 

  1. 此時就完成了主從複製,向主庫插入一條記錄,
  1. mysql> INSERT INTO test
  2.     -> (id, name)
  3.     -> VALUES
  4.     -> (1, "a");
  5. Query OK, 1 rows affected (0.00 sec)

 

  1. 從庫中可以檢索出來,
  1. mysql> select * from test;
  2. +-------+--------+
  3. |     id    |  name  |
  4. +-------+--------+
  5. |      1    |     a      |
  6. +-------+--------+

 

 

  1. 總結:
  2. 1. MySQL相關文件、文件夾需要的許可權,可能會因為不正確,例如需要mysql許可權,但卻是root,導致資料庫異常。
  3. 2. 主從複製,需要關註從庫,這兩個參數值,需要均為YES,出現NO,則可以檢索錯誤日誌,進一步定位。
  4. Slave_IO_Running: Yes
  5. Slave_SQL_Running: Yes


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

-Advertisement-
Play Games
更多相關文章
  • 概述 UWP Community Toolkit 中有一個 Animations 的集合,它們可以幫助開發者實現很多的動畫,本篇我們先來看一下 Animations 的功能都有哪些,再後面會針對每一種 Animations 做詳細的代碼分析。 Animations 集合涵蓋了很多種類的動畫,我們先來 ...
  • 這篇博客的標題用了一個疑問句,源於我們公司的代碼評審,深刻的討論了單例模式的使用場景及其與靜態方法來說有何不同,這次討論確實讓我真正的理解了單例模式的使用,雖然說理解還一定全面,但必須作為一個認知的提升。告訴了我自己,對於編程,不懂的太多,原理性的東西還需要持續的學習。 進入正文,我們來討論一下,什 ...
  • 主題 之前簡單介紹了Asp.net core 的初步的使用,本篇我打算給大家介紹一下Identity的架構,讓大家對Identity有一個總體的理解和認識。 簡介 博客原文歡迎訪問我的博客網站,地址是:[深入理解Aspnet Core之Identity(4) ] : https://www.blue ...
  • 使用Json.Net可以把一個Json字元串轉換成一個JObject對象,如果有已知強類型,如果有已知對應的強類型,可以直接轉成對應的類型。但如果沒有,要訪問Json裡面對應的數據的時候,就顯得比較麻煩。我們可以藉助DynamicObject來訪問對應的屬性。 ...
  • 本文的概念內容來自深入淺出設計模式一書 現實世界中的適配器(模式) 我帶著一個國標插頭的筆記本電腦, 來到歐洲, 想插入到歐洲標準的牆壁插座裡面, 就需要用中間這個電源適配器. 面向對象的適配器 你有個老系統, 現在來了個新供應商的類, 但是它們的介面不同, 如何使用這個新供應商的類呢? 首先, 我 ...
  • WFP 的 Generic.xaml ,App.xaml 等中的資源會被調用 Freezable. 在後臺對該資源進行修改等操作會被提示.資源為密封對象. 如果,確定需要在後臺對資源進行修改. 則需要在資源中加入x:Shared="False"聲明 則不對該資源執行 Freezable() ...
  • 第一種-文章出處 > www.miniui.com/demo/listbox/moveitems.html <body> <h1>兩個ListBox之間選擇移動項 </h1> <input type="button" value="Save" onclick="saveData()" style=" ...
  • Enumerable.Distinct 方法 是常用的LINQ擴展方法,屬於System.Linq的Enumerable方法,可用於去除數組、集合中的重覆元素,還可以自定義去重的規則。 有兩個重載方法: // // 摘要: // 通過使用預設的相等比較器對值進行比較返回序列中的非重覆元素。 // / ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...