精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

MySQL 派生表查詢導致 Crash 的根源分析與解決方案

數據庫 MySQL
對于復雜的 SQL 會執行復雜的 Item 變換和刪除不需要的 Item,但是正是由于這樣才更容易導致 Crash 的出現。分析類似這樣的 Crash 問題的時候,因為涉及代碼量大,代碼邏輯復雜往往很難找到相關修復代碼,因此需要對代碼運行流程比較熟悉,同時要有相關復雜問題解決的經驗才能更好的應對這類問題。?

一、問題發現

在之前的 MySQL 8.0.32 使用中,發現使用以下帶有派生表的 SQL 會導致 MySQL Crash,以下的sequence_table(2)替換為任何非常量表都行:

僅 MySQL 8.0.32 版本有影響。

EXPLAIN FORMAT=TREE 
select
    trim(ref_15.c_ogj),
    0<>0as c_lrcm63eani
from
    (select
    0<>0as c_ogj
from
   sequence_table(2) t1
where0<>0
orderby c_ogj asc) as ref_15;

Crash 的堆棧如下:

Thread 55 "mysqld" received signal SIGSEGV, Segmentation fault.
Item_view_ref::used_tables (this=0x7fff2418f410)
    at sql/item.h:6670
6670            table_map inner_map = ref_item()->used_tables(); ==> ref_item()為空指針,因此crash了
(gdb) bt
#0  Item_view_ref::used_tables (this=0x7fff2418f410)
    at sql/item.h:6670
#1  0x0000555558e978d1 in Item::const_item (this=0x7fff2418f410)
    at sql/item.h:2342
#2  0x0000555558ecc765 in Item_ref::print (this=0x7fff2418f410, thd=0x7fff24001050, 
    str=0x7fffc83ee7e0, query_type=(QT_TO_SYSTEM_CHARSET | QT_SHOW_SELECT_NUMBER))
    at sql/item.cc:9993
#3  0x000055555903b839 in Item_func_trim::print (this=0x7fff24120d20, thd=0x7fff24001050, 
    str=0x7fffc83ee7e0, query_type=(QT_TO_SYSTEM_CHARSET | QT_SHOW_SELECT_NUMBER))
    at sql/item_strfunc.cc:3244
#4  0x0000555558ea7fc5 in Item::print_item_w_name (this=0x7fff24120d20, thd=0x7fff24001050, 
    str=0x7fffc83ee7e0, query_type=(QT_TO_SYSTEM_CHARSET | QT_SHOW_SELECT_NUMBER))
    at sql/item.cc:727
#5  0x00005555593f18c0 in Query_block::print_item_list (this=0x7fff24120768, thd=0x7fff24001050, 
    str=0x7fffc83ee7e0, query_type=(QT_TO_SYSTEM_CHARSET | QT_SHOW_SELECT_NUMBER))
    at sql/sql_lex.cc:4041
#6  0x00005555593efb50 in Query_block::print_query_block (this=0x7fff24120768, 
    thd=0x7fff24001050, str=0x7fffc83ee7e0, 
    query_type=(QT_TO_SYSTEM_CHARSET | QT_SHOW_SELECT_NUMBER))
    at sql/sql_lex.cc:3614
#7  0x00005555593efa3d in Query_block::print (this=0x7fff24120768, thd=0x7fff24001050, 
    str=0x7fffc83ee7e0, query_type=(QT_TO_SYSTEM_CHARSET | QT_SHOW_SELECT_NUMBER))
    at sql/sql_lex.cc:3598
#8  0x00005555593ee556 in Query_expression::print (this=0x7fff24120670, thd=0x7fff24001050, 
    str=0x7fffc83ee7e0, query_type=(QT_TO_SYSTEM_CHARSET | QT_SHOW_SELECT_NUMBER))
    at sql/sql_lex.cc:3232
#9  0x0000555559a89c2c in print_query_for_explain (query_thd=0x7fff24001050, 
    unit=0x7fff24120670, str=0x7fffc83ee7e0)
    at sql/opt_explain.cc:2288
#10 0x0000555559a10b11 in PrintQueryPlan[abi:cxx11](THD*, THD const*, Query_expression*) (
    ethd=0x7fff24001050, query_thd=0x7fff24001050, unit=0x7fff24120670)
    at sql/join_optimizer/explain_access_path.cc:1894
#11 0x0000555559a8985a in ExplainIterator (ethd=0x7fff24001050, query_thd=0x7fff24001050, 
    unit=0x7fff24120670) at sql/opt_explain.cc:2205
#12 0x0000555559a89e91 in explain_query (explain_thd=0x7fff24001050, query_thd=0x7fff24001050, 
    unit=0x7fff24120670) at sql/opt_explain.cc:2359
#13 0x000055555955cd46 in Sql_cmd_dml::execute_inner (this=0x7fff24165630, thd=0x7fff24001050)

二、問題調查過程

調查執行 SQL 的 optimize 的過程,分析發現該 SQL 的 SQL 變換情況如下:

以下的 trim(ref_15.c_ogj) 執行完 find_order_in_list 后,Item_func_trim的args[0]->m_ref_item[0] 等于0<>0 as c_lrcm63eani,而不是0<>0 as c_ogj,這是因為c_lrcm63eani和c_ogj的名字都一樣,都是0<>0,在find_order_in_list函數里面由于名字一樣因此內層字段被外層替代了。而后在Item::clean_up_after_removal執行的時候,Item_func_ne即c_lrcm63eani因為出現了2次,因此執行了2次decrement_ref_count(),然而在Query_block::delete_unused_merged_columns函數卻把0<>0 as c_lrcm63eani的Item置為空了,因為這個時候c_lrcm63eani的item->decrement_ref_count()以后ref_count()為0因此繼續執行Item::clean_up_after_removal了。

EXPLAIN FORMAT=TREE 
select
    trim(ref_15.c_ogj),
    0<>0as c_lrcm63eani
from
    (select
    0<>0as c_ogj
from
   sequence_table(2) t1
where0<>0
orderby c_ogj asc) as ref_15;

查看函數調用過程發現 Query_block 在 prepare 的時候執行了 delete_unused_merged_columns,

-- 函數調用過程: Query_block::prepare -> Query_block::apply_local_transforms -> Query_block::delete_unused_merged_columns

bool find_order_in_list() {
  if (select_item != not_found_item) {
      if ((*order->item)->real_item() != (*select_item)->real_item()) {
        Item::Cleanup_after_removal_context ctx(
            thd->lex->current_query_block());

        (*order->item)
            ->walk(&Item::clean_up_after_removal, walk_options,  ==>Item_func_ne執行了2次,也執行了2次decrement_ref_count()
                   pointer_cast<uchar *>(&ctx));
      }
  }
}

bool Query_block::apply_local_transforms(THD *thd, bool prune) {
  DBUG_TRACE;

  assert(first_execution);
-- 這個函數把((Item_func *)&fields[0][0])->args[0]->m_ref_item[0]給刪了
  if (derived_table_count) delete_unused_merged_columns(&m_table_nest);
}

void Query_block::delete_unused_merged_columns(
    mem_root_deque<Table_ref *> *tables) {
  DBUG_TRACE;

  for (Table_ref *tl : *tables) {
    if (tl->nested_join == nullptr) continue;
    if (tl->is_merged()) {
      for (Field_translator *transl = tl->field_translation;
           transl < tl->field_translation_end; transl++) {
        Item *const item = transl->item;
        // Decrement the ref count as its no more used in
        // select list.
        if (item->decrement_ref_count()) continue; -- 因為執行完decrement_ref_count()以后返回的m_ref_count=0因此不會跳出這個循環

        // Cleanup the item since its not referenced from
        // anywhere.
        assert(item->fixed);
        Item::Cleanup_after_removal_context ctx(this);
        item->walk(&Item::clean_up_after_removal, walk_options,
                   pointer_cast<uchar *>(&ctx));
        transl->item = nullptr; -- 這個地方把Item_view_ref引用的Item_func_ne對象置為空了,即把trim函數參數的c_lrcm63eani列刪除了
      }
    }
    delete_unused_merged_columns(&tl->nested_join->m_tables);
  }
}

三、解決方案

通過上面的分析,我們可以發現問題在于多執行了一次Item::clean_up_after_removal,隨后在 MySQL 最新代碼嘗試執行以上 SQL 發現該 BUG 已經被修復,找到相關修復代碼,可以發現以下修復代碼。

相關commit ID號為: 2171a1260e2cdbbd379646be8ff6413a92fd48f4

-- 相關修復代碼如下:
@@ -7575,7 +7865,6 @@ bool Item::clean_up_after_removal(uchar *arg) {
 
   if (reference_count() > 1) {
     (void)decrement_ref_count();
+    ctx->stop_at(this);
   }
   return false;
 }

修改完查看一下這個函數的堆棧信息:

#0  Item::clean_up_after_removal (this=0x2, 
    arg=0x41 <error: Cannot access memory at address 0x41>)
    at sql/item.cc:9236
#1  0x0000555558fea5a8 in Item::walk (this=0x7fff2c338db8, processor=&virtual table offset 864, 
    walk=7, arg=0x7fffc83ee4b0 "") at sql/item.h:2543
#2  0x00005555596cc6f2 in find_order_in_list(thd=0x7fff2c001070, ref_item_array=..., 
    tables=0x7fff2c330b90, order=0x7fff2c32eae8, fields=0x7fff2c32fb20, is_group_field=false, 
    is_window_order=false) at sql/sql_resolver.cc:4625
#3  0x00005555596cd0ae in setup_order(thd=0x7fff2c001070, ref_item_array=..., 
    tables=0x7fff2c330b90, fields=0x7fff2c32fb20, order=0x7fff2c32eae8)
    at sql/sql_resolver.cc:4811
#4  0x00005555596bf528 in Query_block::prepare(this=0x7fff2c32fae0, thd=0x7fff2c001070, 
    insert_field_list=0x0) at sql/sql_resolver.cc:400
#5  0x00005555597d035d in Query_expression::prepare(this=0x7fff2c32f9e8, thd=0x7fff2c001070, 
    sel_result=0x7fff2c33b2a8, insert_field_list=0x0, added_options=0, removed_options=0)
    at sql/sql_union.cc:758
#6  0x0000555559590772 in Table_ref::resolve_derived(this=0x7fff2c339790, thd=0x7fff2c001070, 
    apply_semijoin=true) at sql/sql_derived.cc:451
#7  0x00005555596c2a80 in Query_block::resolve_placeholder_tables(this=0x7fff2c333f08, 
    thd=0x7fff2c001070, apply_semijoin=true)
    at sql/sql_resolver.cc:1408
#8  0x00005555596bea62 in Query_block::prepare(this=0x7fff2c333f08, thd=0x7fff2c001070, 
    insert_field_list=0x0) at sql/sql_resolver.cc:265

對于0<>0 as c_lrcm63eani這個Item_func_ne對象,執行到Item::clean_up_after_removal的時候,因為reference_count() > 1因此會執行新添加的ctx->stop_at(this),等到下一次再執行到這個Item_func_ne的clean_up_after_removal()函數的時候,就會因為ctx->is_stopped(this)而直接返回,不再執行一次decrement_ref_count(),從而避免了執行后面的transl->item = nullptr。

bool find_order_in_list() {
if (select_item != not_found_item) {
      if ((*order->item)->real_item() != (*select_item)->real_item()) {
        Item::Cleanup_after_removal_context ctx(
            thd->lex->current_query_block());

        (*order->item)
            ->walk(&Item::clean_up_after_removal, walk_options,  -- Item_func_ne執行了2次,而只執行了一次decrement_ref_count()
                   pointer_cast<uchar *>(&ctx));
      }
  }
}

void Query_block::delete_unused_merged_columns(
    mem_root_deque<Table_ref *> *tables) {
  DBUG_TRACE;

for (Table_ref *tl : *tables) {
    if (tl->nested_join == nullptr) continue;
    if (tl->is_merged()) {
      for (Field_translator *transl = tl->field_translation;
           transl < tl->field_translation_end; transl++) {
        Item *const item = transl->item;
        // Decrement the ref count as its no more used in
        // select list.
        if (item->decrement_ref_count()) continue; 因為執行完decrement_ref_count()以后返回的m_ref_count=1因此不會繼續執行后面的置空設置

        // Cleanup the item since its not referenced from
        // anywhere.
        assert(item->fixed);
        Item::Cleanup_after_removal_context ctx(this);
        item->walk(&Item::clean_up_after_removal, walk_options,
                   pointer_cast<uchar *>(&ctx));
        transl->item = nullptr; ==>這個地方不會運行到
      }
    }
    delete_unused_merged_columns(&tl->nested_join->m_tables);
  }
}

四、問題總結

通過以上分析我們可以發現,對于復雜的 SQL 會執行復雜的 Item 變換和刪除不需要的 Item,但是正是由于這樣才更容易導致 Crash 的出現。分析類似這樣的 Crash 問題的時候,因為涉及代碼量大,代碼邏輯復雜往往很難找到相關修復代碼,因此需要對代碼運行流程比較熟悉,同時要有相關復雜問題解決的經驗才能更好的應對這類問題。

責任編輯:武曉燕 來源: GreatSQL社區
相關推薦

2013-05-14 15:47:27

MySQL監控錯誤日志

2010-04-28 11:48:13

Oracle MySQ

2016-02-24 11:25:43

DevOps運維

2025-02-04 12:05:10

2020-09-09 10:00:41

JavaScript前端瓶頸

2017-02-15 09:40:38

JavaScript分析解決

2024-06-12 12:59:16

2017-08-01 17:01:49

IOT梯聯網AWS

2012-01-04 11:05:24

2010-05-17 09:49:46

MySQL中文問題

2011-07-18 09:36:42

Mysql數據庫root@localh

2010-08-06 13:40:06

DB2建立nickna

2010-07-30 13:21:21

2011-08-11 18:38:05

Oracle回滾段

2012-02-07 17:33:07

2010-05-28 19:39:28

MySQL 編碼轉換

2017-06-05 16:16:11

技術業務性

2010-05-28 13:04:04

MySQL root

2010-01-06 09:37:06

華為交換機故障

2010-06-07 09:22:21

MySQL+PHP亂碼
點贊
收藏

51CTO技術棧公眾號

av毛片午夜不卡高**水| 亚洲AV无码精品色毛片浪潮| japanese国产精品| 欧美午夜电影网| 懂色av粉嫩av蜜臀av| 欧美 日韩 国产 成人 在线| 久久青草久久| 久久这里只有精品99| 日本一区二区免费视频| 国产日韩电影| 亚洲欧美日韩国产综合在线| 国产精品一区二区三区观看| 亚洲欧美另类在线视频| 亚洲综合中文| 亚洲男人第一av网站| 91国内在线播放| 第一中文字幕在线| 国产精品素人一区二区| 国产精品区免费视频| 一级黄色在线观看| 国产一区日韩一区| 国产一区二区日韩精品欧美精品| 天天色天天干天天色| 性欧美hd调教| 亚洲国产美国国产综合一区二区 | 精品国产导航| 欧美浪妇xxxx高跟鞋交| 国产女大学生av| av网址在线| 欧美高清在线一区二区| 久久精品国产一区二区三区不卡| 国产精品特级毛片一区二区三区| 一区二区日本视频| 欧美多人爱爱视频网站| 国产日产精品一区二区三区的介绍| 女仆av观看一区| 日韩三级av在线播放| 在线观看日本一区二区| 亚洲国产福利| 亚洲不卡一区二区三区| 91免费网站视频| 色网站免费在线观看| 国产亚洲欧美日韩俺去了| 国产精品免费一区二区三区在线观看 | 热久久免费视频精品| 国产一级二级三级| 欧美成人自拍| 日韩中文第一页| 国产精品国产三级国产专业不| 欧美三级电影在线| 亚洲аv电影天堂网| 一区二区在线免费观看视频| 成人豆花视频| 91精品在线观看入口| 黄色小视频免费网站| 九七电影院97理论片久久tvb| 色先锋aa成人| 欧美成人免费高清视频| 欧美成人免费电影| 一本一道久久a久久精品综合蜜臀| 精品久久久久久久久久中文字幕| 国产经典三级在线| 亚洲国产精品久久久男人的天堂| 人人妻人人澡人人爽欧美一区 | 91精品国产高清| 日韩欧美性视频| 国产精品嫩草99av在线| 欧洲成人免费视频| 日日夜夜狠狠操| 日日夜夜精品视频免费| 国产精品久久久久9999| 888奇米影视| 精品一区二区三区免费视频| 91免费精品视频| 午夜免费福利视频| 福利一区二区在线观看| 精品国产乱码久久久久久108| 深夜福利在线看| 国产亚洲美州欧州综合国| 色一情一区二区三区四区| 在线免费看黄网站| 亚洲免费观看高清在线观看| 欧美一区二区激情| 欧美日韩美女| 69p69国产精品| 折磨小男生性器羞耻的故事| 欧美日日夜夜| www.日韩不卡电影av| 青春草免费视频| 国产午夜精品一区二区三区欧美| 国产精品成人一区| 99热这里精品| 91免费视频大全| 亚洲精品中文字幕乱码三区不卡| 二区三区在线观看| 欧美日韩国产精品一区二区三区四区 | 伊人影院久久| 欧美专区在线播放| 国产精品久久777777换脸| 成人v精品蜜桃久久一区| 欧美日韩国产不卡在线看| 午夜在线播放| 婷婷开心久久网| 国产无色aaa| 亚洲欧洲av| 久热在线中文字幕色999舞| 日韩欧美激情视频| 精品一区二区三区免费| 蜜桃传媒视频麻豆第一区免费观看 | 亚洲日本精品| 黄毛片在线观看| 欧美丰满嫩嫩电影| aa一级黄色片| 欧美日韩1080p| 国产精品久久久久久av| 亚洲免费成人网| 国产精品青草综合久久久久99| 妞干网在线观看视频| 欧美成人高清视频在线观看| 精品视频久久久久久久| 日本青青草视频| 日本亚洲三级在线| 久久综合一区| 国产亚av手机在线观看| 日韩亚洲欧美高清| 国产又黄又粗又猛又爽的| 亚洲欧美日韩一区在线观看| 成人在线观看91| 国产美女av在线| 欧美日产国产精品| 亚洲黄色免费视频| av不卡在线| 国产日韩久久| 在线观看a级片| 666欧美在线视频| 久久视频一区二区三区| 久久久蜜桃一区二区人| 韩国成人一区| cao在线视频| 精品国产免费人成电影在线观看四季| 亚洲精品国产精品乱码在线观看| 奇米888四色在线精品| 久久96国产精品久久99软件| 成人影音在线| 亚洲第一福利在线观看| 久久精品人妻一区二区三区| 国产成人午夜高潮毛片| 国产精品h视频| 99热这里有精品| 上原亚衣av一区二区三区| 日韩不卡高清视频| 国产色91在线| 黄色手机在线视频| 日韩久久久久| 国产在线观看不卡| 国产成人l区| 日韩一区二区在线看| 妺妺窝人体色www聚色窝仙踪 | 18成人在线| 亚洲欧美成人影院| 欧美大片拔萝卜| 久久精品久久国产| 91亚洲国产成人精品一区二区三 | 日韩欧美中文字幕制服| 在线观看成人毛片| 国产91精品欧美| 91免费黄视频| 美女久久久久| 国产精品三级网站| 最新国产在线拍揄自揄视频| 日韩精品资源二区在线| 日产精品久久久久久久| 久久婷婷久久一区二区三区| 国产精品亚洲二区在线观看 | 一本大道亚洲视频| 中文字幕日韩国产| 亚洲欧洲综合另类在线| 久久精品aⅴ无码中文字字幕重口| 精品动漫3d一区二区三区免费版 | 国产综合无码一区二区色蜜蜜| 亚洲1区2区3区4区| 少妇精品无码一区二区免费视频| 男男视频亚洲欧美| 久久人妻无码一区二区| 欧美国产极品| 国产精品自拍网| 色呦呦久久久| 亚洲片在线资源| 国产又粗又大又爽视频| 亚洲午夜激情av| 极品久久久久久久| 国产高清无密码一区二区三区| 日韩欧美国产综合在线| 欧美亚洲高清| 国产成人精品一区二区三区福利 | www.com日本| 老司机亚洲精品| 91传媒免费视频| 亚洲人成亚洲精品| 91青青草免费在线看| 日韩伦理三区| 欧美激情在线观看视频| 二人午夜免费观看在线视频| 欧美不卡在线视频| 自拍偷拍第八页| 亚洲第一福利视频在线| 精品在线观看一区| 久久午夜老司机| av不卡中文字幕| 久久一级大片| 亚洲r级在线视频| 成人网站免费观看| 国产一区福利在线| av丝袜天堂网| 亚洲看片免费| 欧美另类videos| 精品视频黄色| 国产一区二区三区四区hd| 欧美aaa级| 日本亚洲欧美三级| 538视频在线| 欧美尺度大的性做爰视频| 国产在线视频网站| 欧美精品一区二区蜜臀亚洲| 国产美女自慰在线观看| 欧美性三三影院| 国产精品久久久久久人| 亚洲成人动漫av| 精品爆乳一区二区三区无码av| 国产精品久久夜| 中文字幕av网址| av激情亚洲男人天堂| 少妇极品熟妇人妻无码| 国内精品自线一区二区三区视频| wwwwxxxx日韩| 老司机午夜精品视频| jizzjizzxxxx| 国产一区白浆| 国产视频九色蝌蚪| 亚洲国产午夜| 岛国大片在线播放| 狠狠88综合久久久久综合网| 男人日女人的bb| 中文一区一区三区免费在线观看| 中文精品一区二区三区| 精品久久久久久久| 日本最新一区二区三区视频观看| 久久99国产精品视频| 欧美大陆一区二区| 天天久久夜夜| 免费一区二区三区| 群体交乱之放荡娇妻一区二区| 国产视频99| 日韩在线影视| 欧洲av一区| 欧美日韩一二三四| 亚洲精品日韩成人| 99久久夜色精品国产亚洲1000部| 亚洲精品日韩在线观看| 久久精品影视| 青青在线视频免费观看| 韩国av一区| 男人天堂999| 日韩国产欧美在线观看| 日本xxxx黄色| 国产一区二区电影| 国内精品免费视频| 久久亚洲捆绑美女| 手机毛片在线观看| 亚洲日本va午夜在线影院| 欧美日韩大片在线观看| 欧美日韩精品国产| 欧美三级网站在线观看| 欧美片在线播放| 超碰在线观看av| 国产视频精品xxxx| 免费看美女视频在线网站| 欧美国产第一页| 欧美艳星kaydenkross| 国产日产久久高清欧美一区| 欧美日本三级| 鲁丝片一区二区三区| 久久在线电影| 久草视频这里只有精品| 欧美专区18| 99九九精品视频| 99精品国产热久久91蜜凸| a级片在线观看| 亚洲天堂中文字幕| 欧美一区二区三区四| 欧美日韩精品免费观看视频| 国产成人精品a视频| 日韩精品中文在线观看| 日本免费视频在线观看| 久久免费精品视频| 成人在线免费av| 国产精品久久国产精品| 日韩黄色大片网站| 久久国产精品网| 免费久久99精品国产| 91精品又粗又猛又爽| 欧美国产日韩亚洲一区| 麻豆国产尤物av尤物在线观看| 欧美性猛交xxx| 国产免费黄色网址| 亚洲欧美日韩一区二区三区在线| 91精品久久| 国产精品视频精品视频| 久久a爱视频| 国产精品久久久影院| 久久只有精品| 成年人小视频在线观看| 国产精品久久久久久久久快鸭 | 国产精品成久久久久| 六月丁香激情网| 国产98色在线|日韩| 林心如三级全黄裸体| 欧美三级欧美成人高清www| 国内精品国产成人国产三级| 一区二区三区久久精品| 日韩伦理精品| 国产一区免费观看| 中文乱码免费一区二区三区下载| 成人午夜激情av| 26uuu亚洲| 国产精品suv一区二区| 91精品婷婷国产综合久久| 国产一级在线| 欧美一级免费视频| 欧美电影在线观看免费| www.好吊操| 国产成人鲁色资源国产91色综| 美国一级片在线观看| 欧美日韩在线播放三区| 免费在线看v| 欧洲一区二区视频| 欧美交a欧美精品喷水| 水蜜桃色314在线观看| 大桥未久av一区二区三区中文| 青娱乐国产在线视频| 91精品在线麻豆| 18+激情视频在线| 亚洲xxxx3d| 欧美在线1区| 色哟哟免费视频| 樱桃视频在线观看一区| 精品国产伦一区二区三区| 欧美裸体男粗大视频在线观看| 国产精品美女久久久久| www.午夜色| 国产一区日韩二区欧美三区| 日韩影院一区二区| 欧美一区二区在线播放| www在线视频| 国产福利久久精品| 99精品国产99久久久久久福利| av天堂一区二区| 黑人巨大精品欧美一区二区一视频 | 91麻豆精品国产91久久久更新时间 | 视色,视色影院,视色影库,视色网 日韩精品福利片午夜免费观看 | 伊人久久成人网| 日韩在线观看免费高清完整版| 台湾天天综合人成在线| 一区二区三区四区免费观看| 国产精品一级黄| 久久草视频在线| 亚洲欧美成人一区二区在线电影| 欧美大片免费| 亚洲欧美日韩精品综合在线观看| 开心九九激情九九欧美日韩精美视频电影 | 伊人久久国产精品| 欧美xxxx18国产| 国产一区在线电影| 美女福利视频在线| 国产精品系列在线| 精品国产999久久久免费| 欧美激情免费观看| 少妇精品久久久一区二区三区| 鲁一鲁一鲁一鲁一av| 自拍偷拍国产亚洲| 五月激情婷婷网| 国产精品爽黄69| 欧美精品成人| 亚洲第一成人网站| 欧美夫妻性生活| 在线观看网站免费入口在线观看国内| 欧美亚洲国产免费| 国内精品免费在线观看| 国产乡下妇女做爰视频| 亚洲人成五月天| 99精品国产九九国产精品| www.浪潮av.com| 国产精品久久久一区麻豆最新章节| 精品人妻一区二区三区三区四区| 2021国产精品视频| 亚洲情侣在线| 干b视频在线观看| 日韩欧美激情四射| 日韩欧美精品电影| 日韩精品一区二区免费|