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

如何保證數據庫和緩存雙寫一致性?

數據庫 其他數據庫
今天這篇文章我會從淺入深,跟大家一起聊聊,數據庫和緩存雙寫數據一致性問題常見的解決方案,這些方案中可能存在的坑,以及最優方案是什么。

大家好,我是蘇三,又跟大家見面了。

前言

數據庫和緩存(比如:redis)雙寫數據一致性問題,是一個跟開發語言無關的公共問題。尤其在高并發的場景下,這個問題變得更加嚴重。

我很負責的告訴大家,該問題無論在面試,還是工作中遇到的概率非常大,所以非常有必要跟大家一起探討一下。

今天這篇文章我會從淺入深,跟大家一起聊聊,數據庫和緩存雙寫數據一致性問題常見的解決方案,這些方案中可能存在的坑,以及最優方案是什么。

1、 常見方案

通常情況下,我們使用緩存的主要目的是為了提升查詢的性能。大多數情況下,我們是這樣使用緩存

的:

  1. 用戶請求過來之后,先查緩存有沒有數據,如果有則直接返回。
  2. 如果緩存沒數據,再繼續查數據庫。
  3. 如果數據庫有數據,則將查詢出來的數據,放入緩存中,然后返回該數據。
  4. 如果數據庫也沒數據,則直接返回空。

這是緩存非常常見的用法。一眼看上去,好像沒有啥問題。

但你忽略了一個非常重要的細節:如果數據庫中的某條數據,放入緩存之后,又立馬被更新了,那么該如何更新緩存呢?

不更新緩存行不行?

答:當然不行,如果不更新緩存,在很長的一段時間內(決定于緩存的過期時間),用戶請求從緩存中獲取到的都可能是舊值,而非數據庫的最新值。這不是有數據不一致的問題?

那么,我們該如何更新緩存呢?

目前有以下4種方案:

  1. 先寫緩存,再寫數據庫。
  2. 先寫數據庫,再寫緩存。
  3. 先刪緩存,再寫數據庫。
  4. 先寫數據庫,再刪緩存。

接下來,我們詳細說說這4種方案。

2、先寫緩存,再寫數據庫

對于更新緩存的方案,很多人第一個想到的可能是在寫操作中直接更新緩存(寫緩存),更直接明了。

那么,問題來了:在寫操作中,到底是先寫緩存,還是先寫數據庫呢?

我們在這里先聊聊先寫緩存,再寫數據庫的情況,因為它的問題最嚴重。

某一個用戶的每一次寫操作,如果剛寫完緩存,突然網絡出現了異常,導致寫數據庫失敗了。

其結果是緩存更新成了最新數據,但數據庫沒有,這樣緩存中的數據不就變成臟數據了?如果此時該用戶的查詢請求,正好讀取到該數據,就會出現問題,因為該數據在數據庫中根本不存在,這個問題非常嚴重。

我們都知道,緩存的主要目的是把數據庫的數據臨時保存在內存,便于后續的查詢,提升查詢速度。

但如果某條數據,在數據庫中都不存在,你緩存這種“假數據”又有啥意義呢?

因此,先寫緩存,再寫數據庫的方案是不可取的,在實際工作中用得不多。

3、 先寫數據庫,再寫緩存

既然上面的方案行不通,接下來,聊聊先寫數據庫,再寫緩存的方案,該方案在低并發編程中有人在用(我猜的)。 用戶的寫操作,先寫數據庫,再寫緩存,可以避免之前“假數據”的問題。但它卻帶來了新的問題。

什么問題呢?

(1)寫緩存失敗了

如果把寫數據庫和寫緩存操作,放在同一個事務當中,當寫緩存失敗了,我們可以把寫入數據庫的數據進行回滾。

如果是并發量比較小,對接口性能要求不太高的系統,可以這么玩。

但如果在高并發的業務場景中,寫數據庫和寫緩存,都屬于遠程操作。為了防止出現大事務,造成的死鎖問題,通常建議寫數據庫和寫緩存不要放在同一個事務中。

也就是說在該方案中,如果寫數據庫成功了,但寫緩存失敗了,數據庫中已寫入的數據不會回滾。

這就會出現:數據庫是新數據,而緩存是舊數據,兩邊數據不一致的情況。

(2) 高并發下的問題

假設在高并發的場景中,針對同一個用戶的同一條數據,有兩個寫數據請求:a和b,它們同時請求到業務系統。

其中請求a獲取的是舊數據,而請求b獲取的是新數據,如下圖所示:

  1. 請求a先過來,剛寫完了數據庫。但由于網絡原因,卡頓了一下,還沒來得及寫緩存。
  2. 這時候請求b過來了,先寫了數據庫。
  3. 接下來,請求b順利寫了緩存。
  4. 此時,請求a卡頓結束,也寫了緩存。

很顯然,在這個過程當中,請求b在緩存中的新數據,被請求a的舊數據覆蓋了。

也就是說:在高并發場景中,如果多個線程同時執行先寫數據庫,再寫緩存的操作,可能會出現數據庫是新值,而緩存中是舊值,兩邊數據不一致的情況。

(3) 浪費系統資源

該方案還有一個比較大的問題就是:每個寫操作,寫完數據庫,會馬上寫緩存,比較浪費系統資源。

為什么這么說呢?

你可以試想一下,如果寫的緩存,并不是簡單的數據內容,而是要經過非常復雜的計算得出的最終結果。這樣每寫一次緩存,都需要經過一次非常復雜的計算,不是非常浪費系統資源嗎?

尤其是cpu和內存資源。

還有些業務場景比較特殊:寫多讀少。

如果在這類業務場景中,每個用的寫操作,都需要寫一次緩存,有點得不償失。

由此可見,在高并發的場景中,先寫數據庫,再寫緩存,這套方案問題挺多的,也不太建議使用。

如果你已經用了,趕緊看看踩坑了沒?

4、 先刪緩存,再寫數據庫

通過上面的內容我們得知,如果直接更新緩存的問題很多。

那么,為何我們不能換一種思路:不去直接更新緩存,而改為刪除緩存呢?

刪除緩存方案,同樣有兩種:

  1. 先刪緩存,再寫數據庫。
  2. 先寫數據庫,再刪緩存。

我們一起先看看:先刪緩存,再寫數據庫的情況。

說白了,在用戶的寫操作中,先執行刪除緩存操作,再去寫數據庫。這套方案,可以是可以,但也會有一樣問題。

(1)高并發下的問題

假設在高并發的場景中,同一個用戶的同一條數據,有一個讀數據請求c,還有另一個寫數據請求d(一個更新操作),同時請求到業務系統。如下圖所示:

  1. 請求d先過來,把緩存刪除了。但由于網絡原因,卡頓了一下,還沒來得及寫數據庫。
  2. 這時請求c過來了,先查緩存發現沒數據,再查數據庫,有數據,但是舊值。
  3. 請求c將數據庫中的舊值,更新到緩存中。
  4. 此時,請求d卡頓結束,把新值寫入數據庫。

在這個過程當中,請求d的新值并沒有被請求c寫入緩存,同樣會導致緩存和數據庫的數據不一致的情況。

那么,這種場景的數據不一致問題,能否解決呢?

(2) 緩存雙刪

在上面的業務場景中,一個讀數據請求,一個寫數據請求。當寫數據請求把緩存刪了之后,讀數據請求,可能把當時從數據庫查詢出來的舊值,寫入緩存當中。

有人說還不好辦,請求d在寫完數據庫之后,把緩存重新刪一次不就行了?

這就是我們所說的緩存雙刪,即在寫數據庫之前刪除一次,寫完數據庫后,再刪除一次。

該方案有個非常關鍵的地方是:第二次刪除緩存,并非立馬就刪,而是要在一定的時間間隔之后。

我們再重新回顧一下,高并發下一個讀數據請求,一個寫數據請求導致數據不一致的產生過程:

  1. 請求d先過來,把緩存刪除了。但由于網絡原因,卡頓了一下,還沒來得及寫數據庫。
  2. 這時請求c過來了,先查緩存發現沒數據,再查數據庫,有數據,但是舊值。
  3. 請求c將數據庫中的舊值,更新到緩存中。
  4. 此時,請求d卡頓結束,把新值寫入數據庫。
  5. 一段時間之后,比如:500ms,請求d將緩存刪除。

這樣來看確實可以解決緩存不一致問題。

那么,為什么一定要間隔一段時間之后,才能刪除緩存呢?

請求d卡頓結束,把新值寫入數據庫后,請求c將數據庫中的舊值,更新到緩存中。

此時,如果請求d刪除太快,在請求c將數據庫中的舊值更新到緩存之前,就已經把緩存刪除了,這次刪除就沒任何意義。必須要在請求c更新緩存之后,再刪除緩存,才能把舊值及時刪除了。

所以需要在請求d中加一個時間間隔,確保請求c,或者類似于請求c的其他請求,如果在緩存中設置了舊值,最終都能夠被請求d刪除掉。

接下來,還有一個問題:如果第二次刪除緩存時,刪除失敗了該怎么辦?

這里先留點懸念,后面會詳細說。

5、 先寫數據庫,再刪緩存

從前面得知,先刪緩存,再寫數據庫,在并發的情況下,也可能會出現緩存和數據庫的數據不一致的情況。

那么,我們只能寄希望于最后的方案了。

接下來,我們重點看看先寫數據庫,再刪緩存的方案。

在高并發的場景中,有一個讀數據請求,有一個寫數據請求,更新過程如下:

  1. 請求e先寫數據庫,由于網絡原因卡頓了一下,沒有來得及刪除緩存。
  2. 請求f查詢緩存,發現緩存中有數據,直接返回該數據。
  3. 請求e刪除緩存。

在這個過程中,只有請求f讀了一次舊數據,后來舊數據被請求e及時刪除了,看起來問題不大。

但如果是讀數據請求先過來呢?

  1. 請求f查詢緩存,發現緩存中有數據,直接返回該數據。
  2. 請求e先寫數據庫。
  3. 請求e刪除緩存。

這種情況看起來也沒問題呀?

答:對的。

但就怕出現下面這種情況,即緩存自己失效了。如下圖所示:

  1. 緩存過期時間到了,自動失效。
  2. 請求f查詢緩存,發緩存中沒有數據,查詢數據庫的舊值,但由于網絡原因卡頓了,沒有來得及更新緩存。
  3. 請求e先寫數據庫,接著刪除了緩存。
  4. 請求f更新舊值到緩存中。

這時,緩存和數據庫的數據同樣出現不一致的情況了。

但這種情況還是比較少的,需要同時滿足以下條件才可以:

  1. 緩存剛好自動失效。
  2. 請求f從數據庫查出舊值,更新緩存的耗時,比請求e寫數據庫,并且刪除緩存的還長。

我們都知道查詢數據庫的速度,一般比寫數據庫要快,更何況寫完數據庫,還要刪除緩存。所以絕大多數情況下,寫數據請求比讀數據情況耗時更長。

由此可見,系統同時滿足上述兩個條件的概率非常小。

推薦大家使用先寫數據庫,再刪緩存的方案,雖說不能100%避免數據不一致問題,但出現該問題的概率,相對于其他方案來說是最小的。

但在該方案中,如果刪除緩存失敗了該怎么辦呢?

6、 刪緩存失敗怎么辦?

先寫數據庫,再刪緩存的方案,跟緩存雙刪的方案一樣,有一個共同的風險點,即:如果緩存刪除失敗了,也會導致緩存和數據庫的數據不一致。

那么,刪除緩存失敗怎么辦呢?

答:需要加重試機制。

在接口中如果更新了數據庫成功了,但更新緩存失敗了,可以立刻重試3次。如果其中有任何一次成功,則直接返回成功。如果3次都失敗了,則寫入數據庫,準備后續再處理。

當然,如果你在接口中直接同步重試,該接口并發量比較高的時候,可能有點影響接口性能。

這時,就需要改成異步重試了。

異步重試方式有很多種,比如:

  1. 每次都單獨起一個線程,該線程專門做重試的工作。但如果在高并發的場景下,可能會創建太多的線程,導致系統OOM問題,不太建議使用。
  2. 將重試的任務交給線程池處理,但如果服務器重啟,部分數據可能會丟失。
  3. 將重試數據寫表,然后使用elastic-job等定時任務進行重試。
  4. 將重試的請求寫入mq等消息中間件中,在mq的consumer中處理。
  5. 訂閱mysql的binlog,在訂閱者中,如果發現了更新數據請求,則刪除相應的緩存。

7、 定時任務

使用定時任務重試的具體方案如下:

當用戶操作寫完數據庫,但刪除緩存失敗了,需要將用戶數據寫入重試表中。如下圖所示:

在定時任務中,異步讀取重試表中的用戶數據。重試表需要記錄一個重試次數字段,初始值為0。然后重試5次,不斷刪除緩存,每重試一次該字段值+1。如果其中有任意一次成功了,則返回成功。如果重試了5次,還是失敗,則我們需要在重試表中記錄一個失敗的狀態,等待后續進一步處理。

在高并發場景中,定時任務推薦使用elastic-job。相對于xxl-job等定時任務,它可以分片處理,提升處理速度。同時每片的間隔可以設置成:1,2,3,5,7秒等。

如果大家對定時任務比較感興趣的話,可以看看我的另一篇文章《學會這10種定時任務,我有點飄了》,里面列出了目前最主流的定時任務。

使用定時任務重試的話,有個缺點就是實時性沒那么高,對于實時性要求特別高的業務場景,該方案不太適用。但是對于一般場景,還是可以用一用的。

但它有一個很大的優點,即數據是落庫的,不會丟數據。

8、mq

在高并發的業務場景中,mq(消息隊列)是必不可少的技術之一。它不僅可以異步解耦,還能削峰填谷。對保證系統的穩定性是非常有意義的。

對mq有興趣的朋友可以看看我的另一篇文章《mq的那些破事兒》。

mq的生產者,生產了消息之后,通過指定的topic發送到mq服務器。然后mq的消費者,訂閱該topic的消息,讀取消息數據之后,做業務邏輯處理。

使用mq重試的具體方案如下:

  1. 當用戶操作寫完數據庫,但刪除緩存失敗了,產生一條mq消息,發送給mq服務器。
  2. mq消費者讀取mq消息,重試5次刪除緩存。如果其中有任意一次成功了,則返回成功。如果重試了5次,還是失敗,則寫入死信隊列中。
  3. 推薦mq使用rocketmq,重試機制和死信隊列默認是支持的。使用起來非常方便,而且還支持順序消息,延遲消息和事務消息等多種業務場景。

當然在該方案中,刪除緩存可以完全走異步。即用戶的寫操作,在寫完數據庫之后,不用立刻刪除一次緩存。而直接發送mq消息,到mq服務器,然后有mq消費者全權負責刪除緩存的任務。

因為mq的實時性還是比較高的,因此改良后的方案也是一種不錯的選擇。

9、 binlog

前面我們聊過的,無論是定時任務,還是mq(消息隊列),做重試機制,對業務都有一定的侵入性。

在使用定時任務的方案中,需要在業務代碼中增加額外邏輯,如果刪除緩存失敗,需要將數據寫入重試表。

而使用mq的方案中,如果刪除緩存失敗了,需要在業務代碼中發送mq消息到mq服務器。

其實,還有一種更優雅的實現,即監聽binlog,比如使用:canal等中間件。

具體方案如下:

  1. 在業務接口中寫數據庫之后,就不管了,直接返回成功。
  2. mysql服務器會自動把變更的數據寫入binlog中。
  3. binlog訂閱者獲取變更的數據,然后刪除緩存。

這套方案中業務接口確實簡化了一些流程,只用關心數據庫操作即可,而在binlog訂閱者中做緩存刪除工作。

但如果只是按照圖中的方案進行刪除緩存,只刪除了一次,也可能會失敗。

如何解決這個問題呢?

答:這就需要加上前面聊過的重試機制了。如果刪除緩存失敗,寫入重試表,使用定時任務重試。或者寫入mq,讓mq自動重試。

在這里推薦使用mq自動重試機制。

在binlog訂閱者中如果刪除緩存失敗,則發送一條mq消息到mq服務器,在mq消費者中自動重試5次。如果有任意一次成功,則直接返回成功。如果重試5次后還是失敗,則該消息自動被放入死信隊列,后面可能需要人工介入。

責任編輯:姜華 來源: 蘇三說技術
相關推薦

2022-04-01 16:55:22

數據庫緩存日志

2020-09-03 09:45:38

緩存數據庫分布式

2021-06-11 09:21:58

緩存數據庫Redis

2022-12-05 08:24:32

mongodb數據庫數據

2018-05-16 16:10:28

數據庫緩存MySQL

2024-10-28 12:41:25

2022-03-29 10:39:10

緩存數據庫數據

2024-12-26 15:01:29

2020-06-01 22:09:48

緩存緩存同步緩存誤用

2024-01-22 08:52:00

AQS雙異步數據一致性

2022-02-23 09:17:09

數據庫分離變更

2025-04-27 08:52:21

Redis數據庫緩存

2021-12-01 08:26:27

數據庫緩存技術

2022-10-19 12:22:53

并發扣款一致性

2019-08-30 12:46:10

并發扣款查詢SQL

2025-03-27 08:20:54

2023-09-07 08:11:24

Redis管道機制

2021-06-04 09:56:12

RedisMySQL美團

2024-08-06 09:42:23

2022-12-14 08:23:30

點贊
收藏

51CTO技術棧公眾號

欧美a v在线播放| 欧美日本中文字幕| 大荫蒂性生交片| 97免费观看视频| 天天色天天射综合网| 日韩一级片在线观看| 成人黄色片免费| 性生交生活影碟片| 国产日韩免费| 中文字幕久久久| 亚洲色图欧美自拍| 国产精选在线| 欧美国产成人在线| 亚洲xxxx视频| 日韩av电影网| 精品国产一区二区三区av片| 5566中文字幕一区二区电影| 人妻无码久久一区二区三区免费 | 国内精品美女在线观看| 亚洲国产精品999| 日本www.色| 日韩影视在线| 国产视频一区二区三区在线观看| 国产欧美婷婷中文| 国产一级特黄a高潮片| 经典一区二区| 日韩欧美国产一区二区在线播放 | 免费在线性爱视频| 国产一区免费电影| 日本精品免费一区二区三区| 欧美h片在线观看| 日本国产精品| 欧美人妇做爰xxxⅹ性高电影| 91亚洲精品国产| www.久久热.com| 处破女av一区二区| 国产欧美日韩视频| 一区二区三区视频免费看| 91免费精品| 日韩精品视频在线播放| 涩多多在线观看| 日韩免费福利视频| 亚洲一区二区三区四区在线免费观看| 欧美日韩一区二区三区在线视频 | 欧美在线播放高清精品| 久久久性生活视频| 中文在线观看免费| 中文字幕一区二区在线观看| 久久伦理网站| 色香蕉在线视频| 国产99久久久久| 国产在线视频2019最新视频| 波多野结衣黄色| 免播放器亚洲| 久久国产天堂福利天堂| 91导航在线观看| 奇米亚洲欧美| 日韩精品免费在线观看| 亚洲婷婷在线观看| 欧美日韩国产一区二区在线观看| 欧美性视频一区二区三区| jizzjizzxxxx| 亚洲优女在线| 亚洲3atv精品一区二区三区| 中文字幕日韩精品一区二区| 四虎精品一区二区三区| 成人午夜激情视频| 91精品国产一区二区三区动漫 | 78m国产成人精品视频| 国产一级淫片免费| 97精品国产一区二区三区| 亚洲欧美日韩区| 欧美bbbbb性bbbbb视频| 亚洲盗摄视频| 精品亚洲永久免费精品| 狠狠人妻久久久久久综合蜜桃| 精品伊人久久久| 精品久久人人做人人爱| 白丝校花扒腿让我c| 欧美黄色一级| 欧美一级二级三级蜜桃| 丰满熟女人妻一区二区三区| 91精品国产自产精品男人的天堂 | 亚洲一二三av| 欧美日韩午夜电影网| 日韩女同互慰一区二区| 国产精品果冻传媒| 色爱综合av| 亚洲欧美一区二区精品久久久| 精品人妻无码一区| 色综合狠狠操| 综合激情国产一区| 国产一区二区精彩视频| 精品成人久久| 青草热久免费精品视频| 中文字幕在线网址| 国产老妇另类xxxxx| 国产女主播一区二区| 国产精品久久久乱弄| 欧美一级精品在线| 国产精品一级无码| 日韩三级视频| 亚洲欧美另类人妖| 香蕉久久久久久久| 国精品一区二区| 欧美有码在线观看| 91av国产精品| 成人禁用看黄a在线| 久久综合九色99| 中文字幕在线观看日本| 一区二区三区不卡在线观看 | 国产精品视频分类| 精品精品视频| 亚洲精品电影在线观看| 日韩一级片在线免费观看| 欧美欧美全黄| 日产精品99久久久久久| 91丨九色丨丰满| 成人av午夜影院| 亚洲精品永久www嫩草| 日韩精品亚洲人成在线观看| 一本大道av一区二区在线播放| 亚洲 欧美 另类人妖| 大奶在线精品| 日韩精品小视频| 欧美自拍偷拍网| 精品福利av| 91久久久在线| 国产高清视频在线观看| 亚洲不卡一区二区三区| 激情文学亚洲色图| 中文精品一区二区| 国外成人在线播放| 国产情侣在线播放| 亚洲国产精品成人久久综合一区 | 亚洲蜜桃精久久久久久久久久久久| av亚洲在线观看| 性欧美xxxx| 国内老熟妇对白xxxxhd| 欧美激情一区二区在线| 女性女同性aⅴ免费观女性恋| 日韩区一区二| 久久久999国产精品| 波多野结衣电影在线播放| 不卡的av电影| 免费特级黄色片| 中文成人在线| 中文字幕免费国产精品| 日韩精品一区二区亚洲av观看| 成人激情小说网站| 91成人综合网| 日韩区一区二| 亚洲人成电影网站| 天堂在线免费观看视频| 成人性生交大片免费看中文网站| 偷拍盗摄高潮叫床对白清晰| 写真福利精品福利在线观看| 日韩成人久久久| 国产午夜视频在线播放| 懂色av中文字幕一区二区三区| 超碰97免费观看| 祥仔av免费一区二区三区四区| 亚洲男女自偷自拍图片另类| 在线观看 中文字幕| 不卡在线视频中文字幕| 成人精品视频在线播放| 99这里只有精品视频| 欧美日韩999| 日本免费一区视频| 亚洲v中文字幕| 女王人厕视频2ⅴk| 99久久婷婷这里只有精品| 国产精品人成电影在线观看| 888av在线| 欧美日韩国产在线播放网站| 91狠狠综合久久久久久| 免费在线观看视频一区| 色女孩综合网| 视频91a欧美| 久久久精品免费| 性一交一乱一伧老太| 亚洲成av人片在线| 7788色淫网站小说| 国产偷自视频区视频一区二区| 久久本道综合色狠狠五月| 亚洲伦乱视频| www亚洲欧美| 亚洲第一黄色片| 午夜私人影院久久久久| 免费观看av网站| 麻豆精品一区二区av白丝在线| 亚洲一区二区三区加勒比| 91麻豆精品国产综合久久久| 欧美成人亚洲成人| 日本高清视频www| 91成人免费在线视频| 欧美性生给视频| 成人丝袜视频网| 欧美少妇性生活视频| 大胆日韩av| 超碰97国产在线| 成人动漫一区| 永久555www成人免费| 99热这里只有精品在线观看| 午夜精品久久久久影视| 欧美一区二区三区粗大| 国产精品一卡二| 免费在线观看毛片网站| 一本精品一区二区三区| 久久爱av电影| 日韩毛片网站| 91av在线精品| 日本成a人片在线观看| 欧美精品一区二区三区视频 | 欧美日韩亚洲综合在线 | yiren22亚洲综合| 欧美高清视频在线播放| 激情福利在线| 精品久久人人做人人爽| 亚洲天堂中文网| 夜夜操天天操亚洲| 少妇精品一区二区三区| 国产麻豆成人精品| 日本熟妇人妻中出| 尹人成人综合网| 一区二区三区三区在线| 亚洲黄页在线观看| 99热国产免费| 在线成人视屏| 久久人91精品久久久久久不卡| 日本网站在线免费观看视频| 日韩电影大片中文字幕| 国产91视频在线| 欧美浪妇xxxx高跟鞋交| 成人公开免费视频| 亚洲成人av资源| 尤物在线免费视频| 国产人成亚洲第一网站在线播放| av在线播放网址| 国产福利一区二区三区| 深夜黄色小视频| 欧美一级久久| koreanbj精品视频一区| 久久资源中文字幕| 日本在线观看不卡| 日韩有码av| 精品伦精品一区二区三区视频| 国产精品成人3p一区二区三区| 国产成人福利视频| 蜜桃麻豆av在线| 97精品久久久| 99热99re6国产在线播放| 欧美成年人视频网站| 免费黄色在线| 久久精品国亚洲| 在线观看黄色av| 亚洲人成绝费网站色www| 天天综合永久入口| 精品99一区二区三区| 99精品人妻无码专区在线视频区| 538prom精品视频线放| 在线观看视频二区| 欧美视频完全免费看| 进去里视频在线观看| 在线视频观看一区| 狠狠狠狠狠狠狠| 欧美日韩国产丝袜另类| 国产精品suv一区二区三区| 亚洲国产欧美日韩另类综合 | 美女福利精品视频| xvideos国产在线视频| 久久网福利资源网站| 黄av在线播放| 欧美大荫蒂xxx| 成人超碰在线| 国产91精品久久久久久| 亚洲妇女成熟| 国产精品va在线播放| 性欧美又大又长又硬| 国产成人精品电影| 日本a人精品| 97久草视频| 精品欧美午夜寂寞影院| 免费成人深夜夜行视频| 林ゆな中文字幕一区二区| 欧美 日韩 国产在线| 激情综合网五月| 国产又大又长又粗又黄| 国产一区日韩一区| 婷婷无套内射影院| 日日欢夜夜爽一区| 国产高清av片| 91丝袜高跟美女视频| 日韩女同一区二区三区| 日韩毛片高清在线播放| 久久精品无码人妻| 日本乱人伦aⅴ精品| 国产字幕在线观看| 制服丝袜日韩国产| 亚洲欧美日韩成人在线| 国产亚洲欧洲黄色| 中文字幕有码在线观看| 欧美亚洲国产视频小说| 日韩免费在线电影| 国产欧美亚洲日本| 成人一二三区| 免费视频爱爱太爽了| 免费看精品久久片| 中文字幕制服丝袜| 欧美激情一区二区三区蜜桃视频 | 国产精品tv| 五月天色一区| 激情自拍一区| 可以看污的网站| 91丨porny丨户外露出| av手机在线播放| 亚洲一区二三区| 88av在线视频| 亚洲女人被黑人巨大进入al| 青青草免费观看免费视频在线| 中文字幕精品久久久久| 韩日精品一区二区| 激情伦成人综合小说| 欧美日一区二区在线观看| 图片区乱熟图片区亚洲| 国产女同性恋一区二区| 一级黄色在线视频| 亚洲精品视频免费在线观看| 黄页网站在线| 91福利入口| 国产精品成人一区二区网站软件| 亚洲天堂av一区二区| 亚洲国产高清在线| 中文字幕在线日本| 亚洲网站在线观看| 唐人社导航福利精品| 欧美日韩亚洲在线| 爽好久久久欧美精品| 国产福利短视频| 欧美午夜激情视频| 日韩a在线观看| 奇门遁甲1982国语版免费观看高清 | xxx中文字幕| 亚洲精品视频观看| 亚洲黄色小说网址| 性色av香蕉一区二区| 免费观看成人www动漫视频| www一区二区www免费| 久久久久九九视频| 97人妻一区二区精品视频| 在线国产精品视频| www.久久99| 免费cad大片在线观看| 国产激情视频一区二区在线观看 | 欧美日韩生活片| 欧美日韩精品高清| 成人在线视频亚洲| 国产成人精品福利一区二区三区| 国产精品激情| 欧美 变态 另类 人妖| 欧美亚洲免费在线一区| 麻豆传媒在线观看| 亚洲自拍偷拍第一页| 亚洲精品在线二区| 蜜桃av免费看| 欧美精品v国产精品v日韩精品| 亚洲小说区图片| 久久综合狠狠综合久久综青草| 日韩国产欧美视频| 日韩va亚洲va欧美va清高| 日韩一区二区在线看片| 2020日本在线视频中文字幕| 欧美日本韩国一区二区三区| 老司机精品视频在线| 久久久久久天堂| 亚洲男人av电影| 美女精品久久| 激情五月开心婷婷| 18成人在线视频| 亚洲三级黄色片| 国产日韩欧美自拍| 影音先锋亚洲一区| 91资源在线播放| 欧美第一区第二区| 天天综合网站| www.好吊操| 国产精品久久看| 亚洲第一天堂在线观看| 国产97在线亚洲| 激情久久一区| 三级黄色录像视频| 亚洲精品国产综合区久久久久久久| 成人啊v在线| 欧美性潮喷xxxxx免费视频看| 国产欧美精品一区| 五月婷婷在线观看视频| 91九色国产视频| 久久久精品午夜少妇| 九九视频免费观看| 色婷婷av一区二区三区在线观看|