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

弱隔離級別 & 事務并發問題

數據庫
數據庫的研究者就對事務定義了隔離級別這個概念,也就是在高性能與正確性之間做一個權衡。

介紹弱隔離級別

為什么要有弱隔離級別

如果兩個事務操作的是不同的數據, 即不存在數據依賴關系, 則它們可以安全地并行執行。但是當出現某個事務修改數據而另一個事務同時要讀取該數據, 或者兩個事務同時修改相同數據時, 就會出現并發問題。

在應用程序的開發中,我們通常會利用鎖進行并發控制,確保臨界區的資源不會出現多個線程同時進行讀寫的情況,這其實就對應了事務的最高隔離級別:可串行化。可串行化隔離意味著數據庫保證事務的最終執行結果與串行 (即一次一個, 沒有任何并發) 執行結果相同。

那么為什么應用程序中可以提供可串行化的隔離級別,而數據庫卻不能呢?其實根本原因就是應用程序對臨界區大多是內存操作,而數據庫要保證持久性(Durability),需要把臨界區的數據持久化到磁盤,可是磁盤操作比內存操作要慢好幾個數量級,一次隨機訪問內存、 固態硬盤 和 機械硬盤,對應的操作時間分別為幾十納秒、幾十微秒和幾十毫秒,這會導致持有鎖的時間變長,對臨界區資源的競爭將會變得異常激烈,數據庫的性能則會大大降低。

所以,數據庫的研究者就對事務定義了隔離級別這個概念,也就是在高性能與正確性之間做一個權衡,相當于明確地告訴使用者,我們提供了正確性差一點但是性能好一點的模式,以及正確性好一點但是性能差一點的模式,使用者可以根據自己的業務場景來選擇一個合適的隔離級別。

弱隔離級別帶來的風險

弱隔離級別就是非串行化隔離級別。

較弱的隔離級別, 它可以防止某些并發問題,但并非全部的并發問題。

使用這些弱隔離級別,事務并發執行時,可能會出現異常情況,帶來一些難以捉摸的隱患,因此,我們需要了解弱隔離級別存在的并發問題以及如何防范存在的并發問題。 然后, 我們就可以使用所掌握的工具和方法來構建正確、 可靠的應用。

各種隔離級別

SQL-92 標準定義了 4 種事務的隔離級別:讀未提交(Read Uncommitted)、讀已提交(Read Committed)、可重復讀(Repeatable Read)和可串行化(Serializable),在后面的發展過程中,又增加了快照隔離級別(Snapshot Isolation)。

不同的弱隔離級別解決了不同的并發問題(正確性問題),同時也存在一些并發問題。

下面是各種隔離級別及對應的并發問題:

  • :heavy_check_mark:代表該隔離級別已解決該并發問題;
  • :x:代表該隔離級別未解決該并發問題。

SQL 標準對隔離級別的定義還是存在一些缺陷,某些定義模棱兩可,不夠精確,且不能做到與實現無關,所以上面的表格只是對常見的隔離級別并發問題的定義,你可以把它當成一個通用的標準參考。

當你使用某一個數據庫時,需要讀一下它的文檔,確定好它的每一種隔離級別具體的并發問題。

  • MySQL 的默認隔離級別為:可重復讀。
  • Oracle、PostgreSQL 的默認隔離級別為:讀已提交

事務并發執行時,存在的并發問題

如果兩個事務操作的是不同的數據, 即不存在數據依賴關系, 則它們可以安全地并行執行。但是當出現某個事務修改數據而另一個事務同時要讀取該數據, 或者兩個事務同時修改相同數據時, 就會出現并發問題。

并發問題總結:

  • 臟寫 :一個事務覆蓋了其他事務尚未提交的寫入。
  • 臟讀 :一個事務讀到了其他事務尚未提交的寫入。
  • 不可重復讀 :一個事務內,多次讀取同一個記錄的結果不一樣。
  • 更新丟失 :兩個事務同時執行“讀-修改-寫回”操作序列,事務 A 覆蓋了 事務 B 的寫入,但又沒有包含 事務 B 修改后的值,最終導致了部分更新數據發生了丟失。
  • 幻讀 :一個事務內,多次讀取滿足指定條件的數據,讀出來的結果不一樣。
  • 寫傾斜 :事務首先查詢數據,根據返回的結果而作出某些決定,然后修改數據庫。當事務提交時,支持決定的前提條件已不再成立。

臟寫

一個事務覆蓋了其他事務尚未提交的寫入。

臟讀

一個事務讀到了其他事務尚未提交的寫入。

舉例說明臟讀

事務 B 修改了 x,在事務 B 提交之前,事務 A 讀到了 x 修改后的數據。這時事務 B 回滾了,相當于事務 A 讀到了一個無效的數據(未實際提交到數據庫中的數據),事務 A 的讀就是臟讀。

不可重復讀

一個事務內,多次讀取同一個記錄的結果不一樣。(一個事務能夠讀到另一個事務對同一個記錄的修改)

舉例說明不可重復讀

事務 A 讀取了 x,然后事務 B 修改了 x 并提交。這時事務 A 再次讀取 x,發現兩次讀取同一個記錄的結果不一樣,這就是不可重復讀。

 

更新丟失

兩個事務同時執行“讀-修改-寫回”操作序列,事務 A 覆蓋了 事務 B 的寫入,但又沒有包含 事務 B 的修改,最終導致了部分更新數據發生了丟失。

舉例說明更新丟失

事務 A 先讀取某記錄,然后事務 B 再讀取某記錄,事務 B 修改并寫回,緊接著 事務 A 修改并寫入。事務 A 覆蓋了 事務 B 的寫入,但又沒有包含 事務 B 的修改,最終導致事務 B 的更新丟失了。

幻讀

一個事務內,多次讀取滿足指定條件的數據,讀出來的結果不一樣(一個事務能夠讀到另一個事務創建的滿足條件的記錄)

舉例說明幻讀

事務 A 讀取一組滿足條件 1 的數據,之后事務 B 創建了滿足條件 1 的數據,使其滿足條件 1 并提交,如果事務 A 用相同的 條件 1 再次讀取,得到一組不同于第一次讀取的數據。這就叫幻讀。

不可重復讀和幻讀都是一個事務內,多次執行相同的查詢,結果不一樣。那兩者有什么區別呢?

  • 幻讀 主要說的是,讀到了另一個事務的 insert 或者 update 的滿足條件的記錄
  • 不可重復讀 主要說的是,讀到了另一個事務對同一個記錄的 update

寫傾斜

寫傾斜就是:事務首先查詢數據,根據返回的結果而作出某些決定,然后修改數據庫。當事務提交時,支持決定的前提條件已不再成立。

如何防止并發問題

現在我們已經知道了每一個隔離級別可能會出現的并發問題,如果當前數據庫使用了某一個隔離級別,我們也知道這個隔離級別存在的并發問題,是否有辦法來避免并發問題呢?以及對于避免并發問題是如何實現的?

有些并發問題只能通過提升隔離級別來避免,接下來,我們就針對每一種并發問題一一討論。

防止臟寫

允許臟寫這種并發問題出現的數據庫基本上是不可用的。因此所有的隔離級別都不允許出現臟寫這種并發問題。

防止“臟寫”就意味著,寫數據庫時, 只會覆蓋已成功提交的數據。

防止臟寫通常的方式是推遲第二個寫請求,直到前面的事務完成提交(或者中止)。

數據庫通常采用行級鎖來防止臟寫:如果兩個事務同時嘗試寫入同一個對象時 ,以加鎖的方式來確保第二個寫入等待前面事務完成(包括中止或提交)。

這種鎖定是由處于讀已提交模式 ( 或更強的隔離級別) 的數據庫自動完成的。

防止臟讀

防止 “臟讀”就意味著,讀數據庫時, 只能看到已成功提交的數據。

如果業務中不能接受臟讀,那么隔離級別要在“讀已提交”隔離級別或者以上。

當有以下需求時,需要防止臟讀:

  • 如果事務需要進行多個操作更新多個對象,我們需要保證另一個事務或者應用層要么看到所有操作執行前的狀態,要么看到所有操作完成后的狀態,而不能看到部分操作完成的中間狀態。如果我們要提供這樣的保證,那么就必須防止臟讀。臟讀意味著另一個事務可能會看到部分更新, 而非全部,觀察到部分更新的數據可能會造成用戶的困惑。
  • 如果事務發生中止,則所有寫入操作都需要回滾,那么就必須防止臟讀,避免用戶觀察到一些稍后被回滾的數據, 而這些數據實際并未實際提交到數據庫中。

防止臟讀的解決方案:

  • 兩段鎖協議;
  • 存儲數據的舊版本和新版本。

一種選擇是使用和防止臟寫相同的鎖,所有試圖讀取該對象的事務必須先申請鎖,事務完成后釋放鎖,從而確保不會發生讀取到一個臟的、 未提交的值。

然而, 加鎖的方式在實際中并不可行, 因為運行時間較長的寫事務會導致許多只讀的事務等待太長時間, 這會嚴重影響只讀事務的響應時間。應用程序任何局部的性能問題會擴散,進而影響整個應用,產生連鎖反應。

因此, 大多數數據庫采用了下面的方式來防止臟讀:對于每個待更新的對象, 數據庫都會維護對象的兩個版本(其舊值 和 當前持鎖事務將要設置的新值)。在事務提交之前, 其他事務的讀操作都讀取舊值;僅當寫事務提交之后, 才會切換到讀取新值。而 MySQL 使用了多版本并發控制來防止臟讀,多版本比兩個版本更加通用。

防止不可重復讀

防止“不可重復讀”就意味著,一個事務執行過程中看到的數據,總是跟這個事務在啟動時看到的數據是一致的。

不能忍受不可重復讀的場景:

備份場景 :備份任務要復制整個數據庫,這可能需要花費幾小時才能完成。在備份過程中,數據可以繼續寫入數據庫。因此,備份里可能包含部分舊版本數據和部分新版本數據。 如果從這樣的備份進行恢復,那么就導致了永久性的不一致。

如果業務中不能接受不可重復讀,那么隔離級別要在“可重復讀”隔離級別或者以上。

在 MySQL 種,可重復讀隔離級別即快照級別隔離。快照級別隔離的總體想法是:每個事務總是在某個時間點的一致性快照中讀取數據。

為了實現快照級別隔離, MySQL 數據庫采用了一種被稱為多版本并發控制(MultiVersion Concurrency Control,MVCC)的機制。

防止更新丟失

更新丟失可能發生在這樣一個操作場景中:應用程序從數據庫讀取某些值,根據應用邏輯做出修改,然后寫回新值 (read-midify-write 過程)。當有兩個事務在同樣的數據對象上執行類似操作時,后一個寫操作并不包含前一個寫操作的修改,最終導致前一個寫操作的修改丟失。

更新丟失屬于寫事務并發沖突。

防止更新丟失,目前有多種可行的解決方案。

  • 原子更新操作:許多數據庫提供了原子更新操作,以避免在應用層代碼完成“讀-修改-寫回”操作序列,如果數據庫支持原子更新操作的話,通常這就是防止更新丟失最好的解決方案。
  • 原子操作通常采用對讀取對象加獨占鎖的方式來實現,這樣在更新被提交之前其他事務不可以讀取它。

原子操作的另一種實現方式是:強制所有的原子操作都在單線程上執行。這也是 Redis 防止更新丟失的解決方案

  • 顯式的加鎖:既然原子操作采用對讀取對象加獨占鎖的方式來實現,那么我們也可以顯式的鎖定待更新的對象,使“讀-修改-寫回”操作序列串行執行。例如使用 MySQL 的 select ...... for update;

原子更新操作和 顯式的加鎖 都是通過強制“讀-修改-寫回”操作序列串行執行來防止丟失更新。

自動檢測更新丟失 :先讓“讀-修改-寫回”操作序列并發執行,但如果事務管理器檢測到了更新丟失風險,則會中止當前事務,并強制回退到安全的“讀-修改-寫回”方式。

比較并設置 :先讓“讀-修改-寫回”操作序列并發執行,如果讀取的內容已經發生了變化且值與“舊內容”不匹配,則更新失敗,需要應用層再次檢查并在必要時進行重試。例如 update t1 set col1 = '新內容' where id = 1 and col1 = '舊內容';

自動檢測更新丟失

PostgreSQL 的可重復讀, Oracle 的可串行化以及 SQL Server 的快照級別隔離等,都可以自動檢測何時發生了更新丟失,然后會中止違規的那個事務。

但是, MySQL 中 InnoDB 存儲引擎的可重復讀卻并不支持自動檢測更新丟失。

防止幻讀 & 寫傾斜

防止幻讀:

  • 使用 可串行化隔離級別
  • 在 MySQL 的 可重復讀隔離級別下,使用 select ...... for update;

使用可串行化隔離級別可以防止幻讀。

可串行化隔離通常被認為是最強的隔離級別。使用可串行化隔離級別可以防止所有可能的競爭條件。

可串行化隔離保證即使事務可能會并行執行,但最終的執行結果與每次執行一個事務(即串行執行)的結果相同。

可串行化隔離級別的實現有以下幾種方式:

  • 實際串行執行:
  • 兩段鎖 + 索引區間鎖:將兩段鎖與索引區間鎖結合使用,實現可串行化隔離
  • 可串行化快照隔離:(這個暫時還沒有了解)

MySQL 的可串行化隔離級別使用了第 2 種方法(兩段鎖 + 索引區間鎖)

寫傾斜就是:事務首先查詢數據,根據返回的結果而作出某些決定,然后修改數據庫。當事務提交時,支持決定的前提條件已不再成立。寫傾斜可能發生在這樣一個操作場景中:

第一步 select:應用程序從數據庫讀取一組滿足條件 1 的數據

第二步 決定:根據查詢的結果,應用層代碼來決定下一步的操作(有可能繼續,或者報告錯誤井中止)

第三步 寫入:如果應用程序決定繼續執行,它將發起數據庫寫入(insert,update 或 delete)并提交事務。

而第 3 步的這個寫操作會改變第 2 步做出決定的前提條件,如果兩個事務并發執行這樣的“讀取-決定-寫入”操作序列,那么后一個寫入改變了前一個寫入執行的前提條件,導致出現意料之外的結果。

防止寫傾斜

對于寫傾斜問題,有幾種可能的解決方案:

只使用 可串行化隔離級別 即可避免寫傾斜(使用索引區間鎖,避免其他事務寫入滿足條件的行)

更改“讀取-決定-寫入”操作序列的執行順序 為 “寫入-讀取-決定”:先寫入,然后 select 查詢并加獨占鎖(select ...... for update),最后根據查詢的結果來決定是否提交或者放棄。

實體化沖突,也稱物化沖突:有的業務場景 select 查詢的是不滿足給定搜索條件的行(例如 select * from t1 where id != 1)如果第 1 步的查詢根本沒有返回任何行,則 select ...... for update 也就無從加鎖,只能考慮實體化沖突。

本質上這三種可能的解決方案都是對事務所依賴的行顯式的加鎖。

對于實體化沖突(物化沖突)的說明

如果問題的關鍵是查詢結果中沒有對象(空)可以加鎖,或許可以人為引人一些可加鎖的對象。這種方法稱為實體化沖突(或物化沖突),它把幻讀問題轉變為針對數據庫中一組具體行的鎖沖突問題。

然而,弄清楚如何實現實體化往往也具有挑戰性,實現過程也容易出錯,這種把一個并發控制機制降級為數據模型的思路總是不夠優雅。出于這些原因,除非萬不得己,沒有其他可選方案,不推薦采用實體化沖突。

責任編輯:張燕妮 來源: 博客園精華區
相關推薦

2022-08-11 07:55:05

數據庫Mysql

2012-02-02 15:57:09

HibernateJava

2010-11-19 16:13:06

oracle事務隔離級

2018-12-19 16:46:38

MySQL事務隔離數據庫

2009-06-29 17:54:47

Spring事務隔離

2021-07-26 10:28:13

MySQL事務隔離

2024-04-26 09:17:20

MySQL事務隔離

2021-08-04 13:19:42

MySQL 事務隔離

2021-01-18 11:49:26

面試事務隔離

2024-12-02 08:37:04

2025-03-03 08:20:00

MySQL事務隔離數據庫

2021-10-19 10:10:51

MySQL事務隔離級別數據庫

2022-09-19 06:16:23

事務隔離級別Spring

2023-10-11 08:09:53

事務隔離級別

2009-11-25 13:33:39

并發

2022-06-10 11:51:49

MySQL事務隔離

2025-01-13 13:12:54

2020-10-13 10:32:24

MySQL事務MVCC

2010-10-19 13:52:28

SQL Server事

2021-12-27 09:20:13

事務模式隔離
點贊
收藏

51CTO技術棧公眾號

日本道精品一区二区三区| 久久99国产精品成人| 日韩av综合中文字幕| 免费av网址在线| 成人在线视频成人| 国产精品中文有码| 欧美野外猛男的大粗鳮| 国产日产在线观看| 成人av动漫| 91福利区一区二区三区| av中文字幕av| 免费看男男www网站入口在线| 日本va欧美va精品| 久久久久久久久久亚洲| 中文字幕第20页| 手机视频在线观看| 日韩大片在线永久免费观看网站| 国产成人精品综合在线观看 | 在线观看黄色av| 夫妻av一区二区| 国产精品啪视频| 日韩av一二三区| 久久久久久久久丰满| 国产视频久久久久| 日韩精品xxx| av在线一区不卡| 精品成人av一区| 青青视频免费在线| 95在线视频| 91亚洲精品久久久蜜桃网站| 5566av亚洲| 亚洲一区二区色| 国产精品一卡| 欧美精品18videos性欧| 精品国产大片大片大片| 蜜臀av免费一区二区三区| 国内黄色精品| 91精品国产91久久久久久最新毛片 | 日本免费网站在线观看| 激情五月婷婷综合| 国产va免费精品高清在线观看| 91aaa在线观看| 亚洲国产精品日韩专区av有中文| 亚洲天堂第一页| 免费成人蒂法网站| 日韩精品一区二区三区中文在线| 欧美日韩三级一区| 日韩视频免费在线播放| 成人爽a毛片免费啪啪| 亚洲精品视频在线观看网站| 亚洲欧美国产精品桃花| 成人免费黄色网页| 久久亚洲综合av| 精品视频第一区| 神马午夜一区二区| 不卡一区二区三区四区| 国产精品二区在线| www.久久综合| 成人一区在线观看| 99伊人久久| 乱精品一区字幕二区| 国产成人免费视频精品含羞草妖精| 成人激情在线观看| 11024精品一区二区三区日韩| 美女在线视频一区| 国产日韩欧美在线视频观看| 国产99久久久久久免费看| 日韩精品一级中文字幕精品视频免费观看| 91国产美女视频| 天天操夜夜操视频| 久久精品盗摄| 国产精品亚洲美女av网站| 中文在线字幕av| 国模大尺度一区二区三区| 91欧美激情另类亚洲| 国产jzjzjz丝袜老师水多| 国产盗摄精品一区二区三区在线| 97超碰资源| 丁香花免费高清完整在线播放| 国产成人自拍在线| 国产日本一区二区三区| 日本韩国精品一区二区| 国产亚洲精品aa| 一区二区视频在线播放| 亚洲精品白浆| 婷婷夜色潮精品综合在线| 青青在线免费观看视频| 欧美成人家庭影院| 日韩精品一区二区在线| 北岛玲一区二区| 日韩久久精品| 欧美国产视频日韩| 国产免费av一区| 久久99国产精品久久99| 国产精品一区二| 触手亚洲一区二区三区| 一区二区三区在线观看网站| 日韩 欧美 视频| 三上悠亚激情av一区二区三区| 精品视频色一区| 亚洲一区和二区| 国产精品一区高清| 欧美猛男性生活免费| 久久久久在线视频| 国产美女一区二区三区| 欧美精品免费观看二区| 国产鲁鲁视频在线观看特色| 欧美日韩性视频在线| 亚洲精品久久久中文字幕| 大奶在线精品| 中文字幕精品一区久久久久| 免费毛片一区二区三区| 久久爱www久久做| 精品蜜桃一区二区三区| 男人的天堂在线视频免费观看| 亚洲成人激情综合网| 一区二区在线免费看| 亚洲精品动态| 欧美激情啊啊啊| 国产一区二区波多野结衣| 2020国产精品久久精品美国| 国产 国语对白 露脸| 2019年精品视频自拍| 欧美精品一区二| 波多野结衣不卡视频| 蜜桃视频在线观看一区二区| 久久综合九色99| 手机在线免费看av| 欧美精品色一区二区三区| 性欧美精品中出| 国产亚洲一区在线| 国产精品加勒比| 国产三级在线播放| 欧美色综合网站| 中文字幕丰满乱子伦无码专区| 狠狠色丁香久久综合频道| 国产一区红桃视频| jyzzz在线观看视频| 欧美性猛交xxxx乱大交| 99re久久精品国产| 亚洲国产国产亚洲一二三| 亚洲尤物视频网| 国产剧情在线| 91精品国产综合久久小美女 | 亚洲乱码国产乱码精品精的特点 | 懂色av一区二区三区四区五区| 色尼玛亚洲综合影院| 亚洲精品天天看| 国产在线观看黄色| 91丨九色丨黑人外教| 久草热视频在线观看| 成人av地址| 高清亚洲成在人网站天堂| 亚洲av少妇一区二区在线观看| 亚洲色图另类专区| 久久久久久国产精品日本| 91精品91| 亚洲精品日韩av| 羞羞电影在线观看www| 日韩视频免费观看高清完整版 | 日日碰狠狠添天天爽| 蜜臀av亚洲一区中文字幕| 亚洲高清123| **国产精品| 欧美成人激情在线| www.国产.com| 五月婷婷久久综合| 亚洲国产欧美视频| 日本午夜精品一区二区三区电影| 日韩欧美一区二区视频在线播放 | 欧美日韩国产a| 手机在线免费看毛片| 国产成人日日夜夜| www..com日韩| 偷拍视屏一区| 国产精品一区二区3区| 午夜伦理在线视频| 国产视频自拍一区| 中文区中文字幕免费看| 亚洲日本va午夜在线影院| 亚洲国产欧美日韩在线| 亚洲激情专区| 日韩国产在线一区| 亚洲黑人在线| 久久久久久免费精品| 日本护士...精品国| 欧美日高清视频| 久久精品波多野结衣| 97精品久久久久中文字幕| 无需播放器的av| 欧美日韩在线大尺度| 久久久久久久久久久一区| 四虎地址8848精品| 久久久久久久久久亚洲| 国产系列电影在线播放网址| 欧美一级国产精品| 男人天堂2024| 亚洲免费在线观看| 国产美女喷水视频| 国产在线视视频有精品| 成人在线观看你懂的| 手机亚洲手机国产手机日韩| 国产高清自拍一区| 78精品国产综合久久香蕉| 久久久久久国产精品美女| 国产免费永久在线观看| 日韩免费视频线观看| 波多野结衣视频免费观看| 一区二区三区四区亚洲| 亚洲一级黄色录像| av不卡一区二区三区| 国产精品嫩草影院8vv8| 香蕉视频成人在线观看| 伊人再见免费在线观看高清版| 亚洲肉体裸体xxxx137| caoporn国产精品免费公开| 成人免费在线观看视频| 欧美激情a在线| 成人日批视频| 中文字幕免费精品一区| 日韩a在线观看| 精品国产免费一区二区三区四区 | 奇米影视第四色777| 亚洲欧洲日韩一区二区三区| 中文字幕第3页| 国产美女久久久久| 无码少妇一区二区三区芒果| 亚洲免费成人| 丰满的少妇愉情hd高清果冻传媒 | 免费在线观看的av网站| 欧美视频在线观看| 色香蕉在线观看| 欧美综合视频| 欧美亚州在线观看| 日韩精品亚洲aⅴ在线影院| 高清国产在线一区| 国产情侣一区在线| 成人国产精品免费视频| 99只有精品| 国产精品色悠悠| 婷婷综合六月| 日韩av毛片网| 欧美精品在线网站| av在线免费网址| 日韩一区二区三区国产| av在线日韩国产精品| 亚洲香蕉伊综合在人在线视看 | 久久亚洲春色中文字幕久久久| 动漫美女无遮挡免费| 国产激情偷乱视频一区二区三区| 欧美特黄aaa| 国产一区999| 无套白嫩进入乌克兰美女| 激情五月婷婷综合| 97人人模人人爽人人澡| 国产成人免费视频精品含羞草妖精| 毛片毛片毛片毛片毛| 国产精品99久久久久久久女警| 亚洲天堂一区二区在线观看| 国内成人免费视频| 亚洲妇女无套内射精| 粉嫩av亚洲一区二区图片| 亚洲av无码专区在线播放中文| 成人动漫av在线| 亚洲最大免费视频| 久久久91精品国产一区二区精品 | 亚洲乱妇老熟女爽到高潮的片| 国产精品一品二品| 男女一区二区三区| 99国产一区二区三精品乱码| 成人免费毛片糖心| 国产精品久久久久婷婷| 欧美大片xxxx| 亚洲r级在线视频| 国产又黄又粗又爽| 日本道免费精品一区二区三区| 亚洲性在线观看| 日韩一区国产二区欧美三区| 欧美在线精品一区二区三区| 亚洲免费视频观看| 日本在线天堂| 欧美激情成人在线视频| 波多野结衣亚洲| 成人免费视频a| 韩国精品福利一区二区三区| 欧美日韩亚洲一区二区三区在线观看| 欧美日韩激情在线一区二区三区| www亚洲国产| 99精品国产一区二区青青牛奶 | 亚洲天堂av图片| 免费的黄网站在线观看| 久久久久国产一区二区三区| 户外露出一区二区三区| 99精彩视频在线观看免费| 日韩a级大片| 性欧美18一19内谢| 亚洲欧洲一区二区天堂久久| 在线观看亚洲色图| 成人性色生活片免费看爆迷你毛片| 亚洲第一香蕉网| 一区二区三区四区亚洲| 亚洲av无码不卡| 精品区一区二区| 男女网站在线观看| 最近2019中文字幕大全第二页| 变态调教一区二区三区| 成人在线国产精品| 夜夜春成人影院| 大地资源网在线观看免费官网| 丝袜a∨在线一区二区三区不卡| 九九九久久久久久久| 国产亚洲欧美中文| 久久久久香蕉视频| 欧美写真视频网站| 午夜影院在线视频| 欧美精品在线观看91| 久久91视频| 麻豆av一区二区| 一区在线视频| 亚洲欧美日韩网站| 欧美国产综合色视频| 国产精品久久久免费视频| 91精品国产综合久久精品图片| 国产日本在线| 久久免费精品视频| 精品亚洲二区| 亚洲最大色综合成人av| 久久资源在线| 国产精品久久无码| 亚洲综合免费观看高清完整版 | 日韩精品一区二区三区av| 精品日产一区2区三区黄免费 | 久久久久久久久久久91| 97精品资源在线观看| 亚洲五月六月| 日本aⅴ亚洲精品中文乱码| 变态另类丨国产精品| 午夜精品aaa| 免费国产羞羞网站视频| 欧美成人剧情片在线观看| 亚洲精品tv| 亚洲一区二区精品在线观看| 日本午夜一区二区| 欧美一区二区三区粗大| 在线中文字幕一区二区| 国产三级在线免费观看| 日韩av电影手机在线| 国产亚洲欧美日韩在线观看一区二区 | 少妇aaaaa| 欧美丰满一区二区免费视频| 日本在线视频观看| 国产欧美日韩免费| 欧美伦理影院| 亚洲国产高清av| 国产精品久线在线观看| 亚洲一区二区三区网站| 久久精品电影网| 精品伊人久久| 欧美这里只有精品| 成人精品免费网站| 特一级黄色大片| 亚洲品质视频自拍网| 日日夜夜天天综合| 杨幂一区欧美专区| 国产在线不卡一区| 久久久久久av无码免费网站| 亚洲成人av资源网| 中文字幕一区久| 亚洲午夜精品一区二区三区| 国模少妇一区二区三区| 久久久久久久国产精品毛片| 亚洲国产精品va在线看黑人| 天堂√8在线中文| 日韩免费一区二区三区| 麻豆高清免费国产一区| 国产午夜精品理论片| 精品久久人人做人人爰| 丝袜老师在线| 亚洲国产精品www| 粉嫩av一区二区三区粉嫩| 91久久国产综合久久91| 最近更新的2019中文字幕| 欧美日韩国产一区二区在线观看| 日韩极品视频在线观看 | 女人裸体性做爰全过| 在线成人av网站| av影院在线| 亚洲看片网站| 国产成人av自拍| 天堂网免费视频| 九九综合九九综合| 亚洲+小说+欧美+激情+另类 | 色成人综合网| 黄页网站在线观看视频| 91亚洲男人天堂| 国产精品国产三级国产aⅴ| 久久久久久亚洲精品| 亚洲宅男一区| 免费黄频在线观看| 精品久久久在线观看|