slave IO流程之二:註冊slave請求和dump請求

来源:http://www.cnblogs.com/onlyac/archive/2016/08/29/5817727.html
-Advertisement-
Play Games

slave IO流程已經在http://www.cnblogs.com/onlyac/p/5815566.html中有介紹 這次我們要探索註冊slave請求和dump請求的報文格式和主要流程。 一、註冊slave請求 在slave IO連接完資料庫後,slave IO接著在主庫里註冊自己,以便後續不 ...


slave IO流程已經在http://www.cnblogs.com/onlyac/p/5815566.html中有介紹

這次我們要探索註冊slave請求和dump請求的報文格式和主要流程。

一、註冊slave請求

在slave IO連接完資料庫後,slave IO接著在主庫里註冊自己,以便後續不需要提供slave IO登陸的信息如用戶名密碼等。

1.註冊slave請求的報文格式

 1 1              [15] COM_REGISTER_SLAVE
 2 4              server-id
 3 1              slaves hostname length
 4 string[$len]   slaves hostname
 5 1              slaves user len
 6 string[$len]   slaves user
 7 1              slaves password len
 8 string[$len]   slaves password
 9 2              slaves mysql-port
10 4              replication rank
11 4              master-id
View Code

(1)報文的類型COM_REGISTER_SLAVE

(2)slave伺服器的id,該id唯一併且只能通過my.cnf配置文件改變

(3)slave主機名長度

(4)slave主機名

(5)slave在主庫登陸用戶名長度

(6)slave在主庫登陸用戶名

(7)slave在主庫登陸的密碼長度

(8)slave在主庫登陸的密碼

(9)slave的mysql埠

(10)(11)這兩個都是0,不用去關註

2.在register_slave_on_master中

 1   int4store(pos, server_id); pos+= 4;
 2   pos= net_store_data(pos, (uchar*) report_host, report_host_len);
 3   pos= net_store_data(pos, (uchar*) report_user, report_user_len);
 4   pos= net_store_data(pos, (uchar*) report_password, report_password_len);
 5   int2store(pos, (uint16) report_port); pos+= 2;
 6   /* 
 7     Fake rpl_recovery_rank, which was removed in BUG#13963,
 8     so that this server can register itself on old servers,
 9     see BUG#49259.
10    */
11   int4store(pos, /* rpl_recovery_rank */ 0);    pos+= 4;
12   /* The master will fill in master_id */
13   int4store(pos, 0);                    pos+= 4;
View Code

這是除了第一個沒有的在1中的報文格式,然後通過simple_command發送出去。

1 #define simple_command(mysql, command, arg, length, skip_check) \
2   ((mysql)->methods \
3     ? (*(mysql)->methods->advanced_command)(mysql, command, 0, \
4                                             0, arg, length, skip_check, NULL) \
5     : (set_mysql_error(mysql, CR_COMMANDS_OUT_OF_SYNC, unknown_sqlstate), 1))
View Code

該函數指向cli_advanced_command。

(1)在li_advanced_command中

在通過函數net_write_command寫該報文

 1   if (net_write_command(net,(uchar) command, header, header_length,
 2             arg, arg_length))
 3   {
 4     DBUG_PRINT("error",("Can't send command to server. Error: %d",
 5             socket_errno));
 6     if (net->last_errno == ER_NET_PACKET_TOO_LARGE)
 7     {
 8       set_mysql_error(mysql, CR_NET_PACKET_TOO_LARGE, unknown_sqlstate);
 9       goto end;
10     }
11     end_server(mysql);
12     if (mysql_reconnect(mysql) || stmt_skip)
13       goto end;
14     
15     MYSQL_TRACE(SEND_COMMAND, mysql, (command, header_length, arg_length, header, arg));
16     if (net_write_command(net,(uchar) command, header, header_length,
17               arg, arg_length))
18     {
19       set_mysql_error(mysql, CR_SERVER_GONE_ERROR, unknown_sqlstate);
20       goto end;
21     }
22   }
View Code

(2)在net_write_command中

1   buff[4]=command;                /* For first packet */
View Code

這個寫了該報文的類型,

 1   if (length >= MAX_PACKET_LENGTH)
 2   {
 3     /* Take into account that we have the command in the first header */
 4     len= MAX_PACKET_LENGTH - 1 - head_len;
 5     do
 6     {
 7       int3store(buff, MAX_PACKET_LENGTH);
 8       buff[3]= (uchar) net->pkt_nr++;
 9       if (net_write_buff(net, buff, header_size) ||
10           net_write_buff(net, header, head_len) ||
11           net_write_buff(net, packet, len))
12       {
13         MYSQL_NET_WRITE_DONE(1);
14         DBUG_RETURN(1);
15       }
16       packet+= len;
17       length-= MAX_PACKET_LENGTH;
18       len= MAX_PACKET_LENGTH;
19       head_len= 0;
20       header_size= NET_HEADER_SIZE;
21     } while (length >= MAX_PACKET_LENGTH);
22     len=length;         /* Data left to be written */
23   }
24   int3store(buff, static_cast<uint>(length));
25   buff[3]= (uchar) net->pkt_nr++;
26   rc= MY_TEST(net_write_buff(net, buff, header_size) ||
27               (head_len && net_write_buff(net, header, head_len)) ||
28               net_write_buff(net, packet, len) || net_flush(net));
View Code

這所以這樣寫是因為每個報文有個這樣頭

1  if (!skip_check)
2   {
3     result= ((mysql->packet_length= cli_safe_read_with_ok(mysql, 1, NULL)) ==
4              packet_error ? 1 : 0);
View Code

(3)mysql協議的公共報文頭部

每個報文都有一個這樣的頭,這是忘記在上一章講的

View Code

第一個是這個報文的長度(以位元組為單位),第二個是這個報文的系列號,當然發送的內容原來就是一個報文,但是太長分成多個,第三個就是報文本身

對於超過16M的報文會這樣發送

View Code

 二、dump請求

1.dump請求的報文格式

dump有兩種格式:COM_BINLOG_DUMP_GTID和COM_BINLOG_DUMP

在slave IO的情形下,一般會使用COM_BINLOG_DUMP

為此,在此僅僅介紹COM_BINLOG_DUMP的格式

1 1              [12] COM_BINLOG_DUMP
2 4              binlog-pos
3 2              flags
4 4              server-id
5 string[EOF]    binlog-filename
View Code

(1)報文的類型COM_BINLOG_DUMP

(2)請求binlog的寫的位置

(3)一般為COM_BINLOG_DUMP_NO_BLOCK類型

(4)slave IO的所在伺服器的伺服器編號,和slave註冊協議中的那個一致

(5)當前需要讀的binlog文件名

2.在函數request_dump中

 1     int4store(ptr_buffer, DBUG_EVALUATE_IF("request_master_log_pos_3", 3,
 2                                            static_cast<uint32>(mi->get_master_log_pos())));
 3     ptr_buffer+= ::BINLOG_POS_OLD_INFO_SIZE;
 4     // See comment regarding binlog_flags above.
 5     int2store(ptr_buffer, binlog_flags);
 6     ptr_buffer+= ::BINLOG_FLAGS_INFO_SIZE;
 7     int4store(ptr_buffer, server_id);
 8     ptr_buffer+= ::BINLOG_SERVER_ID_INFO_SIZE;
 9     memcpy(ptr_buffer, mi->get_master_log_name(), BINLOG_NAME_INFO_SIZE);
10     ptr_buffer+= BINLOG_NAME_INFO_SIZE;
11 
12     command_size= ptr_buffer - command_buffer;
13     DBUG_ASSERT(command_size == (allocation_size - 1));
View Code

同樣地是COM_BINLOG_DUMP的格式。

這邊也使用simple_command(mysql, command, command_buffer, command_size, 1)寫入。


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

-Advertisement-
Play Games
更多相關文章
  • 牛B的swift屏幕旋轉經驗終結者(OC統一思路) 1、AppDelegate (1)定義變數 var blockRotation: Bool = false (2)定義方法 Swift代碼 func application(application: UIApplication, supported ...
  • 1.方法的命名規範,以NSString和NSMutableString為例如果方法是新創建的方法的第一個名字應該是其返回類型 + (instancetype)string; + (instancetype)stringWithString:(NSString *)string; + (instanc... ...
  • iOS系列 基礎篇 05 視圖鼻祖 - UIView 目錄: 在Cocoa和Cocoa Touch框架中,“根”類時NSObject類。同樣,在UIKit框架中,也存在一個神奇的類——UIView。 從繼承關係上看,UIView是所有視圖的根,我們形象地稱其為“始祖”。 本篇,咱們就一起研究UIVi ...
  • http://www.path8.net/tn/archives/951 MySQL支持大量的列類型,它可以被分為3類:數字類型、日期和時間類型以及字元串(字元)類型。本節首先給出可用類型的一個概述,並且總結每個列類型的存儲需求,然後提供每個類中的類型性質的更詳細的描述。概述有意簡化,更詳細的說明應 ...
  • 增加了一個Tools類,放了一些常用的工具 然後寫了一個比較通用的update方法 懶得寫測試類,肯定好使,相信我~ ...
  • 在使用sqlplus登錄資料庫的時候,輸入sys用戶名出現報錯 解決這個問題就是在輸入用戶名的時候加上as sysdba 這樣就不會出現上面ORA-28009:connection as sys should be as sysdba or sysoper ...
  • 前提條件: 1、Spark Standalone 集群部署完成 2、Intellij Idea 能夠運行 Spark local 模式的程式。 源碼: 這裡主要的思想還是將打包的jar提交到集群。 使用.setJars方法 ...
  • 一、 表設計 二、 索引 三、 SQL語句 四、 散表 五、 其他 FAQ 1-1.庫名、表名、欄位名必須使用小寫字母,“_”分割。 a)MySQL有配置參數lower_case_table_names,不可動態更改,linux系統預設為0,即庫表名以實際情況存儲,大小寫敏感。如果是1,以小寫存儲, ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...