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

MySQL 核心模塊揭秘 | 鎖在內存里長什么樣?

數據庫 其他數據庫
InnoDB 的表鎖結構和行鎖結構,有一部分屬性是相同的,也有一部分屬性是專用的,所以,代碼里定義了三個結構體來描述表鎖結構和行鎖結構。

1. 共用的結構

InnoDB 的表鎖結構和行鎖結構,有一些共同屬性,也有一些不同屬性。

因為有共同屬性,表鎖結構和行鎖結構都使用結構體 lock_t 來表示鎖結構。

在 lock_t 之下,又定義了 lock_table_t、lock_rec_t 分別包含表鎖結構和行鎖結構的不同屬性。

為了更直觀的理解表鎖結構和行鎖結構,我們去掉 lock_t 的一些非核心信息之后,整理如下:

// storage/innobase/include/lock0priv.h
struct lock_t {
  trx_t *trx;
  UT_LIST_NODE_T(lock_t) trx_locks;
  dict_index_t *index;
  lock_t *hash;
  union {
    lock_table_t tab_lock;
    lock_rec_t rec_lock;
  };
  uint32_t type_mode;
};

雖然表鎖結構和行鎖結構都定義了自己的結構體,用于表示各自不同的屬性,但是 lock_t 中 index、hash 這兩個只用于行鎖結構的屬性,并沒有放入 lock_rec_t。

我們就不去追溯為什么這兩個屬性會放在 lock_t 中,而沒有放入 lock_rec_t 了。

2. type_mode

從屬性名上看,表鎖結構和行鎖結構的 type_mode 屬性存放的是鎖類型和鎖模式。

實際上,這個屬性比較復雜,它占用 4 字節,共 32 位,分為四個部分。

圖片圖片

第一部分,1 ~ 4 位,這 4 位是個整體,共同表示一個整數值,就是鎖模式。

  • 0(LOCK_IS),表級別的意向共享鎖。
  • 1(LOCK_IX),表級別的意向排他鎖。
  • 2(LOCK_S),表級別或行級別的共享鎖。
  • 3(LOCK_X),表級別或行級別的排他鎖。
  • 4(LOCK_AUTO_INC),表級別的 Auto-Inc 鎖。

鎖模式部分的 4 字節,作為一個整體使用,而沒有按位使用,這是有原因的。

按整體使用,4 字節的無符號整數最大值為 15,最多可以表示 15 種鎖模式。

按位使用,每位只能表示一種鎖模式,4 位只能表示 4 種鎖模式。

第二部分,5 ~ 8 位,按位使用,存放的是鎖類型。

  • 第 5 位標識是否為表鎖(LOCK_TABLE)。
  • 第 6 位標識是否為行鎖(LOCK_REC)。
  • 第 7 ~ 8 位,暫未使用。

第三部分,第 9 位,按位使用,存放的是鎖等待狀態(LOCK_WAIT),置為 0 表示已經獲得鎖,置為 1 表示處于鎖等待狀態。

第四部分,10 ~ 32 位,按位使用,存放的是鎖的精確模式,這部分只有行鎖和謂詞鎖會用到,表鎖不會用到。

  • 第 10 位用于標識間隙鎖(LOCK_GAP)。
  • 第 11 位用于標識普通記錄鎖(LOCK_REC_NOT_GAP)。
  • 第 12 位用于標識插入意向鎖(LOCK_INSERT_INTENTION)。
  • 第 13 位,暫未使用。
  • 第 14 ~ 15 位分別用于標識 LOCK_PREDICATE、LOCK_PRDT_PAGE,都屬于謂詞鎖。
  • 第 16 ~ 32 位,暫未使用。

看到這里,大家有沒有覺得奇怪,怎么沒有用于標識 Next-Key 的位置?

鎖模式為行鎖(LOCK_REC)時,如果 10 ~ 32 位中所有位都被設置為 0,就表示加的行鎖是 Next-Key 鎖。

3. 表鎖結構

lock_t 中,表鎖結構只使用 trx、trx_locks、type_mode 三個屬性,加上 lock_table_t 的 table、locks 屬性,就是表鎖結構的全部屬性了。

圖片圖片

MySQL 執行 DDL、DML 語句時,InnoDB 都會有對應的事務(用戶手動啟動或者 InnoDB 自動啟動)來執行這些語句對應的操作。

加鎖操作自然也是在事務中進行的,trx 屬性就是加這個表鎖的事務對象。

事務執行一條或多條 DML 語句,可能涉及多個表,也就有可能加多個表鎖。事務除了加表鎖,還有可能加行鎖,同一個事務加的一個或多個表鎖和一個或多個行鎖的鎖結構通過 trx_locks 屬性形成一個表鎖結構和行鎖結構混合的鏈表。

表鎖是加在表上的,自然就需要知道表鎖結構屬于哪個表了,table 屬性就是這個表鎖結構所屬的表對象。

同一時刻,可能有多個事務已經或者想要對同一個表加鎖。對于兼容的表鎖,多個事務可以同時加鎖,對于不兼容的表鎖,后加鎖的事務就會處于等待狀態。

事務想要對某個表加鎖,InnoDB 怎么判斷事務可以立即獲得鎖,還是要進入等待狀態?

這就是 locks 屬性的用武之地了。

多個事務對同一個表加了表鎖,這些表鎖的鎖結構會通過 locks 屬性形成一個鏈表。

事務想要對某個表加表鎖,InnoDB 就會遍歷這個鏈表。

如果鏈表中還沒有表鎖結構,或者所有鎖結構對應的表鎖都和事務當前要加的表鎖兼容,事務就可以立即獲得鎖,否則就需要進入等待狀態。

type_mode 屬性的第 5 位用于標識鎖結構是否為表鎖(LOCK_TABLE)。

對于表鎖,鎖結構中 type_mode 屬性的第 5 位會被設置為 1,第 1 ~ 4 位會寫入鎖模式對應的整數值。

如果事務不能立即獲得表鎖,type_mode 屬性的第 9 位會被設置為 1,表示處于鎖等待狀態。

4. 行鎖結構

lock_t 中,行鎖結構使用 trx、trx_locks、index、hash、type_mode 五個屬性,加上 lock_rec_t 的 page_id、n_bits 兩個屬性,外加行鎖結構最后外掛了一塊沒有屬性名的內存區域(我們暫且命名為 bitmap),就是行鎖的整體結構了。

圖片圖片

4.1 有名有姓的那些屬性

和表鎖結構一樣,行鎖結構里也有 trx 和 trx_locks 兩個屬性。

trx 屬性是加這個行鎖的事務對象。同一個事務加的一個或多個表鎖和一個或多個行鎖的鎖結構,通過 trx_locks 屬性形成一個表鎖結構和行鎖結構混合的鏈表。

主表的記錄存儲在主鍵索引中,二級索引(包括唯一索引、非唯一索引)的記錄存儲在二級索引中,行鎖都是對主鍵索引或二級索引的記錄加鎖。index 屬性就是這個行鎖結構所屬的索引對象。

InnoDB 可能同時有很多個事務在運行,這些事務加的行鎖,可能會產生多個行鎖結構。

每個行鎖結構都會根據 page_id 屬性中保存的表空間 ID、數據頁號計算得到一個哈希值。哈希值相同的多個行鎖結構通過 hash 屬性形成一個行鎖結構鏈表。

n_bits 屬性的值是個無符號整數,表示這個鎖結構能保存多少條記錄的行鎖狀態,也就是最多有多少記錄能共用這個行鎖結構。

對于行鎖,鎖結構中 type_mode 屬性的第 6 位會被設置為 1,第 1 ~ 4 位會被寫入鎖模式對應的整數值。

行鎖的不同精確模式,type_mode 屬性第四部分(10 ~ 32 位)各位的賦值情況如下:

  • 普通記錄鎖,type_mode 屬性的第 10 位會被設置為 1。
  • 間隙鎖,type_mode 屬性的第 11 位會被設置為 1。
  • 插入意向鎖,type_mode 屬性的第 12 位會被設置為 1。
  • Next-Key 鎖,type_mode 屬性的第 10 ~ 32 位都設置為 0。

如果事務不能立即獲得行鎖,type_mode 屬性的第 9 位會被設置為 1,表示處于鎖等待狀態。

4.2 隱姓埋名的內存區域

前面介紹的那些,都是 InnoDB 給取了名字的行鎖結構屬性。

還有一塊沒有名字的內存區域沒有介紹。在前面的行鎖結構圖中,我們給這塊內存區域取了個名字,為 bitmap。

bitmap 這塊內存區域是干嘛用的呢?

待我們細細說來。

我們先忽略 bitmap 內存區域的存在,假設一個事務對一條記錄加行鎖,會產生一個行鎖結構,對多條記錄加行鎖,就會產生多個行鎖結構。

又假設事務對多條記錄加的都是共享 Next-Key 鎖,并且已經獲得了鎖,巧合的是這些記錄又位于同一個數據頁,那么,這些鎖結構除了加鎖記錄不一樣,其它屬性的值都相同。

如果真這么設計行鎖結構,是不是太浪費內存空間了?

當然是了。雖然現在內存越來越便宜,但是畢竟還要花錢,也不能那么鋪張浪費。

本著勤儉節約的原則,InnoDB 把加鎖記錄不同、其它屬性值都相同的多個行鎖結構合并成一個,另外開辟一塊內存區域用于標識加鎖記錄,于是就有了我們命名為 bitmap 的內存區域。

bitmap 內存區域按位使用,每一位都用于標識事務是否對某條記錄加了行鎖。如果某一位被設置為 1,就表示事務對該位對應的記錄加了行鎖。

圖片圖片

上圖是事務對象初始化時,預先創建的一個行鎖結構的 bitmap 內存區域示意圖,大小為 256 字節,可以用于標識這個事務對 2048 條記錄加行鎖的情況。

示意圖中,第 3 位和第 5 位被設置為 1,說明事務對數據頁中序號為 0 和 4 的記錄加了行鎖。

沒有規矩不成方圓,InnoDB 不會胡亂的把多個行鎖結構合并成一個。

事務對多條記錄加行鎖,想要共用一個行鎖結構,需要同時滿足以下個條件:

  • 同一個事務對多條記錄加行鎖。
  • 這些記錄位于同一個數據頁中(也就是同一個表同一個索引的同一個數據頁)。
  • 這些行鎖的鎖模式相同,必須都是共享鎖,或者都是排他鎖。
  • 這些行鎖的精確模式相同,必須都是普通記錄鎖,或者都是間隙鎖,或者都是 Next-Key 鎖。
  • 這些行鎖都處于獲得鎖的狀態,不能處于鎖等待狀態。

4.3 共用行鎖結構的兩個問題

問題一:多個處于等待狀態的行鎖能共用一個鎖結構嗎?

理論上是可以的,但實際上不會出現這種情況。

因為共用一個行鎖結構需要滿足的條件之一,是一個事務對多條記錄加行鎖。

然而,一個事務對某條記錄加行鎖處于等待狀態,在獲得鎖或者鎖超時之前(不考慮異常情況),這個事務不會繼續往下執行。

這樣一來,一個事務在某一時刻,最多只有一個行鎖結構(對應一條記錄)處于等待狀態,也就不存在多個處于等待狀態的行鎖共用一個行鎖結構的情況了。

獲得鎖或者鎖等待超時之后,行鎖結構中 type_mode 的第 9 位就會被設置為 0,表示這個行鎖處于非等待狀態,后續在滿足共用條件的情況下,這個鎖結構才可以被共用。

問題二:多個插入意向鎖能共用一個鎖結構嗎?

同樣,理論上是可以的,但實際上不會出現這種情況。

首先,插入意向鎖的加鎖場景,是事務 T 想要在某條記錄前面的間隙插入一條記錄,而這個間隙被其它事務加了間隙鎖或者 Next-Key 鎖,導致事務 T 必須在這個間隙上加插入意向鎖,并等待其它事務釋放間隙鎖或者 Next-Key 鎖。

前面已經介紹過,處于等待狀態的行鎖結構,是不能共用的。

然后,事務 T 獲得鎖之后,它的精確模式為 LOCK_GAP + LOCK_INSERT_INTENTION,其它間隙鎖也不能共用這個鎖結構,因為間隙鎖的精確模式為 LOCK_GAP。

雖然插入意向鎖的鎖結構不能共用,會浪費一些內存,但好在加插入意向鎖的情況也不會非常多,浪費的內存也就不會太多。

5. 總結

InnoDB 的表鎖結構和行鎖結構,有一部分屬性是相同的,也有一部分屬性是專用的,所以,代碼里定義了三個結構體來描述表鎖結構和行鎖結構。

一個事務對每個表加表鎖,都會產生一個表鎖結構。

一個事務對多條記錄加行鎖,滿足條件時,多條記錄的行鎖可以共用一個行鎖結構,以節省內存。

處于等待狀態的行鎖結構,不能共用。獲得行鎖或者鎖等待超時之后,這個鎖結構會變為非等待狀態,之后滿足條件時,這個鎖結構可以被共用。

插入意向鎖的鎖結構不能共用。

責任編輯:武曉燕 來源: 愛可生開源社區
相關推薦

2024-06-05 11:49:33

2024-05-15 09:05:42

MySQL核心模塊

2024-04-03 08:20:53

MySQL核心模塊

2024-08-07 14:58:00

MySQL釋放鎖核心模塊

2024-08-28 08:50:11

MySQL核心模塊

2020-11-16 09:28:41

函數內存

2024-10-16 11:11:51

隔離InnoDB死鎖

2012-03-07 14:10:53

2024-03-27 13:33:00

MySQLInnoDB事務

2024-09-04 08:44:18

MySQL核心模塊

2015-04-08 10:40:09

2011-07-25 09:22:06

國防部操作系統Linux

2013-06-26 10:49:09

云端大腦科技技術

2011-07-26 09:32:59

操作系統

2024-10-30 10:38:08

2009-08-02 22:32:44

綜合布線系統

2025-02-26 08:26:38

2020-09-23 08:55:16

交換機配置網絡vlan

2019-05-13 15:45:29

程序員面試招聘

2013-09-24 09:52:24

點贊
收藏

51CTO技術棧公眾號

av成人在线观看| 亚洲三区在线播放| 亚洲国产日韩欧美在线| 欧美xfplay| 欧美精品色婷婷五月综合| av在线1区2区| 国产91丝袜在线观看| 欧美亚洲国产视频| 日本午夜在线观看| 最新精品国偷自产在线| 91精品一区二区三区在线观看| 国产精品久久久久9999爆乳| 91网在线播放| 成人激情小说网站| 国产综合福利在线| 在线观看黄网站| 欧美aⅴ99久久黑人专区| 亚洲精品视频免费在线观看| 91精品视频国产| 末成年女av片一区二区下载| 综合久久综合久久| 久久久久久久有限公司| 国产伦精品一区二区三区免.费| 最新国产乱人伦偷精品免费网站| 色婷婷久久一区二区| 久久偷拍免费视频| 91精品啪在线观看国产手机| 精品视频999| 黄www在线观看| 欧美草逼视频| 亚洲精品五月天| 少妇精品久久久久久久久久| 亚洲经典自拍| 你懂的国产精品| 亚洲精品国产品国语在线| 日韩在线不卡一区| 欧美xoxoxo| 亚洲国产日韩一区二区| 五月天男人天堂| h视频在线免费| 久久精品综合网| 久久99精品久久久久子伦| 黄色aaa大片| 国产成人亚洲综合色影视| 成人免费视频网址| 亚洲一区二区三区高清视频| 日韩av网站在线观看| 4438全国亚洲精品在线观看视频| 国产亚洲精品久久久久久无几年桃| 久久中文视频| 日韩亚洲精品视频| 在线观看天堂av| 欧美激情理论| 久久精品一区中文字幕| 亚洲色图27p| 久久社区一区| 久久精品久久精品亚洲人| 五月婷婷六月香| 无码一区二区三区视频| 久久精品亚洲94久久精品| 国产成人精品视频免费| 99国产精品免费视频观看| 色老头一区二区三区在线观看| www.日本高清视频| 99久久综合狠狠综合久久aⅴ| 伊人久久五月天| 日韩在线一卡二卡| 五月久久久综合一区二区小说| 久久精品精品电影网| 国模无码国产精品视频| 亚洲国产黄色| 欧美中文字幕精品| 中文字幕一区二区人妻痴汉电车| 免费不卡在线视频| 91久久久在线| 国精产品一品二品国精品69xx | 久久最新资源网| 日韩视频中文字幕在线观看| 欧美日韩国产一区精品一区| 久久全球大尺度高清视频| 久久黄色精品视频| 日韩1区2区3区| 91牛牛免费视频| 人妻妺妺窝人体色www聚色窝| 99精品欧美一区二区三区小说 | 黑人欧美xxxx| av丝袜天堂网| 欧美h版在线观看| 日韩精品免费在线观看| 日本黄区免费视频观看| 国产精品mv在线观看| 国产69久久精品成人看| 亚洲综合精品视频| 不卡av电影在线播放| 色狠狠久久av五月综合| 国产三级伦理在线| 欧美午夜视频网站| 亚洲精品国产成人av在线| 欧美日韩水蜜桃| 久精品免费视频| 真实新婚偷拍xxxxx| 国产成人自拍网| 日本视频一区二区不卡| 性欧美猛交videos| 色94色欧美sute亚洲13| 黄页网站在线看| 不卡一区综合视频| 午夜精品99久久免费| 91激情在线观看| 久久久久久久性| 欧美图片激情小说| 欧美一级做a| 亚洲免费福利视频| 国产网址在线观看| 国产一区二区三区在线看麻豆| 九九99玖玖| 2024短剧网剧在线观看| 欧美三级一区二区| 久久中文字幕人妻| 亚洲激情av| 亚洲专区在线视频| 日本在线观看www| 色吊一区二区三区| 国产精品果冻传媒| 伊人久久大香线蕉精品组织观看| 国产精品va在线播放| 污污网站免费在线观看| 一区二区三区欧美久久| mm131亚洲精品| 人人狠狠综合久久亚洲婷| 青草青草久热精品视频在线网站| 性欧美8khd高清极品| 综合电影一区二区三区| 国产超碰在线播放| 国产一区日韩| 国产成人精品a视频一区www| 日韩一二三四| 精品久久久中文| 国产精品第七页| 夜夜夜久久久| 激情小说综合网| av剧情在线观看| 欧美一级黄色大片| 亚洲成人生活片| 国产精品 欧美精品| 亚洲黄色网址在线观看| 精品视频在线播放一区二区三区| 久久久国产91| 99久久婷婷国产一区二区三区| 国产精品久久久久久亚洲伦 | 亚洲精品白虎| 久久女人天堂| 久久久成人精品| 精品人妻一区二区三区麻豆91 | 99久久伊人精品| 久久久久久久久久久99| 老司机aⅴ在线精品导航| 午夜免费日韩视频| 免费一级在线观看播放网址| 一本到三区不卡视频| 色欲狠狠躁天天躁无码中文字幕 | 国产精品91在线| 国产乱视频在线观看| 欧美性生活久久| 中文字幕在线观看2018| 成人网页在线观看| 日韩免费视频播放| 国产欧美日韩在线一区二区| 国产美女久久精品香蕉69| 国产激情视频在线| 精品久久一区二区三区| 精品美女久久久久| 国产精品狼人久久影院观看方式| www.久久av.com| 国产精品v日韩精品v欧美精品网站| 国产精品推荐精品| 成人在线爆射| 久久久国产精品x99av | 亚洲视频在线观看视频| 伊人精品在线视频| 亚洲男人的天堂在线观看| 扒开伸进免费视频| 老司机免费视频久久| 自拍偷拍99| 欧美韩一区二区| 国产精品老女人精品视频| 午夜伦理大片视频在线观看| 日韩电影大片中文字幕| 中文字幕第315页| 亚洲一区视频在线观看视频| 中文字幕成人动漫| 国产成人欧美日韩在线电影| 国产综合免费视频| 综合一区二区三区| 免费久久久一本精品久久区| 国产一区二区三区免费观看在线 | 日韩视频永久免费观看| 空姐吹箫视频大全| 欧美在线小视频| 五月天综合在线| 中文字幕在线观看不卡视频| 欲求不满的岳中文字幕| 久久精品久久精品| 男人日女人逼逼| 欧美一区综合| 午夜视频久久久| 牛牛视频精品一区二区不卡| 91欧美精品成人综合在线观看| 色一区二区三区| 欧美国产高跟鞋裸体秀xxxhd| 高清福利在线观看| 日韩精品一二三四区| 国产免费的av| 欧美无人高清视频在线观看| 黄色片视频网站| 亚洲精品视频一区二区| 精品人体无码一区二区三区| 91麻豆免费观看| av电影在线播放| 国产成人av一区| 午夜免费看毛片| 日韩激情av在线| 国产午夜福利在线播放| 国产精品videossex久久发布| 中文字幕超清在线免费观看| 精品理论电影| 欧美另类一区| 天堂在线精品| 久久99精品久久久水蜜桃| 成人动态视频| 91精品在线观看视频| 欧美91在线|欧美| 国产精品久久中文| 日韩免费电影| 青青草99啪国产免费| 高清精品在线| 91精品国产91久久久久| 18video性欧美19sex高清| 色综合视频一区中文字幕| av在线影院| 美女国内精品自产拍在线播放| 成人a在线视频免费观看| 北条麻妃一区二区三区中文字幕 | 欧美高跟鞋交xxxxhd| 51xtv成人影院| 欧美激情中文字幕乱码免费| 污污视频在线看| 欧美高清第一页| 污污影院在线观看| 午夜精品一区二区三区在线播放| 美女日批视频在线观看| 久久青草福利网站| 在线看片国产福利你懂的| 8090成年在线看片午夜| 热色播在线视频| 国产成人av在线播放| 欧美国产日韩电影| 成人看片人aa| 精品国产三级| 国产不卡一区二区三区在线观看| 91精品尤物| 精品一区久久久久久| 久久99国产成人小视频| 亚洲欧美日韩不卡一区二区三区| 久久免费精品视频在这里| 成年在线观看视频| 亚洲影院在线| 91插插插插插插插插| 国产精品中文字幕日韩精品 | 国产欧美日韩不卡| av资源在线免费观看| 亚洲视频在线一区| 久久综合久久鬼| 欧美午夜激情在线| 在线观看黄色网| 精品少妇一区二区三区在线播放| 日韩国产福利| 色老头一区二区三区在线观看| 欧美aaaaaaa| 清纯唯美日韩制服另类| 日韩三区四区| 国产一区二区三区四区五区在线| 夜夜春成人影院| 国产福利片一区二区| 亚洲国产午夜| 在线免费观看视频黄| 国产91高潮流白浆在线麻豆| 色一情一交一乱一区二区三区| 最新国产成人在线观看| 亚州国产精品视频| 欧美人与禽zozo性伦| 黄色片一区二区三区| 色妞欧美日韩在线| freexxx性亚洲精品| 国产精品日韩一区| 电影一区二区在线观看| 亚洲精品二区| 国产精品日韩欧美一区| 欧美视频亚洲图片| 91年精品国产| 九九九在线视频| 日本久久电影网| 丰满少妇一级片| 日韩中文有码在线视频| 免费高潮视频95在线观看网站| 国产原创欧美精品| 五月天亚洲一区| 97碰在线视频| 国模无码大尺度一区二区三区 | 国产精品不卡一区二区三区| 日韩乱码人妻无码中文字幕| 欧美男生操女生| 激情小视频在线观看| 欧美黑人一级爽快片淫片高清| 粉嫩av一区二区三区四区五区 | 欧美xxxxx精品| 亚洲欧洲精品一区二区三区不卡| 精品免费囯产一区二区三区| 欧美成人a视频| 国产激情在线观看| 国产精品一区二区久久久| 亚洲黄页网站| 欧美 丝袜 自拍 制服 另类| 国产98色在线|日韩| 欧产日产国产v| 欧美电影在线免费观看| 91社区在线高清| 国产精品国产三级国产专播精品人| 免费成人三级| av免费观看大全| 成人三级在线视频| 青青操国产视频| 欧美一区二区久久| 欧洲日本在线| 国产日韩中文字幕| 日韩av久操| 亚洲国产日韩欧美在线观看| 国产视频一区不卡| 国产一级淫片a视频免费观看| 亚洲精品日韩在线| 手机av在线| 欧美日韩一区二| 美女黄色成人网| 中文字幕免费视频| 日韩欧美黄色动漫| 九一国产在线| 国产精品第8页| 日产精品一区二区| 加勒比av中文字幕| 亚洲乱码中文字幕综合| www.av黄色| 97成人精品视频在线观看| 亚洲精品一级二级三级| 国产一区二区视频免费在线观看| 久久久美女艺术照精彩视频福利播放| 男人天堂2024| 伊人精品在线观看| 国产精品一区二区精品| bt天堂新版中文在线地址| 国产91精品免费| 91video| 伊人久久久久久久久久| 成人乱码手机视频| 日韩成人三级视频| 99视频精品全部免费在线| 中文字幕一区在线播放| 中文字幕亚洲天堂| 国产一区二区三区精品在线观看| 69sex久久精品国产麻豆| 91香蕉视频在线| 中文字幕免费观看视频| 欧美精品免费在线观看| 麻豆成人入口| 特级丰满少妇一级| 亚洲综合免费观看高清完整版| 视频在线观看你懂的| 国产精品视频午夜| 欧美日韩亚洲一区二区三区在线| 欧美深性狂猛ⅹxxx深喉| 欧美日韩国产首页| 黄视频在线免费看| 欧美日韩亚洲免费| 韩日欧美一区二区三区| 人人干人人干人人干| 中文在线不卡视频| 国内精品国产成人国产三级粉色| 91在线视频观看免费| 亚洲午夜三级在线| 国产小视频在线播放| 99re在线观看视频| 秋霞国产午夜精品免费视频| 久久久久久久久久久久久久免费看| 日韩精品在线观| 精品一区二区三区中文字幕视频| 国产成人精品视频免费看| 国产精品国产三级国产普通话三级| 亚洲精品成人电影| 国产精品免费看久久久香蕉| 亚洲精品一二| 黄色一级片中国|