日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL复制跳过错误--slave_skip_errors、sql_slave_skip_counter、slave_exec_mode

發(fā)布時間:2023/12/8 数据库 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL复制跳过错误--slave_skip_errors、sql_slave_skip_counter、slave_exec_mode 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

MySQL主從復(fù)制中的跳過錯誤處理參數(shù)--slave_skip_errors、sql_slave_skip_counter、slave_exec_mode



跳過復(fù)制錯誤——slave_skip_errors、slave_exec_mode

跳過復(fù)制錯誤——sql_slave_skip_counter




1 簡介

? ? mysql在主從復(fù)制過程中,由于各種的原因,從服務(wù)器可能會遇到執(zhí)行BINLOG中的SQL出錯的情況,在默認(rèn)情況下,服務(wù)器會停止復(fù)制進(jìn)程,不再進(jìn)行同步,等到用戶自行來處理。

? ? slave-skip-errors的作用就是用來定義復(fù)制過程中從服務(wù)器可以自動跳過的錯誤號,當(dāng)復(fù)制過程中遇到定義的錯誤號,就可以自動跳過,直接執(zhí)行后面的SQL語句。

2 官方參考



? ? slave_skip_errors選項有四個可用值,分別為:off,all,ErorCode,ddl_exist_errors。

? ? ?默認(rèn)情況下該參數(shù)值是off,我們可以列出具體的error code,也可以選擇all,mysql5.6及MySQL Cluster NDB 7.3以及后續(xù)版本增加了參數(shù)ddl_exist_errors,該參數(shù)包含一系列error code(1007,1008,1050,1051,1054,1060,1061,1068,1094,1146)

? ? 一些error code代表的錯誤如下:

? ? 1007:數(shù)據(jù)庫已存在,創(chuàng)建數(shù)據(jù)庫失敗

? ? 1008:數(shù)據(jù)庫不存在,刪除數(shù)據(jù)庫失敗

? ? 1050:數(shù)據(jù)表已存在,創(chuàng)建數(shù)據(jù)表失敗

? ? 1051:數(shù)據(jù)表不存在,刪除數(shù)據(jù)表失敗

? ? 1054:字段不存在,或程序文件跟數(shù)據(jù)庫有沖突

? ? 1060:字段重復(fù),導(dǎo)致無法插入

? ? 1061:重復(fù)鍵名

? ? 1068:定義了多個主鍵

? ? 1094:位置線程ID

? ? 1146:數(shù)據(jù)表缺失,請恢復(fù)數(shù)據(jù)庫

? ? 1053:復(fù)制過程中主服務(wù)器宕機(jī)

? ? 1062:主鍵沖突 Duplicate entry '%s' for key %d


?my.cnf中的寫法:

slave_skip_errors=1062,1053??

slave_skip_errors=all??

slave_skip_errors=ddl_exist_errors??

??

? 作為mysql啟動參數(shù)的寫法:

--slave-skip-errors=1062,1053??

--slave-skip-errors=all??

--slave-skip-errors=ddl_exist_errors??

? ??

從數(shù)據(jù)庫中查看該參數(shù)的值:

mysql> show variables like 'slave_skip%';??

+-------------------+-------+??

| Variable_name? ? ?| Value |??

+-------------------+-------+??

| slave_skip_errors | 1007? |??

+-------------------+-------+??


3 舉例分析

? ? 3.1 測試說明

? ? 配置好mysql主從同步,然后在從上寫入數(shù)據(jù),造成主從不一致。

? ? 3.2 準(zhǔn)備測試表結(jié)構(gòu)

? ? 在主機(jī)上創(chuàng)建表:

create table replication (c1 int not null primary key, c2 varchar(10));??

? ? 3.3 準(zhǔn)備測試數(shù)據(jù)

? ? 在主機(jī)上插入基礎(chǔ)數(shù)據(jù)

mysql> insert into replication values (1, 'test1');??

mysql> insert into replication values (2, 'test2');??

? ? 此時,主機(jī)從機(jī)replication表里面都有兩條記錄

? ? 3.4 開始測試

? ? 從機(jī)插入一條記錄

mysql> insert into replication values (3, 'test3');??

? ? 然后在主機(jī)上執(zhí)行相同的操作

mysql> insert into replication values (3, 'test3');??

? ? 在從機(jī)上查看復(fù)制狀態(tài)

mysql> show slave status \G??

*************************** 1. row ***************************??

? ? ? ? ? ? ? ?Slave_IO_State: Waiting for master to send event??

? ? ? ? ? ? ? ? ? Master_Host: 192.168.1.222??

? ? ? ? ? ? ? ? ? Master_User: repl??

? ? ? ? ? ? ? ? ? Master_Port: 3306??

? ? ? ? ? ? ? ? Connect_Retry: 60??

? ? ? ? ? ? ? Master_Log_File: mysql-bin.000003??

? ? ? ? ? Read_Master_Log_Pos: 16700??

? ? ? ? ? ? ? ?Relay_Log_File: mysql-relay-bin.000003??

? ? ? ? ? ? ? ? Relay_Log_Pos: 16595??

? ? ? ? Relay_Master_Log_File: mysql-bin.000003??

? ? ? ? ? ? ?Slave_IO_Running: Yes??

? ? ? ? ? ? Slave_SQL_Running: No??

? ? ? ? ? ? ? Replicate_Do_DB:? ?

? ? ? ? ? Replicate_Ignore_DB:? ?

? ? ? ? ? ?Replicate_Do_Table:? ?

? ? ? ?Replicate_Ignore_Table: mysql.ibbackup_binlog_marker??

? ? ? Replicate_Wild_Do_Table:? ?

? Replicate_Wild_Ignore_Table: mysql.backup_%??

? ? ? ? ? ? ? ? ? ?Last_Errno: 1062??

? ? ? ? ? ? ? ? ? ?Last_Error: Error 'Duplicate entry '3' for key 'PRIMARY'' on query. Default database: 'test'. Query: 'insert into replication values (3, 'test3')'??

? ? ? ? ? ? ? ? ?Skip_Counter: 0??

? ? ? ? ? Exec_Master_Log_Pos: 16425??

? ? ? ? ? ? ? Relay_Log_Space: 17544??

? ? 可以看到:sql線程已經(jīng)停止工作 Slave_SQL_Running: No

? ? ? ? ? ? ? ? ? ? ? ? 錯誤號為:Last_Errno: 1062

? ? ? ? ? ? ? ? ? ? ? ? 錯誤信息為:Last_Error: Error 'Duplicate entry '3' for key 'PRIMARY'' on query. Default database: 'test'. Query: 'insert into replication values (3, 'test3')'

? ? 如果我們在my.cnf中加入如下選項,則可跳過此錯誤,數(shù)據(jù)同步繼續(xù)進(jìn)行。

[mysqld]??

slave_skip_errors=1062??

? ? 具體測試方法同上,大家可自己驗證。

4 從backup恢復(fù)時從機(jī)復(fù)制出錯的一些解釋


? ? mysql企業(yè)版?zhèn)浞莨ぞ適eb提供在線熱備功能,如果在備份過程中執(zhí)行ddl操作,從機(jī)需要從主機(jī)的備份恢復(fù)時可能會異常,從而導(dǎo)致從機(jī)同步數(shù)據(jù)失敗。原因是從機(jī)恢復(fù)時需要先從備份文件恢復(fù)(包含備份過程中執(zhí)行的ddl語句),

同步時不是從全備后的最后一個位置同步,而是從ddl的上個位置同步,如果再次執(zhí)行該ddl語句在從機(jī)上不會造成沖突,

則同步繼續(xù),如果會造成沖突,同步終止。解決此沖突的辦法是在my.cnf文件中加入一行

[mysqld]??

slave_skip_errors=ddl_exist_errors??

5 注意事項

? ? 5.1 該參數(shù)為全局靜態(tài)參數(shù),不能動態(tài)調(diào)整,可在my.cnf中加入該參數(shù)列表后重啟mysql服務(wù)器生效。

? ? 5.2 必須注意的是,啟動這個參數(shù),如果處理不當(dāng),很可能造成主從數(shù)據(jù)庫的數(shù)據(jù)不同步,在應(yīng)用中需要根據(jù)實際情況,如果對數(shù)據(jù)完整性要求不是很嚴(yán)格,那么這個選項確實可以減輕維護(hù)的成本

****************************************************************************************


sql_slave_skip_counter 介紹:

摘自MySQL官方的解釋( 強(qiáng)烈建議閱讀英文原文 。中文版,是筆者自己的理解,只能說仁者見仁)

SET GLOBAL sql_slave_skip_counter Syntax:
??????? SET GLOBAL sql_slave_skip_counter = N
This statement skips the next N events from the master. This is useful for recovering from replication stops caused by a statement.
??????? 跳過N個events。注意:以event為單位,而不是以事務(wù)為單位,只有在由單條語句組成的事務(wù)時,兩者才等價。
??????? 如:一個事務(wù)由多個EVENT組成,BEGIN;INSERT;UPDATE;DELETE;COMMOIT; 這種情況下,兩者絕不相等
This statement is valid only when the slave threads are not running. Otherwise, it produces an error.

When using this statement, it is important to understand that the binary log is actually organized as a sequence of groups known as event groups. Each event group consists of a sequence of events.

For transactional tables, an event group corresponds to a transaction.
??? ????對于事務(wù)表,一個event group對應(yīng)一個事務(wù)
or nontransactional tables, an event group corresponds to a single SQL statement.?
??????? 對于非事務(wù)表,一個event group對應(yīng)一條SQL
When you use SET GLOBAL sql_slave_skip_counter to skip events and the result is in the middle of a group, the slave continues to skip events until it reaches the end of the group. Execution then starts with the next event group
??? ????當(dāng)你跳過event的時候,如果N的值,處于event group之中,那么slave會繼續(xù)跳過event,直至跳過這個event group,從下一個event group開始


對于事務(wù)表使用 sql_slave_skip_counter 的情況:


1、跳過1032復(fù)制錯誤(update/delete error)

跳過由單條SQL組成的事務(wù):


在Slave主機(jī)上人為的刪除兩條數(shù)據(jù):

DELETE FROM `edusoho_e`.`t1` WHERE `id` = '9';?
DELETE FROM `edusoho_e`.`t1` WHERE `id` = '11';?


而Master在變更上述兩條記錄的時候會報錯,導(dǎo)致復(fù)制中斷:

INSERT INTO `edusoho_e`.`t1` (`xname`, `address`, `hobby`) VALUES ('孫權(quán)', '吳國', '妹妹');?
UPDATE `edusoho_e`.`t1` SET xname='游戲' WHERE id=7;
UPDATE `edusoho_e`.`t1` SET age=40 WHERE id=11;???? #報錯
DELETE FROM `edusoho_e`.`t1` WHERE age=40;??????????? ?#報錯
INSERT INTO `edusoho_e`.`t1` (`xname`, `address`, `hobby`) VALUES ('曹丕', '魏國', '甄姬');
DELETE FROM `edusoho_e`.`t1` WHERE id=1;
UPDATE `edusoho_e`.`t1` SET hobby='Games' WHERE id=3;?


在Slave查看主從復(fù)制狀態(tài)時,就會發(fā)現(xiàn)報錯信息:

mysql> show slave status\G;
*************************** 1. row ***************************
Read_Master_Log_Pos: 2176
Exec_Master_Log_Pos:? 874
Last_Errno: 1032
Last_Error: Could not execute? Update_rows ?event on table edusoho_e.t1; Can't find record in 't1', Error_code: 1032; handler error HA_ERR_KEY_NOT_FOUND; the event's master log mysql-bin.000002, end_log_pos 1127
Slave_IO_Running: Yes
Slave_SQL_Running: No


在Master主機(jī)上查看position做了什么操作:

mysql> show binlog events in 'mysql-bin.000002' from 874;
+------------------+------+-------------+-----------+-------------+---------------------------------+
| Log_name???????? | Pos? | Event_type? | Server_id | End_log_pos | Info??????????????????????????? |
+------------------+------+-------------+-----------+-------------+---------------------------------+
| mysql-bin.000002 |?? 874? | Query?????? |???????? 2 |???????? 956 | BEGIN?????????????????????????? |
| mysql-bin.000002 |? 956 | Table_map?? |???????? 2 |??????? 1017 | table_id: 213 (edusoho_e.t1)??? |
| mysql-bin.000002 | 1017 | Update_rows |???????? 2 |??????? 1127 | table_id: 213 flags: STMT_END_F |
| mysql-bin.000002 | 1127 | Xid???????? |???????? 2 |??????? 1158 | COMMIT /* xid=437 */??????????? |
| mysql-bin.000002 | 1158 | Query?????? |???????? 2 |??????? 1240 | BEGIN?????????????????????????? |
| mysql-bin.000002 | 1240 | Table_map?? |???????? 2 |??????? 1301 | table_id: 213 (edusoho_e.t1)??? |
| mysql-bin.000002 | 1301 | Delete_rows |???????? 2 |??????? 1407 | table_id: 213 flags: STMT_END_F |
| mysql-bin.000002 | 1407 | Xid???????? |???????? 2 |??????? 1438 | COMMIT /* xid=446 */??????????? |
| mysql-bin.000002 | 1438 | Query?????? |???????? 2 |??????? 1520 | BEGIN?????????????????????????? |
| mysql-bin.000002 | 1520 | Table_map?? |???????? 2 |??????? 1581 | table_id: 213 (edusoho_e.t1)??? |
| mysql-bin.000002 | 1581 | Write_rows? |???????? 2 |??????? 1644 | table_id: 213 flags: STMT_END_F |
| mysql-bin.000002 | 1644 | Xid???????? |???????? 2 |??????? 1675 | COMMIT /* xid=455 */??????????? |
| mysql-bin.000002 | 1675 | Query?????? |???????? 2 |??????? 1757 | BEGIN?????????????????????????? |
| mysql-bin.000002 | 1757 | Table_map?? |???????? 2 |??????? 1818 | table_id: 213 (edusoho_e.t1)??? |
| mysql-bin.000002 | 1818 | Delete_rows |???????? 2 |??????? 1880 | table_id: 213 flags: STMT_END_F |
| mysql-bin.000002 | 1880 | Xid???????? |???????? 2 |??????? 1911 | COMMIT /* xid=464 */??????????? |
| mysql-bin.000002 | 1911 | Query?????? |???????? 2 |??????? 1993 | BEGIN?????????????????????????? |
| mysql-bin.000002 | 1993 | Table_map?? |???????? 2 |??????? 2054 | table_id: 213 (edusoho_e.t1)??? |
| mysql-bin.000002 | 2054 | Update_rows |???????? 2 |??????? 2145 | table_id: 213 flags: STMT_END_F |
| mysql-bin.000002 | 2145 | Xid???????? |???????? 2 |??????? 2176 | COMMIT /* xid=473 */??????????? |
+------------------+------+-------------+-----------+-------------+---------------------------------+


在Slave跳過第一個 Update_rows event 復(fù)制報錯:

mysql>? set global sql_slave_skip_counter=1;
mysql> ?start slave sql_thread;
mysql> show slave status\G;
Slave_IO_Running: Yes
Slave_SQL_Running: No
Exec_Master_Log_Pos:? 1158
Last_SQL_Errno: 1032
Last_SQL_Error: Could not execute? Delete_rows ?event on table edusoho_e.t1; Can't find record in 't1', Error_code: 1032; handler error HA_ERR_KEY_NOT_FOUND; the event's master log mysql-bin.000002, end_log_pos 1407


成功跳過第一個events group


在Slave繼續(xù)跳過第二個 Delete_rows event 復(fù)制報錯:

mysql> set global sql_slave_skip_counter=1;
mysql> start slave sql_thread;
mysql> show slave status\G;
*************************** 1. row ***************************
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Last_SQL_Errno: 0
Last_SQL_Error:?


成功跳過第二個 events group


注意:

雖然主從復(fù)制出現(xiàn)的故障成功跳過了,但只是暫時恢復(fù)了正常的主從復(fù)制狀態(tài),需要盡快的對Slave缺失的數(shù)據(jù)進(jìn)行補(bǔ)齊,不然Master對Slave不存在的數(shù)據(jù)做的變更,仍然會重復(fù)導(dǎo)致主從復(fù)制故障,筆者覺得如果你的數(shù)據(jù)量差異不是太大的話,可以考慮使用 pt-table-checksum 和 pt-table-sync 工具進(jìn)行恢復(fù),如果你的數(shù)據(jù)量很大且數(shù)據(jù)差異很多,還是建議重做Slave較好,因為使用工具會鎖表,會對線上業(yè)務(wù)造成一定的影響,具體情況,請自行考量。


跳過由多條SQL(event)組成的事務(wù):

在Slave主機(jī)上人為的刪除一條數(shù)據(jù):

DELETE FROM `edusoho_e`.`t1` WHERE `id` = '7';?


在Master主機(jī)上產(chǎn)生一個由多條SQL組成的事務(wù):

BEGIN;
DELETE FROM `edusoho_e`.`t1` WHERE `id` = '7';?
INSERT INTO `edusoho_e`.`t1` (`xname`, `address`, `hobby`) VALUES ('懶死', '不知道', '吃了睡睡了吃');?
COMMIT;


因為Slave主機(jī)上已經(jīng)刪除id=7的數(shù)據(jù),在Slave查看主從復(fù)制狀態(tài)時,就會發(fā)現(xiàn)報錯信息:

mysql> show slave status\G;
*************************** 1. row ***************************
Read_Master_Log_Pos: 7219
Exec_Master_Log_Pos:? 6840
Slave_IO_Running: Yes
Slave_SQL_Running: No
Last_Errno: 1032
Last_Error: Could not execute? Delete_rows ?event on table edusoho_e.t1; Can't find record in 't1', Error_code: 1032; handler error HA_ERR_KEY_NOT_FOUND; the event's master log mysql-bin.000002, end_log_pos 7049


在Master主機(jī)上查看position做了什么操作:

mysql> show binlog events in 'mysql-bin.000002' from 6840;
+------------------+------+-------------+-----------+-------------+---------------------------------+
| Log_name???????? | Pos? | Event_type? | Server_id | End_log_pos | Info??????????????????????????? |
+------------------+------+-------------+-----------+-------------+---------------------------------+
| mysql-bin.000002 | 6840 | Query?????? |???????? 2 |??????? 6922 |? BEGIN??????????????????????????? |
| mysql-bin.000002 | 6922 | Table_map?? |???????? 2 |??????? 6983 | table_id: 213 (edusoho_e.t1)??? |
| mysql-bin.000002 | 6983 | Delete_rows |???????? 2 |??????? 7049 | table_id: 213 flags: STMT_END_F |
| mysql-bin.000002 | 7049 | Table_map?? |???????? 2 |??????? 7110 | table_id: 213 (edusoho_e.t1)??? |
| mysql-bin.000002 | 7110 | Write_rows? |???????? 2 |??????? 7188 | table_id: 213 flags: STMT_END_F |
| mysql-bin.000002 | 7188 | Xid???????? |???????? 2 |???????? 7219? |? COMMIT? /* xid=825 */??????????? |
+------------------+------+-------------+-----------+-------------+---------------------------------+


可以看到,這個事務(wù)是由兩個SQL(event)組成的


如果使用 sql_slave_skip_counter=N 跳過由多條SQL組成的事務(wù)會怎樣呢?

mysql> set global sql_slave_skip_counter=1;
mysql> start slave sql_thread;
mysql> show slave status\G;
*************************** 1. row ***************************
Read_Master_Log_Pos: 7219
Exec_Master_Log_Pos:? 7219
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Last_Errno: 0
Last_Error:


發(fā)現(xiàn)問題沒有 ,在使用sql_slave_skip_counter跳過由多條SQL(event)組成的事務(wù)時,從在Master上執(zhí)行的 show binlog events 可以看到,如果只是跳過出報錯SQL語句,那么 Exec_Master_Log_Pos 值應(yīng)該為7110,但是現(xiàn)在為7219,說明將整個event group跳過了,但是7110的SQL數(shù)據(jù)是我們需要的,所以,和單條SQL組成的事務(wù)一樣,主從復(fù)制狀態(tài)雖然恢復(fù),但是數(shù)據(jù)仍處于不一致狀態(tài),要抓緊時間補(bǔ)齊數(shù)據(jù)或重做Slave


2、 由多條SQL(event)組成的事務(wù)時,僅跳過一個event,而不是一個event group:

在Slave主機(jī)上人為的刪除一條數(shù)據(jù):

DELETE FROM `edusoho_e`.`t1` WHERE `id` = '17';?


在Master主機(jī)上產(chǎn)生一個由多條SQL組成的事務(wù):

BEGIN;
DELETE FROM `edusoho_e`.`t1` WHERE `id` = '17';
INSERT INTO `edusoho_e`.`t1` (`xname`, `address`, `hobby`) VALUES ('我是誰', '不知道', '吃了睡睡了吃');
COMMIT;


因為Slave主機(jī)上已經(jīng)刪除id=17的數(shù)據(jù),在Slave查看主從復(fù)制狀態(tài)時,就會發(fā)現(xiàn)報錯信息:

Exec_Master_Log_Pos:? 120

Slave_IO_Running: Yes
Slave_SQL_Running: No

Last_Errno: 1032
Last_Error: Could not execute? Delete_rows ?event on table edusoho_e.t1; Can't find record in 't1', Error_code: 1032; handler error HA_ERR_KEY_NOT_FOUND; the event's master log mysql-bin.000004, end_log_pos 341


在Master主機(jī)上查看position做了什么操作:

mysqlbinlog -v --base64-output=decode --start-position=120 mysql-bin.000004
/*!50530 SET @@SESSION.PSEUDO_SLAVE_MODE=1*/;
/*!40019 SET @@session.max_insert_delayed_threads=0*/;
/*!50003 SET @OLD_COMPLETION_TYPE=@@COMPLETION_TYPE,COMPLETION_TYPE=0*/;
DELIMITER /*!*/;
# at 120
#190507 13:52:05 server id 2? end_log_pos 202 CRC32 0x0ca0c280 ?? ?Query?? ?thread_id=3?? ?exec_time=0?? ?error_code=0
SET TIMESTAMP=1557208325/*!*/;
SET @@session.pseudo_thread_id=3/*!*/;
SET @@session.foreign_key_checks=1, @@session.sql_auto_is_null=0, @@session.unique_checks=1, @@session.autocommit=1/*!*/;
SET @@session.sql_mode=1073741824/*!*/;
SET @@session.auto_increment_increment=2, @@session.auto_increment_offset=1/*!*/;
/*!\C utf8 *//*!*/;
SET @@session.character_set_client=33,@@session.collation_connection=33,@@session.collation_server=33/*!*/;
SET @@session.lc_time_names=0/*!*/;
SET @@session.collation_database=DEFAULT/*!*/;
BEGIN
/*!*/;
# at 202
#190507 13:52:05 server id 2? end_log_pos 263 CRC32 0x20d2e89d ?? ?Table_map: `edusoho_e`.`t1` mapped to number 216
# at 263
#190507 13:52:05 server id 2? end_log_pos 341 CRC32 0xbec6fd45 ?? ?Delete_rows: table id 216 flags: STMT_END_F
### DELETE FROM `edusoho_e`.`t1`
### WHERE
###?? @1=17
###?? @2='懶死'
###?? @3='不知道'
###?? @4=1
###?? @5='吃了睡睡了吃'
###?? @6=18

# at 341
#190507 13:52:05 server id 2? end_log_pos 402 CRC32 0xa37bc5c9 ?? ?Table_map: `edusoho_e`.`t1` mapped to number 216
# at 402
#190507 13:52:05 server id 2? end_log_pos 483 CRC32 0x0d774707 ?? ?Write_rows: table id 216 flags: STMT_END_F
### INSERT INTO `edusoho_e`.`t1`
### SET
###?? @1=21
###?? @2='我是誰'
###?? @3='不知道'
###?? @4=1
###?? @5='吃了睡睡了吃'
###?? @6=18
# at 483
#190507 13:52:05 server id 2? end_log_pos 514 CRC32 0x8c333b30 ?? ?Xid = 411
COMMIT /*!*/;
DELIMITER ;
# End of log file
ROLLBACK /* added by mysqlbinlog */;
/*!50003 SET COMPLETION_TYPE=@OLD_COMPLETION_TYPE*/;
/*!50530 SET @@SESSION.PSEUDO_SLAVE_MODE=0*/;

可以看到,綠色的部分就是我們需要跳過的,而第二個event是需要我們保留的

這個時候,就需要用到 slave_exec_mode 這個變量了,至于slave_exec_mode詳細(xì)介紹,還是請參考MySQL官網(wǎng)資料


mysql> set global slave_exec_mode='IDEMPOTENT';
mysql> start slave sql_thread;
mysql> show slave status\G;
*************************** 1. row ***************************

Slave_IO_Running: Yes
Slave_SQL_Running: Yes

Exec_Master_Log_Pos: 514


去Slave上edusoho_e.t1表上查看,數(shù)據(jù)id=21的數(shù)據(jù)已經(jīng)過去了,此時,數(shù)據(jù)處于一致性狀態(tài)


3、 跳過主鍵沖突1062錯誤(Duplicate entry):

在Slave主鍵上先插入一條id值:

INSERT INTO `edusoho_e`.`t1` (`id`,`xname`, `address`, `hobby`, `age`) VALUES (19,'小玩子', '明朝', '皇后', '25');?


因為Slave已經(jīng)占用了Master要自動產(chǎn)生的主鍵值id=19,所以Slave主機(jī)會報錯:

INSERT INTO `edusoho_e`.`t1` (`id`,`xname`, `address`, `hobby`, `age`) VALUES (19,'朱棣', '明朝', '皇帝', '36');?


查看Slave主從復(fù)制狀態(tài)發(fā)現(xiàn)已經(jīng)發(fā)生了主從復(fù)制報錯:

mysql> show slave status\G;
*************************** 1. row ***************************
Slave_IO_Running: Yes
Slave_SQL_Running: No
Last_Errno: 1062
Last_Error: Could not execute Write_rows event on table edusoho_e.t1;? Duplicate entry ?'19' for key 'PRIMARY', Error_code: 1062; handler error HA_ERR_FOUND_DUPP_KEY; the event's master log mysql-bin.000002, end_log_pos 7425
Exec_Master_Log_Pos:? 7219


查看Master binlog:

mysql> show binlog events in 'mysql-bin.000002' from 7219;
+------------------+------+------------+-----------+-------------+---------------------------------+
| Log_name???????? | Pos? | Event_type | Server_id | End_log_pos | Info??????????????????????????? |
+------------------+------+------------+-----------+-------------+---------------------------------+
| mysql-bin.000002 | 7219 | Query????? |???????? 2 |??????? 7301 | BEGIN?????????????????????????? |
| mysql-bin.000002 | 7301 | Table_map? |???????? 2 |??????? 7362 | table_id: 213 (edusoho_e.t1)??? |
| mysql-bin.000002 | 7362 | Write_rows |???????? 2 |??????? 7425 | table_id: 213 flags: STMT_END_F |
| mysql-bin.000002 | 7425 | Xid??????? |???????? 2 |??????? 7456 | COMMIT /* xid=893 */??????????? |
+------------------+------+------------+-----------+-------------+---------------------------------+


思考:

因為Slave這條數(shù)據(jù)已經(jīng)存在,如果在Slave主機(jī)上把這條數(shù)據(jù)刪除了,Slave會不會直接同步過來?(答案是:不會。需要重啟Slave thread):

DELETE FROM `edusoho_e`.`t1` WHERE `id` = '19';?
mysql> stop slave;
mysql> start slave user='repliter' password='123456';

驗證的時候,發(fā)現(xiàn)數(shù)據(jù)已經(jīng)同步過去了


題外:

以上是筆者對于單條SQL組成的事務(wù)、多條SQL組成的事務(wù),及在這些單/多條SQL組成的事務(wù)下,人為設(shè)置的1032和1062復(fù)制錯誤和解決方法,還有sql_slave_skip_counter和slave_exec_mode各自的用法和跳過的范圍,當(dāng)然了, 筆者呢,做的只是線上應(yīng)用前的部署測試,并沒有經(jīng)過任何的實戰(zhàn)檢測。一方面,僅為廣大同行做個參考;另一方面,記錄筆者自己的心得和針對問題解決的思路做個總結(jié),當(dāng)問題真正發(fā)生的時候,有個方向可以進(jìn)行參考,而不至于手忙腳亂,不知所措,所以,對其中有誤之處和理解不到位的地方,望請下方留言指正,不勝感激!

還有,筆者做的,只是針對事務(wù)表,做的 sql_slave_skip_counter和slave_exec_mode測試,對于非事務(wù)表, sql_slave_skip_counter和slave_exec_mode用途會稍有不同,請自行百度吧。


slave_exec_mode=IDEMPOTENT?在MySQL復(fù)制環(huán)境中是個很有用的參數(shù):只要在備機(jī)運(yùn)行set?global?slave_exec_mode=IDEMPOTENT?,備機(jī)的sql?thread就運(yùn)行在冥等模式下,可以讓備機(jī)在insert主鍵、唯一鍵沖突,update、delete值未找到錯誤發(fā)生時不斷開復(fù)制而保持冥等性(當(dāng)即生效,連slave的sql線程都不用重啟喲);而類似sql_slave_skip_counter=N和slave-skip-errors?=?N?這樣的粗暴跳過錯誤方法可能破壞主備一致性。但官方文檔的描述很簡潔,我一直好奇slave_exec_mode=IDEMPOTENT?是如何在復(fù)制出錯時保持一致性的--譬如主鍵沖突時是簡單跳過還是覆寫,今天在Percona?5.7下做了個實驗(binlog是row格式),實驗過程就省略了,直接總結(jié)如下: 1.insert場景 此時insert?into語句在備機(jī)的效果就跟replace?into一樣,但卻并不是把insert?into轉(zhuǎn)換成replace?into來執(zhí)行,分兩種情況: a.MySQL配置成autocommit,直接一條insert?into?... 如這樣的insert insert?into?test?set?c1='a',c2='b'; 此時insert?into語句在備機(jī)執(zhí)行時假如遇到主鍵沖突就先轉(zhuǎn)化為delete再insert delete?from?test?where?c1='old_value'?and?c2='old_value';??? insert?into?test?set?c1='a',c2='b';??? 假如遇到非主鍵的唯一鍵沖突就轉(zhuǎn)換為update update?test?set?set?c1='a',c2='b'?where?c1='old_value'?and?c2='old_value'; b.當(dāng)顯示開始事務(wù)時(begin...insert?into...commit;) 如這樣的sql begin;??? ......? insert?into?test?set?c1='a',c2='b';??? ......? commit;??? 此時begin...commit里的insert?into語句在備機(jī)執(zhí)行時假如遇到主鍵沖突、唯一鍵沖突都是先轉(zhuǎn)化為delete再insert begin;??? ......? delete?from?test?where?c1='old_value'?and?c2='old_value';??? insert?into?test?set?c1='a',c2='b';??? ......? commit;??? 2.update場景 當(dāng)備機(jī)不存在要更新的記錄,這條update跳過不執(zhí)行 3.delete場景? 同update場景一樣,備機(jī)跳過此delete啥也不干 注意:使用冥等模式時表要有主鍵 冥等模式并不是萬能的,除了不能對DDL操作冥等,對字段長度不同導(dǎo)致的錯誤也不是冥等(譬如主機(jī)一個字段是char(20)而備機(jī)是char(10)),還有一個限制就是表有主鍵才會對insert的冥等設(shè)置有效:因為insert的冥等行為是通過主鍵來判斷備機(jī)是否有重復(fù)值從而產(chǎn)生覆寫操作,如果表沒有主鍵,則備機(jī)即使設(shè)了冥等也可能會比主機(jī)多重復(fù)數(shù)據(jù)。


slave_exec_mode設(shè)置可以跳過1032(記錄沒有找到)和1062(主鍵重復(fù))錯誤,并記錄到錯誤日志中。 slave_exec_mode和slave_skip_errors作用是一樣的,只是slave_exec_mode可以在線動態(tài)設(shè)置。slave_skip_errors必須添加到配置文件中,重啟生效。 備庫 mysql> select * from testdb1.student; +------+------+-------+-------+ | id???| name | class | score | +------+------+-------+-------+ |????1 | a????| 1?????|????45 | |????2 | b????| 1?????|????46 | |????3 | c????| 2?????|????89 | |????4 | d????| 2?????|????90 | |????5 | e????| 3?????|????67 | |????6 | f????| 3?????|????87 | |????7 | g????| 4?????|????77 | |????8 | h????| 4?????|????91 | +------+------+-------+-------+ 8 rows in set (0.00 sec) mysql> delete from testdb1.student where id >5; Query OK, 3 rows affected (0.00 sec) mysql> commit; Query OK, 0 rows affected (0.00 sec) #修改參數(shù)之前 主庫master mysql>??delete from testdb1.student where id >7; Query OK, 1 row affected (0.00 sec) 備庫查看狀態(tài) mysql> show slave status\G *************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Host: 192.168.56.91 Master_User: rep Master_Port: 3306 Connect_Retry: 60 Master_Log_File: ray-bin.000008 Read_Master_Log_Pos: 1272 Relay_Log_File: ray-relay-bin.000003 Relay_Log_Pos: 1226 Relay_Master_Log_File: ray-bin.000008 Slave_IO_Running: Yes Slave_SQL_Running: No Replicate_Do_DB: Replicate_Ignore_DB: Replicate_Do_Table: Replicate_Ignore_Table: Replicate_Wild_Do_Table: Replicate_Wild_Ignore_Table: Last_Errno: 1032 Last_Error: Could not execute Delete_rows event on table testdb1.student; Can't find record in 'student', Error_code: 1032; handler error HA_ERR_END_OF_FILE; the event's master log ray-bin.000008, end_log_pos 1241 Skip_Counter: 0 Exec_Master_Log_Pos: 1065 Relay_Log_Space: 1957 Until_Condition: None Until_Log_File: Until_Log_Pos: 0 Master_SSL_Allowed: No Master_SSL_CA_File: Master_SSL_CA_Path: Master_SSL_Cert: Master_SSL_Cipher: Master_SSL_Key: Seconds_Behind_Master: NULL Master_SSL_Verify_Server_Cert: No Last_IO_Errno: 0 Last_IO_Error: Last_SQL_Errno: 1032 Last_SQL_Error: Could not execute Delete_rows event on table testdb1.student; Can't find record in 'student', Error_code: 1032; handler error HA_ERR_END_OF_FILE; the event's master log ray-bin.000008, end_log_pos 1241 Replicate_Ignore_Server_Ids: Master_Server_Id: 2 Master_UUID: 840f94e0-8ea0-11e5-af92-080027a94012 Master_Info_File: /data/3307/data/master.info SQL_Delay: 0 SQL_Remaining_Delay: NULL Slave_SQL_Running_State: Master_Retry_Count: 86400 Master_Bind: Last_IO_Error_Timestamp: Last_SQL_Error_Timestamp: 151126 12:42:37 Master_SSL_Crl: Master_SSL_Crlpath: Retrieved_Gtid_Set: Executed_Gtid_Set: Auto_Position: 0 1 row in set (0.00 sec) mysql> stop slave; Query OK, 0 rows affected (0.78 sec) mysql> set global sql_slave_skip_counter=1; Query OK, 0 rows affected (0.01 sec) mysql> start slave; Query OK, 0 rows affected (0.33 sec) #修改備庫參數(shù) mysql> show variables like '%slave_exec_mode%'; +-----------------+--------+ | Variable_name???| Value??| +-----------------+--------+ | slave_exec_mode | STRICT | +-----------------+--------+ 1 row in set (0.00 sec) mysql> set global slave_exec_mode=idempotent; Query OK, 0 rows affected (0.00 sec) mysql> show variables like '%slave_exec_mode%'; +-----------------+------------+ | Variable_name???| Value??????| +-----------------+------------+ | slave_exec_mode | IDEMPOTENT | +-----------------+------------+ 1 row in set (0.00 sec) 主庫刪除數(shù)據(jù) mysql>??delete from testdb1.student where id >6; Query OK, 1 row affected (0.01 sec) mysql> commit; Query OK, 0 rows affected (0.00 sec) 備庫查看狀態(tài)和錯誤日志 mysql> show slave status\G *************************** 1. row *************************** Slave_IO_State: Waiting for master to send event Master_Host: 192.168.56.91 Master_User: rep Master_Port: 3306 Connect_Retry: 60 Master_Log_File: ray-bin.000008 Read_Master_Log_Pos: 1479 Relay_Log_File: ray-relay-bin.000004 Relay_Log_Pos: 488 Relay_Master_Log_File: ray-bin.000008 Slave_IO_Running: Yes Slave_SQL_Running: Yes Replicate_Do_DB: Replicate_Ignore_DB: Replicate_Do_Table: Replicate_Ignore_Table: Replicate_Wild_Do_Table: Replicate_Wild_Ignore_Table: Last_Errno: 0 Last_Error: Skip_Counter: 0 Exec_Master_Log_Pos: 1479 Relay_Log_Space: 1972 Until_Condition: None Until_Log_File: Until_Log_Pos: 0 Master_SSL_Allowed: No Master_SSL_CA_File: Master_SSL_CA_Path: Master_SSL_Cert: Master_SSL_Cipher: Master_SSL_Key: Seconds_Behind_Master: 0 Master_SSL_Verify_Server_Cert: No Last_IO_Errno: 0 Last_IO_Error: Last_SQL_Errno: 0 Last_SQL_Error: Replicate_Ignore_Server_Ids: Master_Server_Id: 2 Master_UUID: 840f94e0-8ea0-11e5-af92-080027a94012 Master_Info_File: /data/3307/data/master.info SQL_Delay: 0 SQL_Remaining_Delay: NULL Slave_SQL_Running_State: Slave has read all relay log; waiting for the slave I/O thread to update it Master_Retry_Count: 86400 Master_Bind: Last_IO_Error_Timestamp: Last_SQL_Error_Timestamp: Master_SSL_Crl: Master_SSL_Crlpath: Retrieved_Gtid_Set: Executed_Gtid_Set: Auto_Position: 0 1 row in set (0.00 sec) [root@ray ~]# tail -20f /data/3307/data/mysql_ray.err 2015-11-26 12:50:29 12127 [Warning] Slave SQL: Could not execute Delete_rows event on table testdb1.student; Can't find record in 'student', Error_code: 1032; handler error HA_ERR_END_OF_FILE; the event's master log ray-bin.000008, end_log_pos 1655, Error_code: 1032 注:pos可能對不上,因為截取的問題,不必在意。







About Me

........................................................................................................................

● 本文作者:小麥苗,部分內(nèi)容整理自網(wǎng)絡(luò),若有侵權(quán)請聯(lián)系小麥苗刪除

● 本文在itpub、博客園、CSDN和個人微 信公眾號( xiaomaimiaolhr )上有同步更新

● 本文itpub地址: http://blog.itpub.net/26736162

● 本文博客園地址: http://www.cnblogs.com/lhrbest

● 本文CSDN地址: https://blog.csdn.net/lihuarongaini

● 本文pdf版、個人簡介及小麥苗云盤地址: http://blog.itpub.net/26736162/viewspace-1624453/

● 數(shù)據(jù)庫筆試面試題庫及解答: http://blog.itpub.net/26736162/viewspace-2134706/

● DBA寶典今日頭條號地址: http://www.toutiao.com/c/user/6401772890/#mid=1564638659405826

........................................................................................................................

● QQ群號: 230161599 (滿) 、618766405

● 微 信群:可加我微 信,我拉大家進(jìn)群,非誠勿擾

● 聯(lián)系我請加QQ好友 646634621 ,注明添加緣由

● 于 2019-07-01 06:00 ~ 2019-07-31 24:00 在西安完成

● 最新修改時間:2019-07-01 06:00 ~ 2019-07-31 24:00

● 文章內(nèi)容來源于小麥苗的學(xué)習(xí)筆記,部分整理自網(wǎng)絡(luò),若有侵權(quán)或不當(dāng)之處還請諒解

● 版權(quán)所有,歡迎分享本文,轉(zhuǎn)載請保留出處

........................................................................................................................

小麥苗的微店 : https://weidian.com/s/793741433?wfr=c&ifr=shopdetail

小麥苗出版的數(shù)據(jù)庫類叢書 : http://blog.itpub.net/26736162/viewspace-2142121/

小麥苗OCP、OCM、高可用網(wǎng)絡(luò)班 : http://blog.itpub.net/26736162/viewspace-2148098/

小麥苗騰訊課堂主頁 : https://lhr.ke.qq.com/

........................................................................................................................

使用 微 信客戶端 掃描下面的二維碼來關(guān)注小麥苗的微 信公眾號( xiaomaimiaolhr )及QQ群(DBA寶典)、添加小麥苗微 信, 學(xué)習(xí)最實用的數(shù)據(jù)庫技術(shù)。

........................................................................................................................

?

?



來自 “ ITPUB博客 ” ,鏈接:http://blog.itpub.net/26736162/viewspace-2651331/,如需轉(zhuǎn)載,請注明出處,否則將追究法律責(zé)任。

總結(jié)

以上是生活随笔為你收集整理的MySQL复制跳过错误--slave_skip_errors、sql_slave_skip_counter、slave_exec_mode的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

成人sm另类专区 | 亚洲婷婷伊人 | wwwww.国产 | 在线免费观看的av | 中文字幕在线免费 | 蜜桃麻豆www久久囤产精品 | a在线观看免费视频 | 99久久精品日本一区二区免费 | 九九九九九九精品 | 美女黄视频免费 | 亚洲最新av网站 | 欧美国产精品久久久久久免费 | 国产精品99在线播放 | 最新免费av在线 | 日韩一区二区三 | 狠狠色噜噜狠狠狠狠2022 | 美女福利视频在线 | 成人av影视在线 | 在线观看电影av | 91成人破解版 | 欧美福利久久 | 国产不卡免费 | 日韩精品一区二区在线观看 | 亚洲电影自拍 | 区一区二区三在线观看 | 国产无遮挡又黄又爽馒头漫画 | 在线免费观看黄色av | 777久久久 | 婷婷久操 | 日韩久久精品一区二区 | 狠狠色丁香婷婷综合久久片 | 亚洲 欧美 国产 va在线影院 | 国产精品黑丝在线观看 | 天堂久久电影网 | 国产在线观看污片 | 九九九视频在线 | a黄色一级 | 久久综合狠狠综合久久综合88 | 中文字幕在线观看网 | 国产高清在线观看av | 17婷婷久久www | 久久99视频免费 | 国产另类av | 丁香电影小说免费视频观看 | 国产精品福利久久久 | 国产主播99| 丁香花五月 | 久久久色 | 97超碰在线久草超碰在线观看 | 最近免费中文字幕 | 久久久久久久久久久久久久av | 亚洲天天综合网 | 日韩精品一区二区三区外面 | 免费影视大全推荐 | 国产精品毛片 | 免费福利片2019潦草影视午夜 | 欧美91成人网 | 欧美少妇xxx | 免费福利视频网站 | 丝袜网站在线观看 | 国产精品区二区三区日本 | 国产尤物一区二区三区 | 成人小视频在线播放 | 狠色在线| 在线观看av大片 | 精精国产xxxx视频在线播放 | 久久精品在线视频 | 久久精品一 | 天天干夜夜 | 久久久久国产一区二区三区四区 | 五月天久久婷 | 99精品国产在热久久下载 | 亚洲无线视频 | 国产亚洲精品免费 | 四虎在线免费 | 超碰精品在线 | 99视频精品免费观看, | 日韩精品免费在线观看视频 | 天天插天天射 | 欧美日韩亚洲第一 | av黄色在线播放 | a一片一级 | 少妇av网| 中文字幕日韩伦理 | 日韩av不卡在线 | 在线观看免费av网站 | 欧美日韩精品在线观看 | 五月婷在线视频 | 久草免费在线视频 | 一区二区国产精品 | 草草草影院| 亚洲精品人人 | 伊人久久电影网 | 久久久av电影 | 狠狠躁夜夜躁人人爽超碰91 | 狠狠天天 | 在线观看亚洲免费视频 | 91社区国产高清 | 精品国产免费久久 | 亚洲精品日韩一区二区电影 | 一区二区三区免费在线观看 | a资源在线 | 九九热视频在线免费观看 | 久久99国产精品自在自在app | 亚州精品天堂中文字幕 | av免费在线网站 | 久久视频精品 | av在观看 | 91亚洲在线 | 国产丝袜在线 | 在线电影av | 国产69精品久久久久99 | 27xxoo无遮挡动态视频 | 国产一级片播放 | 成人欧美在线 | 日韩在线免费小视频 | 69国产精品视频 | 99久久精品无码一区二区毛片 | www.日韩免费| 久久久综合色 | 69av国产 | 久久国产精品99久久人人澡 | 九九久久免费 | 日韩在线观看视频中文字幕 | 美女网站一区 | 国产黄色片久久 | 亚在线播放中文视频 | 激情影音先锋 | 99在线视频免费观看 | 国产视频每日更新 | 日韩av播放在线 | 欧美日韩在线网站 | 精品av在线播放 | www.人人草| 久草在线综合 | 亚洲成人资源 | 人人狠狠综合久久亚洲 | www看片网站 | www.伊人网| 中文字幕av有码 | 国产精品欧美日韩在线观看 | 国产99一区视频免费 | 九九爱免费视频 | 国产精品久久9 | 日韩视频中文字幕在线观看 | 国产在线观看av | 色婷久久 | 五月香婷 | 亚洲综合激情网 | 一区二区精 | 99这里有精品 | 久久免费国产电影 | 久久人人爽人人爽人人片av免费 | 亚洲精品1区2区3区 超碰成人网 | 国产午夜精品免费一区二区三区视频 | 久久视频在线观看免费 | 日韩视频免费在线观看 | 99精品免费 | 国产精品99久久久久久武松影视 | 国产精品日韩在线 | 欧美一级激情 | 欧美日韩在线视频观看 | 成年美女黄网站色大片免费看 | 久久成人免费视频 | 香蕉日日| 91字幕| 国内精品毛片 | 国产美女被啪进深处喷白浆视频 | 中文字幕电影高清在线观看 | 亚洲黄色在线播放 | 草久久久久久 | 99久久久久国产精品免费 | 97人人澡人人爽人人模亚洲 | 国产日本高清 | 伊人丁香| 91人人爽人人爽人人精88v | 91av视频免费观看 | 色婷婷亚洲综合 | 视频一区亚洲 | 免费观看的黄色片 | 五月婷婷香蕉 | 视频一区视频二区在线观看 | 手机在线观看国产精品 | 日韩在线一区二区免费 | 色播五月婷婷 | 在线 精品 国产 | 狠狠操狠狠干天天操 | 日本中文在线 | 久久综合九色综合欧美狠狠 | 中文字幕在线观看免费观看 | 日韩黄色中文字幕 | 国产九色91 | 久久免费一 | 中文字幕在线乱 | 69精品久久 | 久久精品这里热有精品 | 国产精品一区二区三区99 | 午夜久久久影院 | 91高清不卡 | 九色在线视频 | 国产麻豆电影在线观看 | 99久在线精品99re8热视频 | 国产在线国偷精品产拍免费yy | 亚洲欧美成人在线 | 天天插综合 | 欧美日韩在线观看不卡 | avav片 | 在线观看成人国产 | 狠狠干天天 | 我要看黄色一级片 | 久久精品久久99 | www久久精品 | 在线观看激情av | 亚洲一级黄色片 | 日本性久久| 一区二区三区日韩视频在线观看 | 国产不卡精品视频 | 久久无码av一区二区三区电影网 | 国产涩图 | 伊人首页| 色停停五月天 | www.久久久| 韩国三级一区 | 天堂av网在线 | 国产精品尤物视频 | 国产精品久久久久久久久婷婷 | 亚洲妇女av| 狠狠色噜噜狠狠 | 99精品视频在线播放观看 | 久一网站| 偷拍区另类综合在线 | 狠狠的操狠狠的干 | 国产精品福利在线观看 | 久久国产精品二国产精品中国洋人 | 99产精品成人啪免费网站 | 在线观看免费黄色 | 成人免费观看视频大全 | 97超碰超碰久久福利超碰 | 国产v在线 | 91视频免费播放 | 成人a v视频 | 99精品乱码国产在线观看 | 超碰在97 | 成年人视频在线观看免费 | 1000部国产精品成人观看 | 少妇精69xxtheporn | 国产成人精品一区二区三区福利 | 天天做天天爽 | 久久深夜福利免费观看 | 国产精品久久99综合免费观看尤物 | 伊人永久 | 91热这里只有精品 | 国产资源在线播放 | 成人精品亚洲 | 91超碰在线播放 | 婷婷激情av| 韩国av不卡 | 亚洲永久国产精品 | 久久成人在线视频 | 久久色在线播放 | a天堂在线看 | 综合久久久 | 久久综合九色综合欧美狠狠 | 亚洲网站在线看 | 狠狠色综合网站久久久久久久 | 久久久999| 国产综合小视频 | 久久久久久久久久久电影 | 国产资源网| 欧美福利视频一区 | 国产午夜精品久久 | 国产老妇av | 亚洲涩综合 | 丁香婷婷深情五月亚洲 | 综合色天天 | 欧美巨大 | 婷婷六月天综合 | 精品一区二区三区久久久 | 五月婷婷激情 | www.久草.com | 国产在线91在线电影 | 99一区二区三区 | www.99av | 欧美日韩三区二区 | 成人免费在线播放 | 区一区二区三区中文字幕 | 国产精品一区二区视频 | 中文在线8资源库 | 久久久麻豆精品一区二区 | 亚洲日韩中文字幕在线播放 | 国产精品女同一区二区三区久久夜 | 五月婷婷av | 久久大香线蕉app | 国产污视频在线观看 | 婷婷久久网站 | 亚洲精品玖玖玖av在线看 | 亚洲精品在线观看网站 | 日韩免费电影在线观看 | 中文在线www| 91视频首页 | 欧美亚洲一区二区在线 | 色婷婷99| 午夜视频免费在线观看 | 成人av电影免费在线播放 | 天天干视频在线 | 日韩免费看 | 欧美极品少妇xbxb性爽爽视频 | 日韩专区在线观看 | 国产亚洲精品久久19p | 久久久久北条麻妃免费看 | 欧美日韩精品在线一区二区 | 狠狠插天天干 | 99在线观看视频网站 | 日韩欧美高清在线观看 | 日本精品在线 | 久久艹艹 | 欧美日韩高清一区二区 国产亚洲免费看 | 午夜在线国产 | 久久久麻豆视频 | 色99之美女主播在线视频 | 91精品在线免费观看视频 | 国产在线美女 | 韩国av免费观看 | 欧美性受极品xxxx喷水 | 日韩欧美在线国产 | 手机看片中文字幕 | 国产精品高清一区二区三区 | 日韩精品在线免费观看 | 在线观看v片 | 综合黄色网 | 精品特级毛片 | 国产精品乱码高清在线看 | 日韩电影一区二区三区在线观看 | 天天色天 | 最近中文字幕在线中文高清版 | 久久久久久久久国产 | 97色视频在线 | 中文字幕色在线视频 | 国产精品麻豆三级一区视频 | 在线黄色观看 | 黄色免费高清视频 | 99免费在线观看视频 | 欧美精品久久久久久久久久白贞 | av永久网址| 97电影网手机版 | 久草| 高清免费av在线 | 成人久久久久 | 一区二区三区精品久久久 | 欧美国产高清 | 婷婷色中文 | 日本中文字幕电影在线免费观看 | 久久免费精彩视频 | 一区二区三区免费在线观看 | 成人久久毛片 | 日韩在线观看视频一区二区三区 | 久久av高清 | 久久久精品国产一区二区 | 国产区精品视频 | 五月婷婷视频在线 | 91资源在线免费观看 | 色播五月激情五月 | 综合激情伊人 | 亚洲一区欧美激情 | 欧美日韩精品在线观看视频 | 日韩国产精品一区 | 日本公妇在线观看高清 | 亚洲电影第一页av | 亚洲综合小说电影qvod | 日韩午夜视频在线观看 | 久久艹久久 | 精品人妖videos欧美人妖 | 日韩亚洲在线视频 | 一区二区精| 福利久久久 | 日韩激情av在线 | 在线中文字幕一区二区 | 综合激情网... | 日韩r级电影在线观看 | 免费亚洲电影 | 欧美三级在线播放 | 91免费视频网站在线观看 | 激情偷乱人伦小说视频在线观看 | 日韩精品久久久 | 国产黄色片免费观看 | 在线精品一区二区 | 免费中文字幕 | 黄色免费网 | av免费观看高清 | 97超碰精品 | 国产麻豆精品久久 | 天天操夜夜想 | 2023国产精品自产拍在线观看 | 久久久久久久免费观看 | 国产无遮挡又黄又爽馒头漫画 | 欧美精品你懂的 | 97av视频| 日日干夜夜操视频 | 973理论片235影院9 | 日韩精品免费在线 | 精品在线一区二区三区 | 国产亚洲精品久久久久久大师 | 色婷婷成人 | 特级a毛片 | 在线中文字幕网站 | 日韩免费一级电影 | 天天曰天天干 | 一级黄色在线免费观看 | 色a资源在线| 97超碰中文字幕 | 午夜免费福利片 | 香蕉视频在线播放 | 精品在线观 | 国产精品美女免费看 | 中文字幕高清在线播放 | 中文不卡视频 | 中文字幕高清免费日韩视频在线 | 久久精品永久免费 | 久久久午夜视频 | 国产精品高清一区二区三区 | 最新国产在线观看 | 91最新网址在线观看 | 久久伊人综合 | 综合国产在线观看 | 亚洲精品五月天 | 日韩av网址在线 | 丝袜美腿亚洲综合 | 丝袜美女在线 | 欧美日本不卡视频 | 亚洲开心色 | 日韩一级片大全 | 香蕉视频啪啪 | 欧美性色19p | 久久草在线精品 | 日韩午夜在线播放 | 精品久久一 | 高清免费av在线 | 久久久国产精品久久久 | 久久国产精品成人免费浪潮 | 欧美在线视频免费 | 国产精品麻豆三级一区视频 | 黄色app网站在线观看 | 中国一级片在线播放 | 久久9999久久免费精品国产 | 久久久久亚洲精品男人的天堂 | 精品一区二区三区久久 | 国产不卡在线视频 | 人人添人人澡人人澡人人人爽 | 国产午夜一区二区 | 成人免费观看av | 欧美一级激情 | 丰满少妇高潮在线观看 | 日韩精品在线观看视频 | www.狠狠干| 欧美亚洲国产精品久久高清浪潮 | 中文字幕在线电影 | 精品国产成人在线影院 | 日韩av在线网站 | 不卡精品视频 | 91在线www| 草在线| 色999精品 | 一区二区中文字幕在线观看 | 国产一级在线观看视频 | 亚洲精品中文字幕视频 | 综合久久精品 | 国产精品伦一区二区三区视频 | 亚洲精品久| 91精品国产成人 | 国产在线精品一区二区 | 日韩av不卡在线播放 | 国产第一页福利影院 | 97视频在线 | 又黄又爽又无遮挡的视频 | 超碰精品在线 | 国产美女黄网站免费 | 国产 字幕 制服 中文 在线 | 2019天天干天天色 | 久久99精品久久久久久三级 | 日韩中字在线 | 久久久亚洲麻豆日韩精品一区三区 | 日韩r级电影在线观看 | 国产日韩欧美视频在线观看 | 国产精品理论片在线播放 | 国产在线中文字幕 | www.大网伊人 | 日韩免费专区 | 久久精品免费电影 | 免费观看的av网站 | 成人免费观看视频大全 | 一区二区三区观看 | 96av在线视频 | 国产爽妇网 | 99激情网| 黄色毛片一级 | 国内久久视频 | 91九色视频在线 | 国产视频导航 | 亚洲成av人片在线观看无 | 中文字幕在线播放一区二区 | 国产色视频一区二区三区qq号 | 欧美日韩视频在线 | 尤物一区二区三区 | 草在线视频 | 中文字幕文字幕一区二区 | 精品国产123 | 国产精品手机播放 | 欧美老人xxxx18 | 夜色资源站国产www在线视频 | 深夜国产福利 | 色是在线视频 | 天天色天天操综合网 | 婷婷在线资源 | 日韩伦理片一区二区三区 | 欧美吞精 | 精品久久久久久久久久久久久久久久久久 | 超碰免费av | 国产日韩在线播放 | 国产精品久久电影观看 | 国产视频一区二区在线播放 | 超级碰碰碰视频 | 91成人在线观看喷潮 | 久久成人精品视频 | 91日韩免费 | 亚洲精品久久久久999中文字幕 | 精品国产乱码久久久久久久 | 天天操天天射天天爽 | 国产亚洲精品免费 | 三级黄色欧美 | 99久久影院| 中文字幕在线高清 | 毛片精品免费在线观看 | 国产一线二线三线在线观看 | 亚洲午夜精品久久久久久久久 | 最近2019年日本中文免费字幕 | 首页中文字幕 | 国产成人精品久 | 97在线公开视频 | 一区二区三区视频在线 | 久久久综合 | 黄色免费大全 | 国产精品视频区 | 久久99日韩 | 成人免费在线看片 | 亚洲国产日韩av | 97色婷婷成人综合在线观看 | 久保带人 | 国产69熟| 国产精品18久久久久久久网站 | 欧美 激情 国产 91 在线 | 美女精品国产 | 天堂黄色片 | 一区二区三区精品久久久 | 日女人电影 | av中文字幕网 | 中文av不卡| 亚洲精品免费在线播放 | 五月婷婷婷婷婷 | 在线观看一区 | 探花视频免费观看 | 欧美韩日精品 | 色黄久久久久久 | 亚洲视频综合在线 | 草久草久 | 国产精品涩涩屋www在线观看 | zzijzzij亚洲成熟少妇 | 欧美影院久久 | 欧美成人理伦片 | 在线天堂v | 91禁看片 | 99精品网站 | 黄色午夜 | 91自拍成人 | 日日夜夜骑 | 高清av免费一区中文字幕 | 欧美日bb | 久草网站 | 日韩成人邪恶影片 | 久久香蕉国产精品麻豆粉嫩av | 怡红院av | 久久人视频 | 国产亚洲精品久 | 国产精品女人久久久久久 | 色资源在线| 97超视频 | 中文字幕av在线 | 成人日韩av | 黄色毛片在线观看 | 丁香国产视频 | 国产 日韩 中文字幕 | 国产流白浆高潮在线观看 | 国产黄色av影视 | 99re热精品视频| 久久精品视频网 | 中文字幕免费在线看 | 色综合久久综合 | 久久久国产精品亚洲一区 | 色婷婷精品 | 99精品欧美一区二区 | 天天操天天射天天爽 | 精品麻豆入口免费 | 久久蜜臀一区二区三区av | 中文字幕亚洲字幕 | www.久久99 | 日本黄网站 | 天天av综合网 | 亚洲精品国产欧美在线观看 | 亚洲一区二区三区91 | 免费黄色看片 | 国产精品美女久久久久久久 | www.av在线.com| 国产精品高清在线 | 国产精品免费视频观看 | 国产精品久久久精品 | 91在线操 | 婷婷色av| 天天射天天射天天射 | 日批在线看 | 久久黄色影视 | 激情 一区二区 | 天天爽夜夜爽人人爽一区二区 | 成人免费网视频 | 日韩av在线资源 | 91专区在线观看 | 97超碰在线免费观看 | 91精品久久香蕉国产线看观看 | 91精品啪在线观看国产81旧版 | 天天摸天天舔 | 日韩免费不卡视频 | av免费在线播放 | 在线看黄色av | 91精品国产综合久久久久久久 | 中文字幕国产一区 | 人人艹视频 | 91最新中文字幕 | 天堂av色婷婷一区二区三区 | 色狠狠操| 久久免费影院 | 99久久精品免费看国产 | 91精品视频在线观看免费 | 少妇视频一区 | 在线成人欧美 | 久久综合九色欧美综合狠狠 | 久久久久久久亚洲精品 | 亚洲精品视频在线观看免费 | 一区二区 精品 | 久久视频免费观看 | 久久免费美女视频 | 久草精品视频在线看网站免费 | 成人av动漫在线 | 亚洲精品国产精品久久99 | 精品视频在线免费观看 | 99久久婷婷国产一区二区三区 | 久草国产在线 | 精品一区 在线 | 99久久综合狠狠综合久久 | 麻豆国产视频下载 | 操操操综合| 欧美日韩天堂 | 日日夜夜精品免费观看 | 午夜12点| 一区二区三区四区精品视频 | 天堂在线成人 | 亚洲精品88欧美一区二区 | 久久久精品国产一区二区三区 | 久久免费国产视频 | 日韩专区在线播放 | 99在线观看精品 | 亚洲综合欧美日韩狠狠色 | 九九精品视频在线观看 | 四季av综合网站 | 国产视频97 | 正在播放国产一区 | 免费在线一区二区三区 | 国内精品久久久久影院一蜜桃 | 成人在线观看免费视频 | 欧美一区三区四区 | 91免费版成人 | 国产精品 日韩 欧美 | 黄色亚洲 | 久草视频在线免费播放 | 欧美乱大交 | 中文字幕国产在线 | 久久久久久久久久影院 | 久久草在线精品 | 四虎国产免费 | 久久午夜羞羞影院 | 天天色天 | 在线免费观看麻豆视频 | 天天骚夜夜操 | 伊人久久国产 | 日韩欧美综合视频 | 黄色三级免费 | 国产亚洲永久域名 | 久久久久久久久福利 | 久久久久久久久久久久久久电影 | 91免费网 | 国产精品久久久久久吹潮天美传媒 | 欧美一级片免费在线观看 | 免费精品久久久 | 久久人人爽人人 | 婷婷久久久久 | 亚洲欧美日韩在线看 | 精品免费视频. | 在线免费中文字幕 | 亚洲最快最全在线视频 | 午夜久久网站 | 亚洲国产手机在线 | 最近日本字幕mv免费观看在线 | 久久婷婷色综合 | 亚洲国产欧美一区二区三区丁香婷 | 国产123av| 97福利在线 | 国产亚洲精品久久久久久久久久久久 | 97精品国产一二三产区 | 日韩中文字幕91 | 欧美激情综合网 | 黄色国产精品 | 97人人模人人爽人人喊网 | 日韩电影精品 | 四虎在线观看网址 | 激情视频二区 | 国产精品成人免费精品自在线观看 | 精品一区二区在线免费观看 | 色偷偷88888欧美精品久久久 | 一区二区 不卡 | 欧美日韩网址 | 在线免费三级 | 精品日韩中文字幕 | 91大神dom调教在线观看 | 亚洲国产中文字幕 | 综合久久久久久久 | av资源网在线播放 | 天天躁日日躁狠狠躁av麻豆 | 岛国精品一区二区 | 在线观看国产亚洲 | 天天操天天操天天 | 久久免费精品一区二区三区 | 日韩xxxbbb | 欧美日韩免费观看一区二区三区 | 久久视频国产 | 欧美日韩亚洲国产一区 | 久久久久亚洲国产 | 亚州av免费| 亚洲精品中文在线资源 | 免费色网站 | 蜜臀av性久久久久蜜臀aⅴ涩爱 | 伊人狠狠色丁香婷婷综合 | 日本美女xx | 国产中文字幕视频在线观看 | 园产精品久久久久久久7电影 | 久久激情视频免费观看 | 国产成人一级电影 | 六月丁香综合网 | 午夜av免费在线观看 | 亚洲黄色app | 国产精品av在线 | 欧美a√在线| 国产韩国精品一区二区三区 | 一级黄色片毛片 | 六月婷色| 99操视频 | 日韩精品一区二区在线观看 | 日日干夜夜操视频 | 日韩有码欧美 | 久久人人艹 | 亚洲午夜精品一区 | 少妇精品久久久一区二区免费 | 欧美日韩在线观看视频 | 久二影院 | 婷香五月| 日韩理论在线播放 | 伊甸园av在线 | 麻豆视频免费播放 | 欧美少妇xx | 一本色道久久精品 | 99久久婷婷国产精品综合 | 狠狠操狠狠插 | 香蕉影院在线 | 久久国产精彩视频 | 国产视频日韩视频欧美视频 | 久久久免费网站 | 午夜av在线免费 | 日韩专区在线观看 | av资源中文字幕 | 免费在线观看av网址 | 亚洲精品看片 | 亚洲精品视频在线看 | 日韩1页| 国产精品原创在线 | 精品免费观看 | 国内丰满少妇猛烈精品播放 | 国产四虎影院 | 国产精品成久久久久 | 欧美精品一区二区免费 | 草久草久 | 五月婷婷在线视频观看 | 日韩极品在线 | 国产精品免费不卡 | 17婷婷久久www | 欧美日韩国产免费视频 | 91传媒91久久久 | 欧美日韩国产精品一区二区 | 在线高清 | 国产精品少妇 | 最近中文字幕mv免费高清在线 | 天天干国产 | 国产小视频你懂的 | 天堂中文在线视频 | 成人av久久 | 91高清免费观看 | 天天干 夜夜操 | 日日色综合 | 国产亚洲在线观看 | 国产做aⅴ在线视频播放 | 午夜电影久久久 | av在线免费播放 | 91视频免费网址 | 在线观看色视频 | 亚洲国产成人精品在线 | 色综合久久久网 | 中文字幕色婷婷在线视频 | 欧美国产日韩一区二区 | 久久人人爽av | 成人三级网址 | 永久黄网站色视频免费观看w | 久草久草久草久草 | 中国一级片在线观看 | 午夜成人免费影院 | 日韩电影在线一区二区 | 狠狠色丁香久久婷婷综合五月 | 日韩免费在线观看视频 | 欧美日韩中文国产一区发布 | 岛国av在线免费 | 韩国中文三级 | 免费亚洲片 | 日本久久视频 | 国产亚洲精品久久久久久 | 在线观看深夜视频 | 手机看片1042 | 综合精品久久久 | 欧美在线观看禁18 | 日本久久久久 | 欧美日韩高清不卡 | 五月av在线 | 久久不卡免费视频 | 又黄又爽又无遮挡的视频 | 国产日韩精品在线观看 | 麻豆影视在线播放 | 夜夜操综合网 | 国产精品免费在线观看视频 | 狠狠干天天色 | 亚洲精品一区二区三区在线观看 | 亚洲精品网址在线观看 | 人人干人人搞 | 韩国av免费观看 | 国产一区二区久久精品 | 亚洲一级在线观看 | 国产精品久久久精品 | 久草在线免费在线观看 | 99热官网| 日日精品 | 97在线视| 国产成人一区二区三区电影 | 在线亚洲成人 | 国产精品久久嫩一区二区免费 | 天天操天天操天天干 | 不卡的av片 | 精品国产久 | 日本精品久久久一区二区三区 | 99视频久 | 99国产精品 | 久久久国产一区 | 久久婷婷色 | 黄色成年| 欧美精品一区二区三区一线天视频 | 99久久99久国产黄毛片 | av手机在线播放 | www成人精品 | 91天天操 | 久久96国产精品久久99漫画 | 亚洲精品综合久久 | 亚洲伊人网在线观看 | 国产自偷自拍 | 国产精品久久久久久久久久东京 | 久草资源在线 | 亚洲在线观看av | 高清国产午夜精品久久久久久 | 国产午夜三级一区二区三桃花影视 | 国产美女在线精品免费观看 | 国产一区在线观看免费 | 日韩黄色大片在线观看 | 国产视频在线播放 | 麻豆久久久久 | 中文字幕人成乱码在线观看 | 欧美先锋影音 | 婷婷激情5月天 | 波多野结衣久久资源 | 国产一二三区在线观看 | 国产精品一区二区无线 | 精品在线播放视频 | 天天色官网| 国产精品久久久久久久久久免费看 | 99精品国产成人一区二区 | 成人一区在线观看 | av导航福利 | 中文一二区 | 国产91九色视频 | 天天操综合网 | 国产涩涩网站 | 国产999视频 | 久久久久久久久久久久av | 日韩成人精品一区二区 | 欧美专区国产专区 | 国产xxxx | 不卡的av在线播放 | 欧美国产日韩在线观看 | 久久精品久久综合 | 久久久精品久久日韩一区综合 | 国产精品久久久久久久免费 | 国产精品亚洲视频 | 国产你懂的在线 | 四虎www| 久久成人一区二区 | 国产 在线 日韩 | 亚洲在线视频播放 | 成人午夜影院 | av中文字幕在线看 | 国产精品123| 精品亚洲欧美无人区乱码 | 五月开心婷婷 | 午夜久久久精品 | a级片久久久 | 在线成人中文字幕 | 午夜私人影院 | 久久久精品国产一区二区三区 | 欧美精品久久久久性色 | 日韩欧美高清一区二区 | 国产美女搞久久 | 国产精品一区久久久久 | 欧美精品v国产精品 | 天天狠狠干 | 国产色就色| 97国产精品久久 | 国产免费人成xvideos视频 | 久久99国产视频 | 欧美日韩精品在线一区二区 | 91污视频在线观看 | 日韩精品三区四区 | 成人福利在线播放 | 日本丰满少妇免费一区 | 免费a视频在线观看 | 在线视频欧美亚洲 | 在线日韩一区 | 日韩在线视频二区 | 国产视频亚洲精品 | av在线播放免费 | 欧美日韩免费一区 | 超薄丝袜一二三区 | 亚洲欧美国产精品va在线观看 | 97香蕉久久超级碰碰高清版 | 国产黄色大片 | 亚洲激情久久 | 色狠狠综合天天综合综合 | 日韩精品一区二区三区在线视频 | 黄色片软件网站 | 欧美日韩国产区 | 久久九九影视网 | 久久久久久久久电影 | 日韩av成人 | 最新久久免费视频 | 久艹视频在线免费观看 | 欧美视频不卡 | 色视频在线看 | 精品一二三四在线 | 日本福利视频在线 | 日日干夜夜爱 | 99久久精品免费看国产四区 | 欧美日韩免费在线观看视频 | 日韩在线视 | 91片黄在线观看动漫 | 99久久婷婷国产综合精品 | 日韩乱色精品一区二区 | 成年人在线免费看视频 | 亚洲欧美日韩精品久久奇米一区 | 91精品一区国产高清在线gif | 欧美日韩亚洲在线观看 | 亚洲国产精品成人综合 | 四虎国产精品免费观看视频优播 | 欧美国产日韩在线观看 | 日韩高清一二区 | 亚洲精品免费看 | 黄色一区三区 | 91精品在线免费观看视频 | 欧美精品久久久久性色 | 国产精品1区2区在线观看 | 日本高清免费中文字幕 | 人成午夜视频 |