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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL · 特性分析 · 优化器 MRR BKA

發布時間:2025/3/21 数据库 50 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL · 特性分析 · 优化器 MRR BKA 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

什么是 MRR

MRR 的全稱是 Multi-Range Read Optimization,是優化器將隨機 IO 轉化為順序 IO 以降低查詢過程中 IO 開銷的一種手段,咱們對比一下 mrr=on & mrr=off 時的執行計劃:

其中表結構如下:

mysql> show create table t1\G *************************** 1. row ***************************Table: t1 Create Table: CREATE TABLE `t1` (`id` int(11) NOT NULL AUTO_INCREMENT,`a` int(11) DEFAULT NULL,`b` int(11) DEFAULT NULL,`c` int(11) DEFAULT NULL,PRIMARY KEY (`id`),KEY `mrrx` (`a`,`b`),KEY `xx` (`c`) ) ENGINE=MyISAM AUTO_INCREMENT=11 DEFAULT CHARSET=latin1 1 row in set (0.00 sec)

操作如下:

mysql> set optimizer_switch='mrr=off'; Query OK, 0 rows affected (0.00 sec)mysql> explain select * from test.t1 where (a between 1 and 10) and (c between 9 and 10) ; +----+-------------+-------+-------+---------------+------+---------+------+------+------------------------------------+ | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra | +----+-------------+-------+-------+---------------+------+---------+------+------+------------------------------------+ | 1 | SIMPLE | t1 | range | mrrx,xx | xx | 5 | NULL | 2 | Using index condition; Using where | +----+-------------+-------+-------+---------------+------+---------+------+------+------------------------------------+ 1 row in set (0.00 sec)

當把 MRR 關掉的情況下,執行計劃使用的是索引 xx(c),即從索引 xx 上讀取一條數據后回表,取回該主鍵的完整數據,當數據較多且比較分散的情況下會有比較多的隨機 IO, 導致性能低下,我們將 MRR 打開,執行以下操作:

mysql> set optimizer_switch='mrr=on'; Query OK, 0 rows affected (0.00 sec)mysql> explain select * from test.t1 where (a between 1 and 10) and (c between 9 and 10) ; +----+-------------+-------+-------+---------------+------+---------+------+------+-----------------------------------------------+ | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra | +----+-------------+-------+-------+---------------+------+---------+------+------+-----------------------------------------------+ | 1 | SIMPLE | t1 | range | mrrx,xx | xx | 5 | NULL | 2 | Using index condition; Using where; Using MRR | +----+-------------+-------+-------+---------------+------+---------+------+------+-----------------------------------------------+ 1 row in set (0.00 sec)

可以看到 extra 的輸出中多了 “Using MRR” 信息,即使用了 MRR Optimization IO 層面進行了優化,減少 IO 方面的開銷,更詳細的說明可以參考這里。

MRR 原理

在不使用 MRR 時,優化器需要根據二級索引返回的記錄來進行“回表”,這個過程一般會有較多的隨機 IO, 使用 MRR 時,SQL 語句的執行過程是這樣的:

  • 優化器將二級索引查詢到的記錄放到一塊緩沖區中;
  • 如果二級索引掃描到文件的末尾或者緩沖區已滿,則使用快速排序對緩沖區中的內容按照主鍵進行排序;
  • 用戶線程調用 MRR 接口取 cluster index,然后根據cluster index 取行數據;
  • 當根據緩沖區中的 cluster index 取完數據,則繼續調用過程 2) 3),直至掃描結束;

通過上述過程,優化器將二級索引隨機的 IO 進行排序,轉化為主鍵的有序排列,從而實現了隨機 IO 到順序 IO 的轉化,提升性能。

MRR 源碼分析

首先,咱們來看一下 mrr 相對應的內存結構:

class DsMrr_impl {...handler *h;TABLE *table; /* Always equal to h->table */ private:/* Secondary handler object. It is used for scanning the index */handler *h2;/* Buffer to store rowids, or (rowid, range_id) pairs */uchar *rowids_buf;uchar *rowids_buf_cur; /* Current position when reading/writing */uchar *rowids_buf_last; /* When reading: end of used buffer space */uchar *rowids_buf_end; /* End of the buffer */bool dsmrr_eof; /* TRUE <=> We have reached EOF when reading index tuples */int dsmrr_init(handler *h, RANGE_SEQ_IF *seq_funcs, void *seq_init_param,uint n_ranges, uint mode, HANDLER_BUFFER *buf);….int dsmrr_fill_buffer();int dsmrr_next(char **range_info);bool get_disk_sweep_mrr_cost(uint keynr, ha_rows rows, uint flags, uint *buffer_size, Cost_estimate *cost);…. }

簡單說明:h2 指的是 MRR 使用的 second index 或主鍵索引, h 是指利用 h2 返回的主建來查詢的句柄,rowids_buf 是 MRR 執行過程中存儲有序主鍵的緩存區,大小由 MySQL 的變量?read_rnd_buffer_size?設置,下面我們結合程序的執行過程來看一下源碼。

  • MRR 中有序主建的收集過程
    優化器對查詢語句的條件進行分析并選擇合適的二級索引,并對二級索引的條件進行篩選拼裝成 DYNAMIC_ARRAY ranges,在執行的時候將 ranges 傳入初始化函數?ha_myisam::multi_range_read_init?,繼而會調用?dsmrr_fill_buffer?函數,在dsmrr_fill_buffer中會使用二級索引的句柄查找符合 ranges 的數據并添加至 rowids_buf 中,在掃描結束或緩沖區滿的時候會對 rowids_buf 進行快速排序,詳細過程可以參考函數:dsmrr_fill_buffer,其調用堆棧如下:

    #0 DsMrr_impl::dsmrr_fill_buffer (this=0x2aab0000cf00)#1 0x00000000006e49dd in DsMrr_impl::dsmrr_init(...)#2 0x00000000017d35e4 in ha_myisam::multi_range_read_init(...)#3 0x0000000000d134c6 in QUICK_RANGE_SELECT::reset (this=0x2aab00014070)#4 0x00000000009a266f in join_init_read_record (tab=0x2aab0000f5b8)#5 0x000000000099d6d4 in sub_select#6 0x000000000099c914 in do_select (join=0x2aab000064b0)#7 0x00000000009982f8 in JOIN::exec (this=0x2aab000064b0)#8 0x0000000000a5bd7c in mysql_execute_select........
  • MRR 中主建緩沖區的使用過程

    物理執行階段,調用?ha_myisam::multi_range_read_next,在使用 MRR 的情況下會從過程1)中收集的有序主建的緩沖區取主建,然后再調用引擎層的 rnd_pos 直接找到數據,其中使用 mrr 的調用堆棧如下:

    #0 DsMrr_impl::dsmrr_next (this=0x2aab0000cf00, range_info=0x2aaafc03de70)#1 0x00000000017d3634 in ha_myisam::multi_range_read_next (this=0x2aab0000ca40, range_info=0x2aaafc03de70)#2 0x0000000000d138cc in QUICK_RANGE_SELECT::get_next (this=0x2aab00014070)#3 0x0000000000d46908 in rr_quick (info=0x2aab0000f648)#4 0x00000000009a2791 in join_init_read_record (tab=0x2aab0000f5b8)#5 0x000000000099d6d4 in sub_select (join=0x2aab000064b0, join_tab=0x2aab0000f5b8, end_of_records=false)#6 0x000000000099c914 in do_select (join=0x2aab000064b0)

    二緩索引(h2)& 主建索引(h) 的協同是通過rowids_buf_cur來進行的。最初的初始化過程中,h2 會首先將數據填沖到 rowids_buf 中,如果發現緩沖區中的數據已經取完,則會繼續調用?dsmrr_fill_buffer?往 rowids_buf 填主鍵并進行排序,如此反復,直至 h2 掃描至文件末尾,詳情可以參考函數?DsMrr_impl::dsmrr_next。

  • 通過上面的分析,是不是感覺 MRR 有點像二級索引與主鍵的 join 操作,那就是有點和 BKA 有些類似的概念了,咱們下面看一下 BKA 是如何實現的。

    BKA 原理

    BKA 是指在表連接的過程中為了提升 join 性能而使用的一種 join buffer,其作用是在讀取被 join 表的記錄的時候使用順序 IO,BKA 被使用的標識是執行計劃的 extra 信息中會有 “Batched Key Access” 信息, 我們首先看一個例子:

    DROP TABLE t1, t2; CREATE TABLE t1 (a int PRIMARY KEY, b int); CREATE TABLE t2 (a int PRIMARY KEY, b int); INSERT INTO t1 VALUES (1,2), (2,1), (3,2), (4,3), (5,6), (6,5), (7,8), (8,7), (9,10); INSERT INTO t2 VALUES (3,0), (4,1), (6,4), (7,5);mysql> set optimizer_switch="mrr=on,mrr_cost_based=off,batched_key_access=on"; mysql> explain SELECT * FROM t1 LEFT JOIN t2 ON t1.a = t2.a WHERE t2.b <= t1.a AND t1.a <= t1.b; +----+-------------+-------+--------+---------------+---------+---------+-----------+------+-----------------------------------------------------+ | id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra | +----+-------------+-------+--------+---------------+---------+---------+-----------+------+-----------------------------------------------------+ | 1 | SIMPLE | t2 | ALL | PRIMARY | NULL | NULL | NULL | 4 | Using where | | 1 | SIMPLE | t1 | eq_ref | PRIMARY | PRIMARY | 4 | test.t2.a | 1 | Using where; Using join buffer (Batched Key Access) | +----+-------------+-------+--------+---------------+---------+---------+-----------+------+-----------------------------------------------------+ 2 rows in set (0.00 sec)

    從以上的例子中我們可以看到,在讀取表 t1 的時候使用了帶 BKA 功能的 join buffer, 其中 BKA & join buffer 的關系與實現我們放在后面詳解。

    BKA & MRR 之間的關系

    使用 BKA 的表的 JOIN 過程如下:

  • 連接表將滿足條件的記錄放入JOIN_CACHE,并將兩表連接的字段放入一個 DYNAMIC_ARRAY ranges 中,此過程類似于 MRR 操作的過程,且在內存中使用的是同樣的結構體 DsMrr_impl;
  • 在進行表的過接過程中,會將 ranges 相關的信息傳入?DsMrr_impl::dsmrr_fill_buffer,并進行被連接表主建的查找及排序等操作操作,這個過程比較復雜,包括需要判斷使用的 key、key 是主建時的特殊操作等;
  • JOIN_CACHE_BKA::join_matching_records?會調用過程2中產生的有序主建,然后順序讀取數據并進入下一步的操作(evaluate_join_record?等);
  • 當緩沖區的數據被讀完后,會重復進行過程2,3, 直到記錄被讀取完。
  • 由上面的分析可以看出,BKA將有序主建投遞到存儲引擎是通過 MRR 的接口的調用來實現的(DsMrr_impl::dsmrr_next),所以BKA 依賴 MRR,如果要使用BKA, MRR 是需要打開的,另外?batched_key_access?是默認關閉的,如果要使用,需要打開此選項。
    BKA 的詳細說明可參考這里。

    BKA 源碼實現

    表之間的連接操作是通過 JOIN_CACHE 來做的,5.6 目前實現了 BNL, BKA (JOIN_CACHE_BKA & JOIN_CACHE_BKA_UNIQUE) 兩種表連接的優化方式,其中 BKA 就是其中減少隨機 IO 的一種方式,BKA內存中對應的結構是 JOIN_CACHE_BKA,咱們首先看一下多表 JOIN 之間的過程;

  • 優化器生成的執行計劃是由一個 JOIN_TAB 的左支樹組成,每個 JOIN_TAB 包含了相關的表、使用的索引、語句中包含的條件等信息;
  • 進入物理執行計劃后,會對每一個表進行讀數據,然后進入?evaluate_join_record, 當發現滿足條件的記錄時,則會將該記錄添加到下一個JOIN_TAB 中的JOIN_CACHE 中,其堆棧如下:

    #0 JOIN_CACHE::put_record (this=0x2aab00019d20)#1 0x000000000099d29c in sub_select_op (join=0x2aab00016268, join_tab=0x2aab00018ed8, end_of_records=false)#2 0x000000000099ee1c in evaluate_join_record (join=0x2aab00016268, join_tab=0x2aab00018bd8)#3 0x000000000099d984 in sub_select (join=0x2aab00016268, join_tab=0x2aab00018bd8, end_of_records=false)#4 0x000000000099c914 in do_select (join=0x2aab00016268)#5 0x00000000009982f8 in JOIN::exec (this=0x2aab00016268)#6 0x0000000000a5bd7c in mysql_execute_select (thd=0x314d690, select_lex=0x31503a8, free_join=true)
  • 當緩沖區滿或者讀到文件的末尾時,會調用下一個JOIN_TAB 中?JOIN_CACHE::join_records?方法(BKA 使用時 JOIN_CACHE 為 JOIN_CACHE_BKA),然后會進入 MRR 的相關邏輯,其完整的堆棧為:

    #0 DsMrr_impl::dsmrr_fill_buffer (this=0x2aab000128e0)#1 0x00000000006e49dd in DsMrr_impl::dsmrr_init#2 0x00000000017d35e4 in ha_myisam::multi_range_read_init#3 0x0000000000d838aa in JOIN_CACHE_BKA::init_join_matching_records (this=0x2aab00019d20, seq_funcs=0x2aaafc03dd80, ranges=4)#4 0x0000000000d8335c in JOIN_CACHE_BKA::join_matching_records (this=0x2aab00019d20, skip_last=false)#5 0x0000000000d812e8 in JOIN_CACHE::join_records (this=0x2aab00019d20, skip_last=false)#6 0x0000000000d86ed3 in JOIN_CACHE::end_send (this=0x2aab00019d20)#7 0x000000000099d0d1 in sub_select_op (join=0x2aab00016268, join_tab=0x2aab00018ed8, end_of_records=true)#8 0x000000000099d3c4 in sub_select (join=0x2aab00016268, join_tab=0x2aab00018bd8, end_of_records=true) at#9 0x000000000099c97d in do_select (join=0x2aab00016268)#10 0x00000000009982f8 in JOIN::exec (this=0x2aab00016268)#11 0x0000000000a5bd7c in mysql_execute_select
  • dsmrr_fill_buffer?的過程相對復雜,需要首先取出兩表相連接的字段的索引,如果沒有索引,則會使用主建并直接讀取,如果使用了索引,則需要從上一個JOIN_TAB中將索引的信息讀出來并從 join_cache 的 buffer 中取出該索引的數據,然后再進行回表,查找主建、排序等操作,其堆棧如下:

    #0 JOIN_CACHE_BKA::get_next_key (this=0x2aab00019d20, key=0x2aab0001e178)#1 0x0000000000d82f83 in bka_range_seq_next (rseq=0x2aab00019d20, range=0x2aab0001e178)#2 0x00000000006e3cac in handler::multi_range_read_next (this=0x2aab0001e020, range_info=0x2aaafc03dc10)#3 0x00000000006e5466 in DsMrr_impl::dsmrr_fill_buffer (this=0x2aab000128e0)#4 0x00000000006e49dd in DsMrr_impl::dsmrr_init (…)#5 0x00000000017d35e4 in ha_myisam::multi_range_read_init (…)#6 0x0000000000d838aa in JOIN_CACHE_BKA::init_join_matching_records (this=0x2aab00019d20, seq_funcs=0x2aaafc03dd80, ranges=4)
  • 此過程只是兩個表的使用 BKA 時的過程,當是多表時,過程將更為復雜。

    小結

    本篇文章中我們詳細的介紹了 MRR、BKA 以及 MRR & BKA 之間的關系等內容,測試用例都是在mrr_cost_based=OFF 的情況下進行的,因為SQL 語句是否使用 MRR 優化依賴于其代價的大小,優化器的代價計算是一個比較復雜的過程,無論是 MRR 還是 BKA 都只是優化器進行優化的方法,當其發現優化后的代價過高時就會不使用該項優化,因此在使用 MRR 相關的優化時,盡量設置 mrr_cost_based=ON,畢竟大多數情況下優化器是對的。

    總結

    以上是生活随笔為你收集整理的MySQL · 特性分析 · 优化器 MRR BKA的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    久草网首页 | 天天干天天干天天 | www视频免费在线观看 | 亚洲精品777 | 九九热在线播放 | 久久久久久久久久久久av | 欧美精品亚洲精品日韩精品 | 激情五月激情综合网 | 91九色最新| 天天干,天天草 | 精品在线视频播放 | 中文av资源站 | 国产免费大片 | 天天色播 | 在线观看中文字幕 | 国产综合视频在线观看 | 又爽又黄又无遮挡网站动态图 | 九九视频免费观看视频精品 | 亚洲一区网| 91视频com| 中国一区二区视频 | 欧美性久久久 | 欧美黑人猛交 | 97av在线视频| 91丨九色丨高潮 | av福利超碰网站 | 蜜臀av夜夜澡人人爽人人 | 99爱精品在线 | 免费看黄电影 | 久久综合影音 | 91麻豆精品 | 成人午夜黄色影院 | 在线国产日韩 | 国产在线观看午夜 | 精品999国产| 奇米7777狠狠狠琪琪视频 | 日韩精品一区二区免费视频 | 亚洲黄色免费在线 | 国产粉嫩在线观看 | 国产九九精品视频 | 五月天激情综合网 | 国产专区在线播放 | 久久艹国产视频 | 亚洲 成人 欧美 | 亚州人成在线播放 | 国内久久精品 | 中文久草 | 国产精品久久久久国产精品日日 | 久久久精品久久 | 成人黄色电影在线观看 | www久久99| 久久久精品欧美一区二区免费 | 精品国产电影一区二区 | 久久久国产精品一区二区三区 | 久久久午夜剧场 | 综合久久精品 | 亚洲综合色激情五月 | 99视频久久| 偷拍视频一区 | 在线观看91精品视频 | 天天插伊人| 亚洲精品视频在线观看视频 | 国产精品久久久久久久久久99 | 日韩av电影网站在线观看 | 亚洲人成精品久久久久 | 97色se | 欧美做受高潮1 | 日韩精品一区二区三区不卡 | 亚洲 中文 在线 精品 | 久久免费美女视频 | 波多野结衣在线观看视频 | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 国产一级高清视频 | 亚洲精品乱码久久 | 日韩一区二区三免费高清在线观看 | 狠狠色伊人亚洲综合网站色 | 欧洲在线免费视频 | 五月婷婷六月丁香激情 | 色先锋av资源中文字幕 | 日韩电影中文字幕在线 | av亚洲产国偷v产偷v自拍小说 | 婷婷国产v亚洲v欧美久久 | 色在线最新 | 在线观看国产福利片 | 亚洲综合欧美日韩狠狠色 | 国产中文字幕亚洲 | 久久免费电影网 | 在线欧美小视频 | 天堂av网站 | 久久久久福利视频 | 97视频在线观看播放 | 精品国产免费观看 | 国产96精品 | 精品国产成人av在线免 | 中文字幕乱码日本亚洲一区二区 | 久久99热精品这里久久精品 | 日韩激情在线 | 在线观看网站av | 色噜噜日韩精品一区二区三区视频 | 丰满少妇在线观看 | 亚洲va欧美 | 日韩视频一区二区在线 | 国产精品网红直播 | 中文字幕一区二区三区四区久久 | 亚洲精品在线观看中文字幕 | 欧美成人免费在线 | 麻豆国产视频下载 | av资源免费看 | 久久在线视频在线 | 日本黄色一级电影 | 中文字幕专区高清在线观看 | 97碰碰视频 | 久久国产精品免费看 | 成人在线视频一区 | 国产精品久久久久久久久久久久久久 | 欧美一二三四在线 | 手机av在线网站 | 国产成人免费 | 久久久久久久网站 | 高清不卡毛片 | 久久久男人的天堂 | 午夜久久福利影院 | 久久久国产电影 | 国产精品mv在线观看 | 久久天天拍 | 奇米影视777四色米奇影院 | 国产精品久久中文字幕 | 伊人天堂网 | 国产精品中文在线 | 免费午夜在线视频 | 国产探花| 国产在线小视频 | 国产色秀视频 | 日韩免费网站 | 日韩专区中文字幕 | 日韩在线视频一区二区三区 | 91精品视频在线免费观看 | 国产一区二区三区在线 | 欧美激情视频久久 | 中国一 片免费观看 | 黄色一级大片免费看 | 亚洲高清免费在线 | 亚洲开心激情 | 久久看片网 | 天天曰夜夜操 | 91福利视频一区 | 在线观看亚洲精品 | 麻豆成人在线观看 | 午夜av剧场 | 日韩在线精品视频 | 久久国产精品免费视频 | 久久久久免费精品视频 | av在线免费观看黄 | 99久久影院 | 99爱在线 | 欧美日本不卡视频 | 最近中文字幕大全中文字幕免费 | 亚洲在线成人精品 | 91久久在线观看 | 91自拍91 | 美女网站色免费 | www.婷婷色 | 日韩成人免费在线 | av一本久道久久波多野结衣 | 亚洲欧美成人 | 97人人澡人人添人人爽超碰 | av亚洲产国偷v产偷v自拍小说 | 成人三级网址 | 久久久久伦理电影 | 高清视频一区二区三区 | 欧美日韩国语 | 波多野结衣视频一区二区 | 国产 在线观看 | 色永久免费视频 | 亚洲日本中文字幕在线观看 | 亚洲第二色 | 国产精品6999成人免费视频 | 99久久久久国产精品免费 | 国产精品久久久久久久久搜平片 | 韩国av三级 | 国产精品久久久久久一区二区三区 | 人人干在线 | 亚洲视频分类 | 国产精品夜夜夜一区二区三区尤 | 黄色午夜 | 久久久久久久久久久影院 | 国产成人黄色在线 | 500部大龄熟乱视频使用方法 | 日本公妇在线观看 | 国产精品午夜在线观看 | av日韩国产| 国产亚洲综合性久久久影院 | 天天弄天天操 | 欧美激情第十页 | 欧美精品乱码久久久久久 | 精品a在线 | 久久精品一区 | 天天天色综合a | 狂野欧美激情性xxxx欧美 | 五月激情丁香图片 | 五月色婷 | 伊人婷婷久久 | 在线观看一二三区 | 欧美精品你懂的 | 精品一区二区三区四区在线 | h视频在线看 | 亚洲综合在线观看视频 | 日韩a在线 | 国产a免费| 在线高清| 亚洲久草视频 | 亚洲日本一区二区在线 | 亚洲黄色在线 | 久久成人免费视频 | 国产在线日韩 | 日韩伦理片一区二区三区 | 国产99久久久国产精品免费看 | 成年人免费在线播放 | 久久久精品国产一区二区电影四季 | 尤物97国产精品久久精品国产 | 久久国产精品影片 | 91av在线视频免费观看 | 欧美精品在线观看免费 | 国产欧美日韩精品一区二区免费 | 久久综合网色—综合色88 | 久草在线视频在线 | 国产精品久久久久久一区二区 | 亚州视频在线 | 国产高清视频网 | 国产国产人免费人成免费视频 | 在线免费视频a | 午夜黄色大片 | 99精品视频在线播放观看 | 伊人狠狠色丁香婷婷综合 | 99精品国产兔费观看久久99 | 亚洲一区二区视频在线 | 久久综合中文色婷婷 | 黄色aaaaa| 青青射 | 久久精品99国产精品 | 日韩精品aaa | 久久久99精品免费观看 | 欧美国产日韩一区二区三区 | 免费久久99精品国产 | 最近中文字幕大全中文字幕免费 | 欧美一二在线 | 夜夜高潮夜夜爽国产伦精品 | 日韩中文字幕免费在线观看 | 日韩精品一区二区三区视频播放 | 欧美久久成人 | 久99久在线 | 久久久久综合精品福利啪啪 | 久久久久久久久久电影 | 亚洲激情综合 | 欧美极品一区二区三区 | 日韩动漫免费观看高清完整版在线观看 | 中文字幕在线观看日本 | 日韩在线视频看看 | 一区二区激情视频 | 久久久久久久久艹 | 一区二区视频在线观看免费 | 91porny九色在线播放 | 欧美日韩国产一区二区在线观看 | 国产色视频网站2 | 91看毛片 | 黄色一级片视频 | 二区三区在线 | 国产美女网站在线观看 | 日韩经典一区二区三区 | 毛片99| 人人超碰人人 | 日本精品久久久久影院 | 韩日精品在线 | 免费中文字幕视频 | 91chinese在线| 婷婷黄色片 | 精品日韩视频 | 黄网站免费久久 | 国产热re99久久6国产精品 | 欧美日韩午夜在线 | 九九热免费在线视频 | 亚洲欧美日韩精品久久奇米一区 | 国产亚洲精品久久19p | 国产麻豆电影在线观看 | 久久免费的精品国产v∧ | 久久久综合九色合综国产精品 | 免费国产一区二区视频 | 国内精品一区二区 | 手机成人在线电影 | 国产成人精品综合久久久久99 | 久久艹免费 | 一二三精品视频 | 亚洲狠狠干 | 偷拍精偷拍精品欧洲亚洲网站 | 中文字幕av全部资源www中文字幕在线观看 | 91九色视频观看 | 亚洲精品乱码久久久久久高潮 | 天天天操操操 | 五月婷婷在线视频观看 | 五月综合色 | 欧美一区二区三区在线 | 九九视频精品在线 | 射久久久 | 亚洲成人黄色av | 欧美另类成人 | 欧美激情亚洲综合 | 中文字幕一区二区三区四区久久 | 99精品系列 | av黄色免费在线观看 | 97精品久久| 日韩免费在线 | 日韩理论片中文字幕 | 97激情影院 | 国产流白浆高潮在线观看 | 日韩免费不卡视频 | 成年人在线观看免费视频 | 天堂av高清 | 欧美精品少妇xxxxx喷水 | 日韩在线视频精品 | 麻豆免费精品视频 | 国产无套精品久久久久久 | 亚洲视频在线视频 | 在线看国产日韩 | 美女在线免费视频 | 激情综合色图 | 国产精品人人做人人爽人人添 | 久久精品99国产国产 | 97免费| 国产亚洲精品久久久久久久久久 | 韩日成人av | 国产精品欧美一区二区三区不卡 | 91精品一区二区三区久久久久久 | 天堂网av在线 | 亚洲国产中文字幕在线观看 | 夜夜躁日日躁狠狠久久av | 久久五月婷婷丁香 | 国产亚洲精品久久久久久久久久 | 97超碰人人澡人人爱学生 | 亚洲va在线va天堂va偷拍 | 国产区欧美 | 日韩中文在线字幕 | 五月天视频网站 | 日本黄色免费在线 | 久久在线精品 | 天天想夜夜操 | 国产精品久久久视频 | 国产精品成人国产乱 | 91视频在线 | 国产精品欧美日韩在线观看 | 四季av综合网站 | 午夜精品一区二区三区在线 | 狠狠的操你 | 麻豆视频免费在线 | 日韩中文免费视频 | 午夜91视频| 色免费在线| 欧美性生爱| 成人中文字幕在线 | 黄色网址中文字幕 | 日日摸日日爽 | 狠狠色狠狠色综合日日小说 | 成人免费在线电影 | 久久久久久久久久久成人 | 国产精品高清av | 激情视频一区二区 | 黄色三级免费看 | 一级黄色在线免费观看 | 蜜桃传媒一区二区 | av中文天堂 | 免费一级片观看 | 中文字幕在线观看第二页 | 视色网站| 精品女同一区二区三区在线观看 | 欧美在线视频第一页 | av网址在线播放 | 黄色网免费 | 欧美日韩不卡一区二区三区 | 日韩系列在线观看 | av资源免费在线观看 | 婷婷伊人综合亚洲综合网 | 日韩四虎 | 日本精品视频一区 | 久久久久女教师免费一区 | 亚洲精选在线观看 | 久久国产一二区 | 一区二区三区免费在线观看视频 | 一区二区三区免费 | 久久精品国产亚洲精品 | 99视频在线精品免费观看2 | 99人久久精品视频最新地址 | 国产在线不卡精品 | 久草爱视频 | 国产高清福利在线 | 黄色大片国产 | 欧美孕妇与黑人孕交 | 伊人久久影视 | 91麻豆精品国产自产 | 看片在线亚洲 | 久久婷婷色 | 国产99久久久精品视频 | 激情丁香综合五月 | av福利网址导航大全 | 亚洲精品乱码久久久久久蜜桃动漫 | 9999精品视频 | 久久精品9 | av线上看 | 久久婷婷色综合 | 99精品在线免费视频 | 黄色片亚洲 | 精品视频在线视频 | av视屏在线 | 九九免费观看全部免费视频 | av在线之家电影网站 | 久久a久久 | 天天爽夜夜爽人人爽一区二区 | 97超碰人人 | 久久一久久| 国产女人免费看a级丨片 | 涩涩网站在线 | 久草在线在线视频 | 日韩视频一区二区在线 | 欧美一区在线观看视频 | 高清av在线免费观看 | 国产日韩欧美在线一区 | 久久久精品一区二区 | 成在人线av | 国产精品久久久久aaaa九色 | 欧美性色综合 | 日韩1页| 精品黄色在线 | 在线观看www. | 国产91精品久久久久久 | 五月婷在线播放 | 在线a视频免费观看 | 色五月成人 | 亚洲免费一级电影 | 中日韩在线视频 | 国产91学生粉嫩喷水 | 狠狠干天天干 | 日韩精品免费在线观看视频 | 91丨九色丨国产在线观看 | 日韩三级视频在线观看 | 91黄色小网站 | 人人澡人人澡人人 | 日本三级吹潮在线 | 狠狠婷婷 | 996久久国产精品线观看 | 久久黄色小说视频 | 最近最新最好看中文视频 | www.伊人网 | 一二三精品视频 | 精品国产一区二区在线 | 国产乱码精品一区二区蜜臀 | 国产成人在线网站 | 国产在线a免费观看 | 国内精品视频在线 | www.亚洲激情.com | 日韩欧美大片免费观看 | 久久久男人的天堂 | 国产精选在线 | 免费看片亚洲 | 欧美精品中文字幕亚洲专区 | 在线国产99 | 在线导航福利 | 日本在线视频网址 | 在线看岛国av | 精品欧美小视频在线观看 | 麻豆国产精品永久免费视频 | 奇米网444| 中文字幕第一页在线播放 | 国产日韩欧美综合在线 | 成年人免费在线播放 | 黄色毛片视频 | 成人a v视频 | 久福利| 亚洲女人天堂成人av在线 | 狠狠干我 | 天天爱天天 | 亚洲伊人成综合网 | 国产一区成人 | 久久免费视频5 | 456成人精品影院 | 怡红院av| 免费观看的黄色 | 99色在线播放 | 中文字幕黄色 | 69性欧美 | 在线日韩中文 | 天天干夜夜干 | 狠狠的干狠狠的操 | 久草在线视频免赞 | 九九九视频在线 | 五月婷婷六月丁香 | 91视频免费播放 | 精品久久久久久久久亚洲 | 色偷偷中文字幕 | 91福利视频在线 | 97精品一区| 99久久精品免费看国产四区 | 国产精品原创视频 | 99久久精品无码一区二区毛片 | 最近中文字幕视频完整版 | 婷婷久久综合九色综合 | 81精品国产乱码久久久久久 | www.五月天婷婷.com | 国产色女| 中文字幕黄色网址 | 97视频免费在线观看 | 在线观看亚洲电影 | 国产精品免费久久久 | 国产精品久99 | 国产又粗又猛又色 | 五月婷婷久 | 久久久午夜电影 | 国产福利精品在线观看 | 国产尤物一区二区三区 | 中文字幕永久免费 | 久久深夜 | 亚洲精品日韩一区二区电影 | 狠狠狠色丁香综合久久天下网 | 香蕉视频在线免费看 | 亚洲国内精品在线 | 日韩动态视频 | 最近更新好看的中文字幕 | 91九色性视频 | 色综合激情网 | 播五月婷婷 | 国产亚洲精品久久久久久无几年桃 | 久久综合久久综合九色 | 探花视频在线观看免费版 | www夜夜操com| 午夜视频导航 | 国产一级一片免费播放放 | 色婷婷精品 | 在线精品观看国产 | 激情五月开心 | 人人爽人人澡 | 国产亚洲成人网 | 综合激情伊人 | 国产色妞影院wwwxxx | 日本韩国在线不卡 | 国产小视频在线免费观看视频 | 国产精品亚洲片夜色在线 | 欧美日韩精品免费观看 | 在线精品观看国产 | 亚洲精品一区二区三区高潮 | 日韩久久精品一区二区三区下载 | 婷婷久久久久 | 亚洲综合在线五月天 | 久久婷婷一区二区三区 | 99久久精品视频免费 | 国产一区二区三区在线免费观看 | 久久久久久高潮国产精品视 | 日本公妇在线观看 | 国产精品久久久久久久久费观看 | 日韩一区二区三区免费电影 | 在线亚州 | 亚洲aⅴ乱码精品成人区 | 日韩在线欧美在线 | 天天干天天干天天干 | 男女免费视频观看 | 九九视频精品免费 | 在线播放一区二区三区 | 精品一区二区久久久久久久网站 | 毛片随便看 | 韩国av一区二区三区在线观看 | 天天操福利视频 | 免费观看91视频大全 | 亚洲黄色免费网站 | 日日综合 | 免费视频久久久 | 五月婷婷操 | 国产高清综合 | 一区二区三区国产精品 | 国产精品午夜8888 | 午夜精品久久久久久久久久久 | 欧美乱淫视频 | 免费av电影网站 | 综合网中文字幕 | a亚洲视频 | 伊人五月天.com | a色视频| 日韩最新在线视频 | 国产日韩精品一区二区三区在线 | 成年人在线看片 | 福利视频网址 | 91大神dom调教在线观看 | 在线播放视频一区 | 久草香蕉在线 | 夜夜骑日日操 | 91精品国产成人观看 | 中文字幕不卡在线88 | 六月丁香六月婷婷 | 久久成年人 | av日韩国产 | 欧美极度另类 | 日韩久久久久久久久久 | 国产韩国精品一区二区三区 | 精品一区二区在线免费观看 | 亚州av网站 | 国产一区在线不卡 | 天天操天 | 夜夜爱av | 成人av地址 | 97视频网站 | 亚洲激情校园春色 | 久久久国产影视 | av韩国在线 | 亚洲欧洲精品在线 | 人人超在线公开视频 | 18性欧美xxxⅹ性满足 | 久久免费观看视频 | 国产精品视频全国免费观看 | 色综合狠狠干 | 久久久久久免费视频 | 色综合久久中文综合久久牛 | 国产97av | 日韩精品一区二区三区在线播放 | 成人久久久久久久久久 | 99久久婷婷国产一区二区三区 | 国产在线精品一区二区不卡了 | 天天爽人人爽 | 日韩电影在线观看一区二区三区 | 国产精品久久久久久模特 | www.777奇米| 99精品久久久久久久久久综合 | 国产精品观看在线亚洲人成网 | 国产美女久久久 | 一区二区毛片 | 国产小视频免费在线观看 | wwwwww色| 欧美成人a在线 | 夜添久久精品亚洲国产精品 | 久久香蕉国产精品麻豆粉嫩av | 精品国产诱惑 | 中文理论片 | 国产午夜三级一区二区三 | 精品国产乱码久久久久久1区二区 | 一色av | 一级免费观看 | 美女网站在线免费观看 | 久久国产精品99久久久久久老狼 | 国产成人av在线 | 日韩精品久久久免费观看夜色 | 中文字幕av网站 | 国产日本在线播放 | 黄色小说在线免费观看 | 免费a v观看| 午夜成人免费电影 | 伊人国产在线播放 | 亚洲免费在线 | 四虎影视国产精品免费久久 | 99久久精品国产毛片 | 超碰97中文 | 亚洲日本韩国一区二区 | 欧美天天射| 亚洲免费在线观看视频 | 成年人在线| 亚洲视频电影在线 | 久久视频这里只有精品 | 狠狠干中文字幕 | 婷婷精品在线视频 | 久久久九色精品国产一区二区三区 | 国产免码va在线观看免费 | 国产一区二区三区在线 | 国产精品美女在线观看 | 一区二区三区免费看 | 成人精品国产免费网站 | 色a网 | 免费观看一区二区三区视频 | 波多野结衣在线观看视频 | 日韩二区在线播放 | 久久久久激情 | 日韩h在线观看 | 亚洲国产精品成人综合 | 波多野结衣电影一区 | 亚洲播播| 国产日韩欧美视频 | 日日操夜夜操狠狠操 | 日韩精品三区四区 | 成人在线一区二区 | 69国产盗摄一区二区三区五区 | 国产一区二区精品 | 欧美日韩一区二区三区免费视频 | ww视频在线观看 | 麻豆成人精品 | 国产精品6999成人免费视频 | 欧美三人交| 91网址在线看 | 九九热在线视频免费观看 | 97精品国产91久久久久久久 | 色久综合 | 久久国产视屏 | 天天操操操操操操 | 人人插人人艹 | 中文资源在线官网 | 国产又粗又长的视频 | 久久久久久国产精品免费 | 91亚洲欧美激情 | 蜜臀久久99精品久久久无需会员 | 天天爽天天碰狠狠添 | 国产一级a毛片视频爆浆 | 天天操夜 | 超级碰碰碰碰 | 亚洲码国产日韩欧美高潮在线播放 | 亚洲成av人影院 | 成人国产精品一区二区 | 日本午夜在线亚洲.国产 | 中文av日韩 | 色偷偷88888欧美精品久久久 | 国产午夜精品理论片在线 | 一级淫片在线观看 | 玖玖在线观看视频 | 最近更新好看的中文字幕 | 手机在线小视频 | 婷婷 综合 色 | 一区二区三区在线免费观看 | 97手机电影网| 国产一二三四在线视频 | 91精品视频观看 | 成 人 黄 色视频免费播放 | 九九视频网 | 久久精品99国产精品酒店日本 | 国产高清福利在线 | 欧美一区二区三区四区夜夜大片 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 丁香激情综合久久伊人久久 | 色综合天天做天天爱 | 国产精品中文在线 | 黄污污网站 | 黄色日本片 | 91精品国产高清自在线观看 | 五月婷香 | 99久热在线精品视频成人一区 | 欧美精品v国产精品v日韩精品 | 久久久久久久久久久免费视频 | 久操久 | 欧美日韩国产mv | 伊人激情网 | 夜夜骑日日操 | 久久超碰免费 | 狠狠黄 | 亚洲精品一区二区三区高潮 | 日韩不卡高清 | 亚洲国产久 | 最新国产在线观看 | 国产精品九九久久久久久久 | 激情欧美xxxx | 国产精品资源在线观看 | 96久久精品| 国产综合视频在线观看 | 亚洲欧洲国产视频 | 久久久午夜剧场 | 天天爱综合 | 亚洲视频网站在线观看 | 国产又黄又爽无遮挡 | 国产成人一区二区三区影院在线 | 999久久久国产精品 高清av免费观看 | 欧美在线视频a | 日韩av免费在线电影 | 日韩专区 在线 | 国产一区二区在线播放 | 欧美性生活小视频 | 久久成人久久 | 91精品国产综合久久福利 | 精品久久九九 | 成人网大片 | 一区二区三区免费在线 | 国内精品久久久精品电影院 | 99久久精品日本一区二区免费 | 国产无遮挡又黄又爽馒头漫画 | 久久国产精品99国产精 | 国产精品久久久久久久av电影 | 又污又黄的网站 | 国产999视频在线观看 | 在线黄色观看 | 免费网站看v片在线a | 国产精品中文在线 | 在线播放视频一区 | 91精品亚洲影视在线观看 | 久久天堂影院 | 五月婷婷网站 | 欧美国产不卡 | 人人干人人添 | 精品视频成人 | 国产精品国产三级国产aⅴ9色 | 成人丝袜| 午夜精品久久久久久久99水蜜桃 | 久久久国产网站 | 女人18毛片90分钟 | 久久免费视频网站 | 日本韩国在线不卡 | 日韩视频一区二区三区在线播放免费观看 | 91视频免费看网站 | 精品在线免费观看 | 亚洲成人精品国产 | www.天天干.com| 欧美日韩视频在线观看一区二区 | 免费在线观看污网站 | 精品国产乱码久久久久久三级人 | 中文字幕有码在线播放 | 91精品国产九九九久久久亚洲 | 久久久官网 | 国内综合精品午夜久久资源 | 中文字幕日韩精品有码视频 | 色综久久| 91网址在线| 午夜视频一区二区 | 成人蜜桃视频 | 在线蜜桃视频 | 久久久国际精品 | 欧美一区视频 | 美女网站在线 | 一区二区精 | 99久久精品国产一区二区三区 | 婷婷久久一区二区三区 | 91久久爱热色涩涩 | 日韩精品中文字幕一区二区 | 国产69久久精品成人看 | 国产精品免费av | 国产高清在线精品 | 国产剧情久久 | 免费观看十分钟 | 国产一区二区在线精品 | 国产精品久久久久久久7电影 | 国产美女精品视频 | 天天射天天爽 | 91一区在线观看 | 欧美另类xxxx | 国产欧美最新羞羞视频在线观看 | 欧美成人精品三级在线观看播放 | 日韩乱理 | 97在线观看免费高清 | a在线观看国产 | 国产一区视频在线播放 | 婷婷丁香色 | 国产精品 久久 | 中文字幕亚洲国产 | 91视频在线看 | 日韩天天干 | 五月色综合 | 日韩综合在线观看 | 久久久久久综合网天天 | 伊人激情网 | 国产精品毛片一区二区 | 久久久精品成人 | 欧美乱码精品一区 | 欧美三级高清 | 亚洲精品国产成人 | 国产精品夜夜夜一区二区三区尤 | 依人成人综合网 | 亚洲色五月 | 一区二区激情视频 | 国产精品免费久久久久影院仙踪林 | 狠狠色狠狠色合久久伊人 | 超碰免费观看 | 国产精品国产精品 | 亚洲黄在线观看 | 久久综合导航 | 免费网站黄 | 在线激情电影 | 最近日韩中文字幕中文 | 亚洲国产免费网站 | 97在线视频免费观看 | 黄色一级片视频 | a级片韩国 | av在观看 | 99久高清在线观看视频99精品热在线观看视频 | 超碰资源在线 | 在线视频你懂 | 亚州欧美视频 | 天天拍天天操 | 91av电影 | 久久国产精品久久精品国产演员表 | 精品国产一区二区三区四区在线观看 | 国产精品乱码久久久久久1区2区 | 福利一区二区 | 中文字幕免费高 | 美女又爽又黄 | 最近免费中文视频 | 亚州精品天堂中文字幕 | 97国产大学生情侣白嫩酒店 | av大全在线观看 | 精品国产成人在线 | 99久久精品午夜一区二区小说 | www色,com| 色姑娘综合 | 日韩三级视频在线看 | 男女视频久久久 | 日韩不卡高清视频 | 欧美日韩国产mv | 国产在线久久久 | 9在线观看免费高清完整版在线观看明 | 久久国产免费看 | 日韩av视屏 | 最近日本韩国中文字幕 | 欧美性网站 | 日韩三级在线 | 国产精品18久久久久白浆 | 欧美日韩天堂 | 中文字幕在线播出 | 欧美性性网 | 黄网站色欧美视频 | 亚洲综合射 | av理论电影 | 国产精品露脸在线 | 日韩理论在线 | 国产精品热 | 国产 精品 资源 | 中文字幕在线观看完整版 | 国产精品黄网站在线观看 | 日本三级久久久 | 黄色av电影在线观看 | 国产日产精品一区二区三区四区的观看方式 | 91久久精品一区二区二区 | 日韩在线观看视频在线 | 久久精精品 | 91福利视频久久久久 | 国产精品一区二区三区在线看 | 精品久久福利 | www.69xx| 亚洲国产激情 | 亚洲乱码在线观看 | 精品国产一区二区三区不卡 | 欧美一级日韩三级 | 日韩欧美高清一区二区 | 国产又粗又硬又长又爽的视频 | 99色在线| 综合激情久久 | 日本精品在线看 | 久久精品久久精品久久精品 | 日韩高清不卡在线 | 91成人精品一区在线播放69 | 欧美专区日韩专区 | 久草在线久 | 国产 欧美 日产久久 | 婷婷国产一区二区三区 | 亚洲 欧美 国产 va在线影院 | 国产成人精品在线观看 | 激情五月播播久久久精品 | 国产精品精 | 五月婷激情 | 国产精品久久久久久久久久直播 | 色网站国产精品 | 99精品欧美一区二区三区黑人哦 | 伊色综合久久之综合久久 | 国产精品久久久久久久久久妇女 | 久久午夜电影 | 精品久久久久久久久久久久 | 天天躁日日躁狠狠躁av麻豆 | 手机av电影在线观看 | 中文字幕在线一二 | 国产xxxxx在线观看 | 亚洲午夜精品电影 | 国产综合香蕉五月婷在线 | 欧美一区二区三区四区夜夜大片 | 免费观看成人av | 色在线最新 | 中文字幕乱码一区二区 | av免费看在线 | www国产亚洲精品久久麻豆 | 欧美激情综合色 | 三级av免费观看 | 毛片网站免费在线观看 | av中文字幕免费在线观看 | 久久国产免| 五月婷婷六月丁香 | 免费在线观看91 | 亚洲精品网址在线观看 | 综合国产在线观看 | 开心激情五月网 | 日韩av图片 | 欧美日韩二区在线 | 久久99中文字幕 | 久草在线视频中文 | 91麻豆传媒 | 国产一区二区久久久久 | 香蕉影院在线播放 | 精品九九九| 欧美日韩亚洲在线观看 | 久久99精品国产99久久6尤 | 欧美激情精品久久久久 | 中文字幕一区二区在线播放 | 国产一级大片在线观看 | 美女搞黄国产视频网站 | 五月综合激情婷婷 | 国内免费久久久久久久久久久 | 国产色视频一区二区三区qq号 | 天天摸天天干天天操天天射 | 中国精品一区二区 | 国产麻豆精品久久 | 欧美日韩在线视频一区二区 | 999毛片| 日韩精品一区二区三区中文字幕 | 久久观看免费视频 | 月下香电影| 黄色在线视频网址 | 免费的黄色av|