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

答應我,這次要搞懂 Buffer Pool

數據庫 MySQL
要想提升查詢性能,加個緩存就行了嘛。所以,當數據從磁盤中取出后,緩存內存中,下次查詢同樣的數據的時候,直接從內存中讀取。

今天聊 MySQL 的 Buffer Pool,發車!

為什么要有 Buffer Pool?

雖然說 MySQL 的數據是存儲在磁盤里的,但是也不能每次都從磁盤里面讀取數據,這樣性能是極差的。

要想提升查詢性能,加個緩存就行了嘛。所以,當數據從磁盤中取出后,緩存內存中,下次查詢同樣的數據的時候,直接從內存中讀取。

為此,Innodb 存儲引擎設計了一個緩沖池(Buffer Pool),來提高數據庫的讀寫性能。

有了緩沖池后:

  • 當讀取數據時,如果數據存在于 Buffer Pool 中,客戶端就會直接讀取 Buffer Pool 中的數據,否則再去磁盤中讀取。
  • 當修改數據時,首先是修改 Buffer Pool 中數據所在的頁,然后將其頁設置為臟頁,最后由后臺線程將臟頁寫入到磁盤。

Buffer Pool 有多大?

Buffer Pool 是在 MySQL 啟動的時候,向操作系統申請的一片連續的內存空間,默認配置下 Buffer Pool 只有 128MB 。

可以通過調整 innodb_buffer_pool_size 參數來設置 Buffer Pool 的大小,一般建議設置成可用物理內存的 60%~80%。

Buffer Pool 緩存什么?

InnoDB 會把存儲的數據劃分為若干個「頁」,以頁作為磁盤和內存交互的基本單位,一個頁的默認大小為 16KB。因此,Buffer Pool 同樣需要按「頁」來劃分。

在 MySQL 啟動的時候,InnoDB 會為 Buffer Pool 申請一片連續的內存空間,然后按照默認的16KB的大小劃分出一個個的頁, Buffer Pool 中的頁就叫做緩存頁。此時這些緩存頁都是空閑的,之后隨著程序的運行,才會有磁盤上的頁被緩存到 Buffer Pool 中。

所以,MySQL 剛啟動的時候,你會觀察到使用的虛擬內存空間很大,而使用到的物理內存空間卻很小,這是因為只有這些虛擬內存被訪問后,操作系統才會觸發缺頁中斷,接著將虛擬地址和物理地址建立映射關系。

Buffer Pool 除了緩存「索引頁」和「數據頁」,還包括了 undo 頁,插入緩存、自適應哈希索引、鎖信息等等。

為了更好的管理這些在 Buffer Pool 中的緩存頁,InnoDB 為每一個緩存頁都創建了一個控制塊,控制塊信息包括「緩存頁的表空間、頁號、緩存頁地址、鏈表節點」等等。

控制塊也是占有內存空間的,它是放在 Buffer Pool 的最前面,接著才是緩存頁,如下圖:

上圖中控制塊和緩存頁之間灰色部分稱為碎片空間。

為什么會有碎片空間呢?

你想想啊,每一個控制塊都對應一個緩存頁,那在分配足夠多的控制塊和緩存頁后,可能剩余的那點兒空間不夠一對控制塊和緩存頁的大小,自然就用不到嘍,這個用不到的那點兒內存空間就被稱為碎片了。

當然,如果你把 Buffer Pool 的大小設置的剛剛好的話,也可能不會產生碎片。

查詢一條記錄,就只需要緩沖一條記錄嗎?

不是的。

當我們查詢一條記錄時,InnoDB 是會把整個頁的數據加載到 Buffer Pool 中,因為,通過索引只能定位到磁盤中的頁,而不能定位到頁中的一條記錄。將頁加載到 Buffer Pool 后,再通過頁里的頁目錄去定位到某條具體的記錄。

如何管理 Buffer Pool?

如何管理空閑頁?

當啟動 Mysql 服務器的時候,需要完成對 Buffer Pool 的初始化過程,即分配 Buffer Pool 的內存空間,把它劃分為若干對控制塊和緩存頁。

但是此時并沒有真正的磁盤頁被緩存到 Buffer Pool 中,之后隨著程序的運行,會不斷的有磁盤上的頁被緩存到 Buffer Pool 中。

為了標記哪些頁是空閑頁,就使用了鏈表結構,將空閑緩存頁的「控制塊」作為鏈表的節點,一個一個串起來,這個鏈表稱為 Free 鏈表(空閑鏈表)。

Free 鏈表上除了有控制塊,還有一個頭節點,該頭節點包含鏈表的頭節點地址,尾節點地址,以及當前鏈表中節點的數量等信息。

Free 鏈表節點是一個一個的控制塊,而每個控制塊包含著對應緩存頁的地址,所以相當于 Free 鏈表節點都對應一個空閑的緩存頁。

有了 Free 鏈表后,每當需要從磁盤中加載一個頁到 Buffer Pool 中時,就從 Free 鏈表中取一個空閑的緩存頁,并且把該緩存頁對應的控制塊的信息填上,然后把該緩存頁對應的控制塊從 Free 鏈表中移除。

如何管理臟頁?

設計 Buffer Pool 除了能提高讀性能,還能提高寫性能,也就是更新數據的時候,不需要每次都要寫入磁盤,而是將 Buffer Pool 對應的緩存頁標記為臟頁,然后再由后臺線程將臟頁寫入到磁盤。

那為了能快速知道哪些緩存頁是臟的,于是就設計出 Flush 鏈表,它跟 Free 鏈表類似的,鏈表的節點也是控制塊,區別在于 Flush 鏈表的元素都是臟頁。

有了 Flush 鏈表后,后臺線程就可以遍歷 Flush 鏈表,將臟頁寫入到磁盤。

如何提高緩存命中率?

Buffer Pool 的大小是有限的,對于一些頻繁訪問的數據我們希望可以一直留在 Buffer Pool 中,而一些很少訪問的數據希望可以在某些時機可以淘汰掉,從而保證 Buffer Pool 不會因為滿了而導致無法再緩存新的數據,同時還能保證常用數據留在 Buffer Pool 中。

要實現這個,最容易想到的就是 LRU(Least recently used)算法。

該算法的思路是,鏈表頭部的節點是最近使用的,而鏈表末尾的節點是最久沒被使用的。那么,當空間不夠了,就淘汰最久沒被使用的節點,從而騰出空間。

簡單的 LRU 算法的實現思路是這樣的:

當訪問的頁在 Buffer Pool 里,就直接把該頁對應的 LRU 鏈表節點移動到鏈表的頭部。

當訪問的頁不在 Buffer Pool 里,除了要把頁放入到 LRU 鏈表的頭部,還要淘汰 LRU 鏈表末尾的節點。

比如下圖,假設 LRU 鏈表長度為 5,LRU 鏈表從左到右有 1,2,3,4,5 的頁。

如果訪問了 3 號的頁,因為 3 號頁在 Buffer Pool 里,所以把 3 號頁移動到頭部即可。

而如果接下來,訪問了 8 號頁,因為 8 號頁不在 Buffer Pool 里,所以需要先淘汰末尾的 5 號頁,然后再將 8 號頁加入到頭部。

到這里我們可以知道,Buffer Pool 里有三種頁和鏈表來管理數據。

圖中:

  • Free Page(空閑頁),表示此頁未被使用,位于 Free 鏈表;
  • Clean Page(干凈頁),表示此頁已被使用,但是頁面未發生修改,位于LRU 鏈表。
  • Dirty Page(臟頁),表示此頁「已被使用」且「已經被修改」,其數據和磁盤上的數據已經不一致。當臟頁上的數據寫入磁盤后,內存數據和磁盤數據一致,那么該頁就變成了干凈頁。臟頁同時存在于 LRU 鏈表和 Flush 鏈表。

簡單的 LRU 算法并沒有被 MySQL 使用,因為簡單的 LRU 算法無法避免下面這兩個問題:

  • 預讀失效;
  • Buffer Pool 污染;

什么是預讀失效?

先來說說 MySQL 的預讀機制。程序是有空間局部性的,靠近當前被訪問數據的數據,在未來很大概率會被訪問到。

所以,MySQL 在加載數據頁時,會提前把它相鄰的數據頁一并加載進來,目的是為了減少磁盤 IO。

但是可能這些被提前加載進來的數據頁,并沒有被訪問,相當于這個預讀是白做了,這個就是預讀失效。

如果使用簡單的 LRU 算法,就會把預讀頁放到 LRU 鏈表頭部,而當 Buffer Pool空間不夠的時候,還需要把末尾的頁淘汰掉。

如果這些預讀頁如果一直不會被訪問到,就會出現一個很奇怪的問題,不會被訪問的預讀頁卻占用了 LRU 鏈表前排的位置,而末尾淘汰的頁,可能是頻繁訪問的頁,這樣就大大降低了緩存命中率。

怎么解決預讀失效而導致緩存命中率降低的問題?

我們不能因為害怕預讀失效,而將預讀機制去掉,大部分情況下,局部性原理還是成立的。

要避免預讀失效帶來影響,最好就是讓預讀的頁停留在 Buffer Pool 里的時間要盡可能的短,讓真正被訪問的頁才移動到 LRU 鏈表的頭部,從而保證真正被讀取的熱數據留在 Buffer Pool 里的時間盡可能長。

那到底怎么才能避免呢?

MySQL 是這樣做的,它改進了 LRU 算法,將 LRU 劃分了 2 個區域:old 區域 和 young 區域。

young 區域在 LRU 鏈表的前半部分,old 區域則是在后半部分,如下圖:

old 區域占整個 LRU 鏈表長度的比例可以通過 innodb_old_blocks_pc 參數來設置,默認是 37,代表整個 LRU 鏈表中 young 區域與 old 區域比例是 63:37。

劃分這兩個區域后,預讀的頁就只需要加入到 old 區域的頭部,當頁被真正訪問的時候,才將頁插入 young 區域的頭部。如果預讀的頁一直沒有被訪問,就會從 old 區域移除,這樣就不會影響 young 區域中的熱點數據。

接下來,給大家舉個例子。

假設有一個長度為 10 的 LRU 鏈表,其中 young 區域占比 70 %,old 區域占比 20 %。

現在有個編號為 20 的頁被預讀了,這個頁只會被插入到 old 區域頭部,而 old 區域末尾的頁(10號)會被淘汰掉。

如果 20 號頁一直不會被訪問,它也沒有占用到 young 區域的位置,而且還會比 young 區域的數據更早被淘汰出去。

如果 20 號頁被預讀后,立刻被訪問了,那么就會將它插入到 young 區域的頭部,young 區域末尾的頁(7號),會被擠到 old 區域,作為 old 區域的頭部,這個過程并不會有頁被淘汰。

雖然通過劃分 old 區域 和 young 區域避免了預讀失效帶來的影響,但是還有個問題無法解決,那就是 Buffer Pool 污染的問題。

什么是 Buffer Pool 污染?

當某一個 SQL 語句掃描了大量的數據時,在 Buffer Pool 空間比較有限的情況下,可能會將 Buffer Pool 里的所有頁都替換出去,導致大量熱數據被淘汰了,等這些熱數據又被再次訪問的時候,由于緩存未命中,就會產生大量的磁盤 IO,MySQL 性能就會急劇下降,這個過程被稱為 Buffer Pool 污染。

注意, Buffer Pool 污染并不只是查詢語句查詢出了大量的數據才出現的問題,即使查詢出來的結果集很小,也會造成 Buffer Pool 污染。

比如,在一個數據量非常大的表,執行了這條語句:

select * from t_user where name like "%xiaolin%";

可能這個查詢出來的結果就幾條記錄,但是由于這條語句會發生索引失效,所以這個查詢過程是全表掃描的,接著會發生如下的過程:

  • 從磁盤讀到的頁加入到 LRU 鏈表的 old 區域頭部;
  • 當從頁里讀取行記錄時,也就是頁被訪問的時候,就要將該頁放到 young 區域頭部;
  • 接下來拿行記錄的 name 字段和字符串 xiaolin 進行模糊匹配,如果符合條件,就加入到結果集里;
  • 如此往復,直到掃描完表中的所有記錄。

經過這一番折騰,原本 young 區域的熱點數據都會被替換掉。

舉個例子,假設需要批量掃描:21,22,23,24,25 這五個頁,這些頁都會被逐一訪問(讀取頁里的記錄)。

在批量訪問這些數據的時候,會被逐一插入到 young 區域頭部。

可以看到,原本在 young 區域的熱點數據 6 和 7 號頁都被淘汰了,這就是 Buffer Pool 污染的問題。

怎么解決出現 Buffer Pool 污染而導致緩存命中率下降的問題?

像前面這種全表掃描的查詢,很多緩沖頁其實只會被訪問一次,但是它卻只因為被訪問了一次而進入到 young 區域,從而導致熱點數據被替換了。

LRU 鏈表中 young 區域就是熱點數據,只要我們提高進入到 young 區域的門檻,就能有效地保證 young 區域里的熱點數據不會被替換掉。

MySQL 是這樣做的,進入到 young 區域條件增加了一個停留在 old 區域的時間判斷。

具體是這樣做的,在對某個處在 old 區域的緩存頁進行第一次訪問時,就在它對應的控制塊中記錄下來這個訪問時間:

  • 如果后續的訪問時間與第一次訪問的時間在某個時間間隔內,那么該緩存頁就不會被從 old 區域移動到 young 區域的頭部;
  • 如果后續的訪問時間與第一次訪問的時間不在某個時間間隔內,那么該緩存頁移動到 young 區域的頭部;

這個間隔時間是由 innodb_old_blocks_time 控制的,默認是 1000 ms。

也就說,只有同時滿足「被訪問」與「在 old 區域停留時間超過 1 秒」兩個條件,才會被插入到 young 區域頭部,這樣就解決了 Buffer Pool 污染的問題 。

另外,MySQL 針對 young 區域其實做了一個優化,為了防止 young 區域節點頻繁移動到頭部。young 區域前面 1/4 被訪問不會移動到鏈表頭部,只有后面的 3/4被訪問了才會。

臟頁什么時候會被刷入磁盤?

引入了 Buffer Pool 后,當修改數據時,首先是修改 Buffer Pool 中數據所在的頁,然后將其頁設置為臟頁,但是磁盤中還是原數據。

因此,臟頁需要被刷入磁盤,保證緩存和磁盤數據一致,但是若每次修改數據都刷入磁盤,則性能會很差,因此一般都會在一定時機進行批量刷盤。

可能大家擔心,如果在臟頁還沒有來得及刷入到磁盤時,MySQL 宕機了,不就丟失數據了嗎?

這個不用擔心,InnoDB 的更新操作采用的是 Write Ahead Log 策略,即先寫日志,再寫入磁盤,通過 redo log 日志讓 MySQL 擁有了崩潰恢復能力。

下面幾種情況會觸發臟頁的刷新:

  • 當 redo log 日志滿了的情況下,會主動觸發臟頁刷新到磁盤;
  • Buffer Pool 空間不足時,需要將一部分數據頁淘汰掉,如果淘汰的是臟頁,需要先將臟頁同步到磁盤;
  • MySQL 認為空閑時,后臺線程回定期將適量的臟頁刷入到磁盤;
  • MySQL 正常關閉之前,會把所有的臟頁刷入到磁盤;

在我們開啟了慢 SQL 監控后,如果你發現「偶爾」會出現一些用時稍長的 SQL,這可能是因為臟頁在刷新到磁盤時可能會給數據庫帶來性能開銷,導致數據庫操作抖動。

如果間斷出現這種現象,就需要調大 Buffer Pool 空間或 redo log 日志的大小。

總結

Innodb 存儲引擎設計了一個緩沖池(Buffer Pool),來提高數據庫的讀寫性能。

Buffer Pool 以頁為單位緩沖數據,可以通過 innodb_buffer_pool_size 參數調整緩沖池的大小,默認是 128 M。

Innodb 通過三種鏈表來管理緩頁:

  • Free List (空閑頁鏈表),管理空閑頁;
  • Flush List (臟頁鏈表),管理臟頁;
  • LRU List,管理臟頁+干凈頁,將最近且經常查詢的數據緩存在其中,而不常查詢的數據就淘汰出去。;

InnoDB 對 LRU 做了一些優化,我們熟悉的 LRU 算法通常是將最近查詢的數據放到 LRU 鏈表的頭部,而 InnoDB 做 2 點優化:

  • 將 LRU 鏈表 分為young 和 old 兩個區域,加入緩沖池的頁,優先插入 old 區域;頁被訪問時,才進入 young 區域,目的是為了解決預讀失效的問題。
  • 當「頁被訪問」且「 old 區域停留時間超過 innodb_old_blocks_time 閾值(默認為1秒)」時,才會將頁插入到 young 區域,否則還是插入到 old 區域,目的是為了解決批量數據訪問,大量熱數據淘汰的問題。

可以通過調整 innodb_old_blocks_pc 參數,設置 young 區域和 old 區域比例。

在開啟了慢 SQL 監控后,如果你發現「偶爾」會出現一些用時稍長的 SQL,這可因為臟頁在刷新到磁盤時導致數據庫性能抖動。如果在較短的時間頻繁出現這種現象,就需要調大 Buffer Pool 空間或 redo log 日志的大小,從而減少臟頁刷入磁盤的頻率。

責任編輯:武曉燕 來源: 小林coding
相關推薦

2019-06-24 05:05:40

緩沖池查詢數據InnoDB

2021-04-07 20:01:23

Go變量常量

2021-03-17 16:53:51

IO多路

2025-04-08 08:20:00

2025-03-17 00:21:00

2022-10-12 08:52:00

內存緩沖管理

2019-06-26 06:31:56

緩沖緩沖池查詢數據

2018-08-30 05:04:22

谷歌互聯網網絡

2020-11-30 08:06:27

Windows10

2016-07-29 00:09:31

數據庫云計算

2018-02-07 14:31:57

顯卡顯存價格

2022-03-22 15:05:15

MySQL緩沖池

2021-03-01 18:37:15

MySQL存儲數據

2021-02-22 07:29:07

算法初級排序

2021-02-26 05:29:11

排序算法數組

2010-05-07 19:15:18

Oracle flas

2021-01-29 11:05:50

PrintPython代碼

2024-10-23 08:47:46

2023-11-29 09:09:27

OceanBase底層

2020-10-23 10:10:59

Promise前端代碼
點贊
收藏

51CTO技術棧公眾號

波多野结衣av无码| 人妻大战黑人白浆狂泄| 69xxx在线| 岛国精品在线观看| 日本sm极度另类视频| 国产精品18在线| 都市激情亚洲欧美| 欧美性猛交xxxxx免费看| 在线视频精品一区| 天堂网av2014| 久久精品久久综合| 97色在线观看| 欧美老熟妇一区二区三区| 日韩精品免费一区二区夜夜嗨 | www.亚洲视频.com| 国产在线观看高清视频| 国产在线观看一区二区| 欧美在线性爱视频| 免费一级片在线观看| 国产精品手机在线播放| 精品精品国产高清一毛片一天堂| 哪个网站能看毛片| 国语对白在线刺激| 国产精品久久毛片av大全日韩| 翡翠波斯猫1977年美国| 亚洲天堂视频在线| 日韩制服丝袜av| 久久久久五月天| 中文字幕亚洲欧美日韩| 日韩啪啪网站| 日韩天堂在线观看| 九九热精品国产| 成人开心激情| 日韩欧美999| 欧美一级欧美一级| 手机在线免费看av| 亚洲欧美日韩一区二区 | 国产精品一区二区入口九绯色| 懂色av色香蕉一区二区蜜桃| 欧美亚洲精品一区| 无码人妻丰满熟妇区毛片| 蜜桃视频在线观看播放| 亚洲国产一区二区三区 | 日韩欧美黄色网址| 嫩草影视亚洲| 国产一区二区三区视频免费| xxx在线播放| 亚洲免费观看高清完整版在线观| 精品国产乱码久久久久久影片| 中文字幕在线视频一区二区三区| 免费视频成人| 欧美日韩三级在线| 久久久久久蜜桃一区二区| 日本成人片在线| 在线视频一区二区免费| 玩弄japan白嫩少妇hd| 婷婷六月国产精品久久不卡| 色呦呦国产精品| 日韩毛片在线免费看| 姬川优奈av一区二区在线电影| 一本一道久久a久久精品综合蜜臀| 免费在线a视频| 日本在线播放一二三区| 色天使久久综合网天天| 婷婷丁香激情网| 欧美一级在线| 51精品国自产在线| 蜜臀av粉嫩av懂色av| 久久久精品国产**网站| 亚洲欧美中文字幕| 亚洲色图欧美色| 一区二区不卡| 97在线精品视频| 亚洲乱码国产乱码精品| 麻豆精品在线播放| 99久久一区三区四区免费| 三级视频在线看| 久久久不卡网国产精品二区| 亚洲精品欧美精品| 女子免费在线观看视频www| 天天影视色香欲综合网老头| 国产日韩成人内射视频| 亚洲精品成人一区| 亚洲风情亚aⅴ在线发布| 国产ts在线播放| 综合久久婷婷| 456亚洲影院| 国产又粗又猛视频免费| 国产精品亚洲成人| 欧美午夜精品久久久久久蜜| 黄色网页网址在线免费| 午夜欧美大尺度福利影院在线看 | 国产福利拍拍拍| 丝袜诱惑亚洲看片| 亚洲综合一区二区不卡| 欧美美女搞黄| 尤物在线观看一区| 日韩在线第三页| 国产suv精品一区| 伊人久久久久久久久久久久久| 中文字幕av免费在线观看| 午夜亚洲视频| 99久久伊人精品影院| 成人高清免费观看mv| 亚洲一区二区三区在线| 欧美日韩一区二区三区69堂| 美国成人xxx| 欧美成人午夜影院| 最近中文字幕av| av成人老司机| 国产内射老熟女aaaa| 欧美与亚洲与日本直播| 亚洲国产精品久久91精品| 亚洲天堂网av在线| 日韩电影免费在线观看网站| 黑人另类av| 日本h片在线观看| 欧美精品在线观看播放| 国产精品手机在线观看| 亚洲先锋影音| 国产日韩在线播放| 九色视频在线播放| 黄色成人av网| 男男一级淫片免费播放| 亚洲无中文字幕| 91久久国产婷婷一区二区| 国自产拍在线网站网址视频| 天天综合天天综合色| 亚洲AV成人精品| 中文精品久久| 成人综合网网址| 日本精品在线| 欧美日本一道本在线视频| 日韩精品电影一区二区| 石原莉奈在线亚洲三区| 欧美精品久久久| 不卡一二三区| 亚洲欧美日韩另类| www亚洲视频| 26uuu亚洲综合色欧美 | 久久国产免费观看| 国产伦精品一区二区三区视频青涩| 五月婷婷一区| 黑人一区二区三区| 中文字幕久精品免费视频| а中文在线天堂| 欧美国产日韩亚洲一区| 妓院一钑片免看黄大片| 精品国产一区二区三区噜噜噜 | 成人av免费播放| 亚洲一线二线三线视频| 日韩综合第一页| 激情久久久久久| 国产综合第一页| 麻豆成全视频免费观看在线看| 亚洲第一综合天堂另类专 | 欧美视频日韩视频| 青青草自拍偷拍| 精品一区二区在线观看| 干日本少妇视频| www.豆豆成人网.com| 午夜精品在线视频| 欧美18xxxxx| 欧美日韩国产免费一区二区| 777777国产7777777| 国产激情偷乱视频一区二区三区 | 99国产精品无码| 国产乱码精品1区2区3区| 台湾无码一区二区| 亚洲精品蜜桃乱晃| 国产日韩欧美在线播放| 七七久久电影网| 日韩av中文在线| 国产成人av免费| 一区二区三区在线观看网站| 在线黄色免费网站| 日韩电影在线看| www.69av| 国产99久久精品一区二区300| 国产精品久久久久7777婷婷| √天堂8在线网| 日韩精品视频观看| 97超碰资源站| 婷婷激情综合网| 亚洲 欧美 国产 另类| 成人h版在线观看| 密臀av一区二区三区| 午夜欧美视频| 欧洲精品码一区二区三区免费看| 成人短视频软件网站大全app| 66m—66摸成人免费视频| av在线之家电影网站| 精品久久国产97色综合| 中文字幕一区二区三区波野结 | 天天天天天天天干| 一区二区三区在线观看动漫| 永久免费看mv网站入口78| 狠狠色综合色综合网络| 免费在线观看的av网站| 欧美一区二区三区另类| 茄子视频成人在线观看| 成人高潮视频| 91在线网站视频| 素人一区二区三区| 91精品国产91| 最近中文字幕免费mv2018在线| 亚洲九九九在线观看| 亚洲精品一区二区三区蜜桃| 欧美视频精品在线观看| 激情五月色婷婷| 亚洲精品午夜久久久| 亚洲无人区码一码二码三码的含义| 丁香婷婷综合激情五月色| 五月激情五月婷婷| 久久男女视频| 国产极品尤物在线| 中文在线日韩| 亚洲蜜桃av| 国产影视一区| 欧洲一区二区日韩在线视频观看免费 | 国产精品theporn88| 亚洲狼人综合| 国产精品国产三级国产aⅴ9色| h片在线观看视频免费| 欧美成人国产va精品日本一级| 成人福利在线| 尤物99国产成人精品视频| 青青色在线视频| 日韩电影中文字幕av| 亚洲精品无码专区| 日韩欧美国产综合| 国产激情视频在线播放| 日韩一级精品视频在线观看| 国产三级在线观看视频| 欧美日本一区二区在线观看| 91theporn国产在线观看| 欧美视频中文字幕| 中国a一片一级一片| 欧美亚洲免费在线一区| 精品国产青草久久久久96| 精品视频在线免费观看| 最近中文字幕免费观看| 欧美在线观看18| 在线观看日韩一区二区| 欧美日韩免费观看一区二区三区| 中文在线免费观看| 欧美高清视频www夜色资源网| 夜夜骚av一区二区三区| 欧美剧在线免费观看网站| 国产又粗又黄又爽的视频| 制服丝袜在线91| 亚洲精品成av人片天堂无码| 欧美r级在线观看| 天天躁日日躁狠狠躁伊人| 亚洲精品不卡在线| 国产一级在线| 精品国产美女在线| 在线观看的网站你懂的| 欧美激情视频一区二区三区不卡| japanese色国产在线看视频| 欧美在线免费视频| 88xx成人网| 91免费视频网站| 高潮按摩久久久久久av免费| 久久综合中文色婷婷| 国产一区二区三区不卡视频网站| 亚洲一区三区电影在线观看| 在线国产一区二区| 亚洲 高清 成人 动漫| 视频一区二区三区中文字幕| 福利视频999| 99精品国产一区二区三区不卡| 麻豆精品免费视频| 日韩一区在线免费观看| 日本三级理论片| 欧美亚洲高清一区二区三区不卡| 国产精品久久久久毛片| 精品国产乱码久久久久久免费 | www.日本xxxx| 国产一区视频在线看| aaaa黄色片| 国产精品视频一区二区三区不卡| 欧美日韩免费一区二区| 精品国产鲁一鲁一区二区张丽| 国内av在线播放| 亚洲精品在线三区| 国产福利在线观看| 久久久久久伊人| 高清在线一区| 国产主播一区二区三区四区| 大胆日韩av| 霍思燕三级露全乳照| 久久成人麻豆午夜电影| 日本少妇xxxx| 亚洲天堂精品视频| 日韩在线 中文字幕| 日韩一二三四区| 91在线品视觉盛宴免费| 97婷婷大伊香蕉精品视频| 亚洲国产一区二区久久| 蜜桃传媒视频第一区入口在线看| 亚洲天堂免费| 免费看污污网站| 91麻豆国产福利精品| 日韩a级片在线观看| 欧美视频你懂的| 青青草免费在线| 久久久久久久久久久91| 欧美日韩卡一| 日韩欧美国产二区| 99这里有精品| 国产精品果冻传媒| 亚洲日本电影在线| 中文字幕免费高清在线观看| 亚洲精品一区久久久久久| 狂野欧美性猛交xxxxx视频| 国产精品亚洲综合天堂夜夜| 中文字幕中文字幕精品| 2018国产在线| 国产99一区视频免费| 国产一区二区精彩视频| 欧美三级电影在线看| 国产原创av在线| 青青在线视频一区二区三区| 精品精品精品| 国产精品国产亚洲精品看不卡| 国产福利一区二区三区在线视频| av黄色免费在线观看| 欧美日韩免费一区二区三区视频| 好男人免费精品视频| 国产经典一区二区| 视频一区中文| 欧美日韩亚洲一二三| 久久久久久99久久久精品网站| 精品美女久久久久| 亚洲国产精品电影在线观看| 爱啪啪综合导航| 国产福利不卡| 一区在线免费| 中文字幕a在线观看| 亚洲成a人v欧美综合天堂下载| 性生交大片免费看女人按摩| 美女精品视频一区| 免费看一区二区三区| 男女裸体影院高潮| 国产成人亚洲综合a∨婷婷| 欧美日韩大片在线观看| 精品美女在线观看| 91精品国产黑色瑜伽裤| 精品网站在线看| 亚洲在线观看| 亚洲黄色免费视频| 欧美美女一区二区| av大全在线| 狠狠干一区二区| 丝袜诱惑制服诱惑色一区在线观看| 性欧美精品男男| 欧美精品日韩一区| 手机在线免费av| 快播亚洲色图| 欧美aaa在线| 色在线观看视频| 亚洲精品98久久久久久中文字幕| 日韩伦理精品| 亚洲最新在线| 国产成人精品www牛牛影视| 日韩欧美a级片| 亚洲视频在线视频| 大胆国模一区二区三区| 国产男女免费视频| 国产人成一区二区三区影院| 国产一区二区在线视频观看| 欧美精品videosex性欧美| 日韩成人一级| 欧美一级视频在线| 亚洲国产乱码最新视频 | 国产精品三级电影| 国产按摩一区二区三区| 91福利视频网| 五月久久久综合一区二区小说| 在线中文字日产幕| 欧美性色aⅴ视频一区日韩精品| 国产精品刘玥久久一区| 国产精品久久久久久久久久久久午夜片| 香蕉久久久久久久av网站| 999精品在线视频| 亚洲精品国产精品乱码不99按摩| 免费高清视频在线一区| 拔插拔插海外华人免费| 国产精品视频你懂的| 男人天堂一区二区| 国产在线视频欧美| 欧美专区18| 福利所第一导航| 东京干手机福利视频| 国产精品免费久久久| 亚洲黄网站黄| 暗呦丨小u女国产精品| 亚洲桃花岛网站| 波多野结衣欧美|