婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL復制問題的三個參數分析

MySQL復制問題的三個參數分析

熱門標簽:400電話辦理服務價格最實惠 400電話變更申請 武漢電銷機器人電話 北京金倫外呼系統 大豐地圖標注app 催天下外呼系統 南太平洋地圖標注 html地圖標注并導航 呂梁外呼系統

    今天星期二,早上居然起晚了,上班遲到了,簡直是。。。廢話不多說,在昨天的文章中,我們提到了三個參數,分別是:

  • slave_exec_mode參數;
  • sql_slave_skip_counter=N參數;
  • slave-skip-errors=N參數。

這三個參數都可以解決并行復制中的一些指定的錯誤,例如duplicate key 1062錯誤等,今天我們簡單試驗一下,這三個參數的區別:

01 sql_slave_skip_counter參數

這個參數的設置主要是為了跳過某些錯誤的"event",注意這里的用詞是event而不是事務,是因為它的本質是跳過一個一個事件,需要注意的是,這個參數需要在偏移量復制模式中使用,如果使用的是gtid的復制模式,則不可以使用這個參數。我們來看例子,首先搭建一套復制關系:

master   10.30.124.68

slave     10.30.124.128

這倆實例互為主從。我們創建測試表test.yeyz,并插入一些數據,其中id為主鍵,具有唯一性,如下:

master上

mysql:(none) 22:25:56>>select * from test.yeyz;
+----+------+
| id | age  |
+----+------+
|  1 |    1 |
|  2 |    2 |
|  3 |    3 |
|  4 |    4 |
+----+------+
4 rows in set (0.00 sec)

slave上

mysql:(none) 22:25:38>>select * from test.yeyz;
+----+------+
| id | age  |
+----+------+
|  1 |    1 |
|  2 |    2 |
|  3 |    3 |
|  4 |    4 |
|  5 |    5 |
+----+------+
5 rows in set (0.00 sec)

我們可以發現,從節點的數據比主節點多一條,多了id=5的記錄,然后我們在主節點上插入數據:

mysql:(none) 22:26:06>>insert into test.yeyz values (5,5),(6,6);
Query OK, 2 rows affected (0.00 sec)
Records: 2  Duplicates: 0  Warnings: 0

此時觀察從節點:

mysql:(none) 22:26:34>>show slave status\G
                  Master_Host: 10.30.124.68
                  Master_User: dba_repl
                  Master_Port: 4306
                Connect_Retry: 60
              Master_Log_File: mysqlbin.000002
          Read_Master_Log_Pos: 523
               Relay_Log_File: slave-relay-bin.000002
                Relay_Log_Pos: 319
        Relay_Master_Log_File: mysqlbin.000002
             Slave_IO_Running: Yes
            Slave_SQL_Running: No
                   Last_Errno: 1062
                   Last_Error: Coordinator stopped because there were error(s) 
in the worker(s). The most recent failure being:
 Worker 0 failed executing transaction 'ANONYMOUS' at
 master log mysqlbin.000002, end_log_pos 492.
 See error log and/or performance_schema.replication_applier_status_by_worker
 table for more details about this failure or others, if any.
                 Skip_Counter: 0

可以發現,從節點已經SQL線程斷開了, 這個時候,在主節點上查詢這個錯誤position 492處的binlog,可以看到:

mysql:(none) 22:30:28>>show binlog events in 'mysqlbin.000002' from 194;  
+-----------------+-----+----------------+-----------+-------------+--------------------------------------------+
| Log_name        | Pos | Event_type     | Server_id | End_log_pos | Info                                       |
+-----------------+-----+----------------+-----------+-------------+--------------------------------------------+
| mysqlbin.000002 | 194 | Anonymous_Gtid |       192 |         259 | SET @@SESSION.GTID_NEXT= 'ANONYMOUS'       |
| mysqlbin.000002 | 259 | Query          |       192 |         327 | BEGIN                                      |
| mysqlbin.000002 | 327 | Rows_query     |       192 |         391 | # insert into test.yeyz values (5,5),(6,6) |
| mysqlbin.000002 | 391 | Table_map      |       192 |         439 | table_id: 108 (test.yeyz)                  |
| mysqlbin.000002 | 439 | Write_rows     |       192 |         492 | table_id: 108 flags: STMT_END_F            |
| mysqlbin.000002 | 492 | Xid            |       192 |         523 | COMMIT /* xid=38 */                        |
+-----------------+-----+----------------+-----------+-------------+--------------------------------------------+
6 rows in set (0.00 sec)

從上面的binlog可以看出來,我們的一個insert操作實際上生成了5個enent,分別對應的pos是從259~492,關于event,待會兒再說。

因為主節點上插入了id=5的記錄,跟從節點上的記錄沖突了,查看錯誤日志,可以發現:

Duplicate entry '5' for key 'PRIMARY',
 Error_code: 1062; handler error HA_ERR_FOUND_DUPP_KEY; 
the event's master log FIRST, 
end_log_pos 492 | 2019-07-16 22:26:25

我們通過sql_slave_skip_counter參數的設置來解決這個問題,步驟如下:

mysql:(none) 22:29:32>>stop slave;
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql:(none) 22:32:45>>set global sql_slave_skip_counter=1;
Query OK, 0 rows affected (0.00 sec)

mysql:(none) 22:33:06>>start slave;

   在昨天的文章中我們說過,sql_slave_skip_counter后面跟的值是event的個數,所以這里我們相當于跳過了一個event,mysql中規定,如果跳過一個event之后,還在某一個事務里面,那么會繼續跳過這個事務。

   使用這個參數跳過一個event之后,我們再來看從庫表中的數據和復制情況,可以看到:

slave表:

mysql:(none) 22:33:10>>show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 10.30.124.68
                  Master_User: dba_repl
                  Master_Port: 4306
                Connect_Retry: 60
              Master_Log_File: mysqlbin.000002
          Read_Master_Log_Pos: 523
               Relay_Log_File: slave-relay-bin.000003
                Relay_Log_Pos: 319
        Relay_Master_Log_File: mysqlbin.000002
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes


mysql:(none) 22:33:16>>select * from test.yeyz;
+----+------+
| id | age  |
+----+------+
|  1 |    1 |
|  2 |    2 |
|  3 |    3 |
|  4 |    4 |
|  5 |    5 |
+----+------+
5 rows in set (0.00 sec)

看看master表:

mysql:(none) 22:33:36>>select * from test.yeyz;
+----+------+
| id | age  |
+----+------+
|  1 |    1 |
|  2 |    2 |
|  3 |    3 |
|  4 |    4 |
|  5 |    5 |
|  6 |    6 |
+----+------+
6 rows in set (0.00 sec)

   可以發現,master中數據插入成功,而slave中數據插入失敗,也就是說:

該參數跳過錯誤的時候,會導致主從的數據不一致。

02 slave_skip_errors參數

    這個參數是跳過制定的錯誤,也就是說,需要我們設置對應的error_code,從下面的日志中的內容可以看出,error_code的值為1062

Duplicate entry '5' for key 'PRIMARY',
 Error_code: 1062; handler error HA_ERR_FOUND_DUPP_KEY; 
the event's master log FIRST, 
end_log_pos 492 | 2019-07-16 22:26:25

   我們需要手動將這個參數的值也該為1062,需要注意的是,這個參數的改動需要重啟mysql服務,因為這個參數是一個只讀的參數。

   修改后的情況如下:

mysql--dba_admin@127.0.0.1:(none) 22:38:55>>show variables like '%errors%';
+--------------------+---------+
| Variable_name      | Value   |
+--------------------+---------+
| max_connect_errors | 1000000 |
| slave_skip_errors  | 1062    |
+--------------------+---------+
2 rows in set (0.01 sec)

   此時我們更新master表和slave表的數據,更新后的情況如下:

master:

mysql:(none) 22:39:15>>select * from test.yeyz;
+----+------+
| id | age  |
+----+------+
|  1 |    1 ||  2 |    2 |
|  3 |    3 ||  4 |    4 |
|  5 |    5 ||  6 |    6 |
+----+------+
6 rows in set (0.00 sec)

slave上:

mysql:(none) 22:40:15>>select * from test.yeyz;
+----+------+
| id | age  |
+----+------+
|  1 |    1 |
|  2 |    2 |
|  3 |    3 |
|  4 |    4 |
|  5 |    5 |
|  6 |    6 |
|  7 |    7 |
+----+------+
7 rows in set (0.00 sec)

我們發現,slave表比master表多一條數據,也就是id=7的記錄,此時我們在master上執行:

mysql:(none) 22:34:15>>insert into test.yeyz values (7,7),(8,8);
Query OK, 2 rows affected (0.00 sec)
Records: 2  Duplicates: 0  Warnings: 0

查看slave上面的復制情況和數據情況,如下:

mysql:(none) 22:39:05>>show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 10.30.124.68
                  Master_User: dba_repl
                  Master_Port: 4306
                Connect_Retry: 60
              Master_Log_File: mysqlbin.000002
          Read_Master_Log_Pos: 852
               Relay_Log_File: slave-relay-bin.000005
                Relay_Log_Pos: 648
        Relay_Master_Log_File: mysqlbin.000002
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
              Replicate_Do_DB: 
          Replicate_Ignore_DB: 
           Replicate_Do_Table: 
       Replicate_Ignore_Table: 
      Replicate_Wild_Do_Table: 


mysql:(none) 22:40:15>>select * from test.yeyz;
+----+------+
| id | age  |
+----+------+
|  1 |    1 |
|  2 |    2 |
|  3 |    3 |
|  4 |    4 |
|  5 |    5 |
|  6 |    6 |
|  7 |    7 |
+----+------+
7 rows in set (0.00 sec)

   可以看到,復制沒有出現錯誤,即使從庫上已經有id=7的記錄。而且發現,從庫的數據跟之前保持一致,也就是說,主庫插入的id=8的記錄沒有被同步過來。

   總結一下:該參數在跳過復制錯誤的時候,需要重啟mysql服務,然后可能導致主從數據不一致。

03 slave-skip-errors=N參數

  再看最后一個參數,這個參數表示的是并行復制過程中的從庫復制模式,默認值是strict嚴格模式,和上面一樣,我們先看主庫和從庫的數據情況:

master數據:

mysql:(none) 22:39:20>>select * from test.yeyz;                 
+----+------+
| id | age  |
+----+------+
|  1 |    1 |
|  2 |    2 |
|  3 |    3 |
|  4 |    4 |
|  5 |    5 |
|  6 |    6 |
|  7 |    7 |
|  8 |    8 |
+----+------+
8 rows in set (0.00 sec)

slave數據:

mysql:(none) 22:42:46>>select * from test.yeyz;
+----+------+
| id | age  |
+----+------+
|  1 |    1 |
|  2 |    2 |
|  3 |    3 |
|  4 |    4 |
|  5 |    5 |
|  6 |    6 |
|  7 |    7 |
|  8 |    8 |
|  9 |    9 |
+----+------+
9 rows in set (0.00 sec)

   此時我們在從庫上修改參數如下:

mysql:(none) 22:42:59>>show variables like '%exec%';
+----------------------------------+--------+
| Variable_name                    | Value  |
+----------------------------------+--------+
| gtid_executed_compression_period | 1000   |
| max_execution_time               | 0      |
| rbr_exec_mode                    | STRICT |
| slave_exec_mode                  | STRICT |
+----------------------------------+--------+
4 rows in set (0.00 sec)

mysql:(none) 22:44:05>>set global slave_exec_mode='IDEMPOTENT';
Query OK, 0 rows affected (0.00 sec)

mysql:(none) 22:44:10>>show variables like '%exec%';           
+----------------------------------+------------+
| Variable_name                    | Value      |
+----------------------------------+------------+
| gtid_executed_compression_period | 1000       |
| max_execution_time               | 0          |
| rbr_exec_mode                    | STRICT     |
| slave_exec_mode                  | IDEMPOTENT |
+----------------------------------+------------+
4 rows in set (0.00 sec)

  修改完參數,我們在主庫上進行insert操作:

insert into test.yeyz values (9,9),(10,10);

   查看從庫的復制狀態和數據情況,如下:

mysql:(none) 22:44:14>>show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 10.30.124.68
                  Master_User: dba_repl
                  Master_Port: 4306
                Connect_Retry: 60
              Master_Log_File: mysqlbin.000002
          Read_Master_Log_Pos: 1183
               Relay_Log_File: slave-relay-bin.000007
                Relay_Log_Pos: 650
        Relay_Master_Log_File: mysqlbin.000002
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes

1 row in set (0.00 sec)

mysql:(none) 22:44:38>>select * from test.yeyz;
+----+------+
| id | age  |
+----+------+
|  1 |    1 |
|  2 |    2 |
|  3 |    3 |
|  4 |    4 |
|  5 |    5 |
|  6 |    6 |
|  7 |    7 |
|  8 |    8 |
|  9 |    9 |
| 10 |   10 |
+----+------+
10 rows in set (0.00 sec)

   可以發現,既沒有出現復制錯誤,主庫上插入的數據也同步過來了。   

總結一下:

  • slave_exec_mode參數;
  • sql_slave_skip_counter=N參數;
  • slave-skip-errors=N參數。

   這三個參數都能解決復制過程中的不一致情況,區別如下:

slave_exec_mode參數可以保證主從數據一致,其他兩個不可以。

slave-skip-errors參數可以跳過制定的錯誤,但是需要重啟實例,不能保證數據一致。

sql_slave_skip_counter參數需要在偏移量的復制模式下使用,不能保證數據一致。

以上就是MySQL復制問題的三個參數分析的詳細內容,更多關于MySQL復制問題的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • MySQL5.7并行復制原理及實現
  • 詳解MySQL主從復制及讀寫分離
  • MySQL主從復制斷開的常用修復方法
  • MySql主從復制機制全面解析
  • MySQL系列之十三 MySQL的復制

標簽:迪慶 徐州 南充 龍巖 無錫 麗水 西寧 自貢

巨人網絡通訊聲明:本文標題《MySQL復制問題的三個參數分析》,本文關鍵詞  MySQL,復制,問,題的,三個,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL復制問題的三個參數分析》相關的同類信息!
  • 本頁收集關于MySQL復制問題的三個參數分析的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    久久 天天综合| 一区二区三区四区激情| 欧美日韩一区二区在线视频| 粉嫩在线一区二区三区视频| 国产在线精品免费av| 久久精品国产99| 国产精品99久久不卡二区| 国产一区二区三区四区五区入口| 国产一区二区伦理片| 国产一区二区三区免费观看| 国产成人精品三级麻豆| 99久久精品99国产精品| 色婷婷一区二区三区四区| 欧洲一区在线电影| 欧美一区二视频| 国产婷婷色一区二区三区在线| 国产精品久线在线观看| 一区二区欧美视频| 日韩精品亚洲一区| 懂色av噜噜一区二区三区av| 99视频一区二区| 欧美乱妇15p| 久久久久青草大香线综合精品| 国产精品久久久久影院色老大| 艳妇臀荡乳欲伦亚洲一区| 久久国产综合精品| 成人av在线看| 91精品国产乱码久久蜜臀| 久久精品一区蜜桃臀影院| 亚洲蜜桃精久久久久久久| 美女脱光内衣内裤视频久久网站| 高清不卡在线观看av| 欧美在线观看视频在线| 精品国产免费人成在线观看| 亚洲色图在线播放| 久久精品国产亚洲aⅴ| 99re热这里只有精品免费视频| 91精品国产免费久久综合| 中文字幕不卡在线观看| 首页国产欧美日韩丝袜| 97久久久精品综合88久久| 日韩美女在线视频| 一区二区三区**美女毛片| 国产风韵犹存在线视精品| 欧美精品日韩一本| 亚洲欧洲精品一区二区精品久久久| 免费成人在线影院| 欧美亚洲国产怡红院影院| 欧美国产精品一区二区| 极品美女销魂一区二区三区| 欧美在线观看视频一区二区| 中文字幕欧美区| 国产在线精品一区二区三区不卡| 在线电影一区二区三区| 亚洲午夜视频在线| 91视视频在线直接观看在线看网页在线看| 精品国产一区二区三区忘忧草 | 色综合视频一区二区三区高清| 欧美videos中文字幕| 日韩高清不卡在线| 欧美精品久久天天躁| 亚洲精品少妇30p| av不卡一区二区三区| 国产精品色在线| 国产69精品一区二区亚洲孕妇| 欧美大片拔萝卜| 久久国产精品72免费观看| 日韩欧美一级二级三级| 看电视剧不卡顿的网站| 日韩精品一区在线| 激情综合网天天干| 26uuu欧美| 丁香网亚洲国际| 成人欧美一区二区三区黑人麻豆 | 欧美大胆一级视频| 久久99精品一区二区三区三区| 欧美一级在线免费| 精品亚洲成a人| 国产欧美日本一区二区三区| 国产成人99久久亚洲综合精品| 国产日韩欧美精品电影三级在线| 国产情人综合久久777777| 国产精品福利在线播放| 成人黄色av网站在线| 中文字幕一区二区三区四区| 97超碰欧美中文字幕| 亚洲欧美视频在线观看视频| 在线看日韩精品电影| 日韩国产高清在线| 久久久久久免费| 成人免费视频app| 亚洲欧洲日韩av| 欧美剧在线免费观看网站 | 国产成人在线影院| 国产精品网友自拍| 欧美日韩在线精品一区二区三区激情| 日本少妇一区二区| 国产三级精品在线| 在线一区二区三区四区| 奇米影视一区二区三区| 中文在线一区二区| 欧美午夜一区二区三区免费大片| 免费不卡在线观看| 国产精品国产自产拍高清av王其 | 狠狠色综合日日| 国产精品入口麻豆九色| 欧美日韩日日骚| 成人精品亚洲人成在线| 午夜精品久久久久久久久久| 国产三级一区二区| 欧美日韩精品系列| 丰满岳乱妇一区二区三区| 三级影片在线观看欧美日韩一区二区| 国产亚洲1区2区3区| 欧美日韩激情一区| 不卡欧美aaaaa| 精品亚洲成av人在线观看| 亚洲午夜久久久久久久久久久 | 国产亚洲欧美中文| 欧美在线色视频| 国产ts人妖一区二区| 日韩国产成人精品| 亚洲精品中文字幕乱码三区| 欧美精品一区二区三区一线天视频| 色哟哟精品一区| 成人aaaa免费全部观看| 国产在线观看免费一区| 秋霞午夜鲁丝一区二区老狼| 亚洲综合男人的天堂| 亚洲欧洲国产日韩| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 美女看a上一区| 午夜精品免费在线| 亚洲午夜精品17c| 一区二区三区在线观看网站| 中文字幕免费观看一区| 欧美电影免费提供在线观看| 91精品欧美一区二区三区综合在 | 日本免费在线视频不卡一不卡二| 亚洲人精品午夜| 日韩理论片在线| 国产精品伦一区二区三级视频| 久久久91精品国产一区二区精品| 久久综合九色综合97_久久久| 日韩欧美国产综合一区| 欧美大片在线观看| 亚洲精品国产无天堂网2021 | 97精品电影院| 91老司机福利 在线| 91免费看片在线观看| 日本韩国一区二区| 欧美自拍偷拍午夜视频| 欧美日韩在线三区| 日韩一区二区三区视频在线 | 国产宾馆实践打屁股91| 国产精品一区二区在线观看不卡| 国产精品一二三区在线| 成人一区二区三区中文字幕| 99精品桃花视频在线观看| 色狠狠桃花综合| 欧美精品久久天天躁| 久久亚洲欧美国产精品乐播| 亚洲欧美在线另类| 亚洲成人777| 精品一区二区免费在线观看| 国产在线精品视频| av亚洲精华国产精华| 欧美日韩国产美女| 精品久久久久av影院| 中文字幕va一区二区三区| 亚洲美女在线一区| 久久超碰97中文字幕| 不卡的av在线| 欧美日韩第一区日日骚| 久久久久久久一区| 亚洲一级二级三级在线免费观看| 日本成人在线不卡视频| 风流少妇一区二区| 欧美福利一区二区| 国产精品色哟哟| 蜜臀久久久久久久| 成人一区二区三区视频在线观看| 91国产视频在线观看| 欧美不卡一区二区| 亚洲午夜一区二区三区| 国产成a人亚洲精品| 538prom精品视频线放| 自拍偷拍亚洲综合| 久久精品国产亚洲aⅴ| 欧美午夜精品理论片a级按摩| 久久久噜噜噜久久中文字幕色伊伊| 一区二区在线观看av| 国产麻豆精品视频| 欧美日韩成人在线一区| 中文字幕不卡在线播放| 奇米在线7777在线精品| 欧美综合在线视频| 自拍偷在线精品自拍偷无码专区 | 丝袜美腿亚洲一区| 色综合久久久久|