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

如何保證Mongodb和數(shù)據(jù)庫(kù)雙寫(xiě)數(shù)據(jù)一致性?

數(shù)據(jù)庫(kù) 其他數(shù)據(jù)庫(kù)
很多小伙伴看到雙寫(xiě)數(shù)據(jù)一致性問(wèn)題,首先會(huì)想到的是Redis和數(shù)據(jù)庫(kù)的數(shù)據(jù)雙寫(xiě)一致性問(wèn)題。有些小伙伴認(rèn)為,Redis和數(shù)據(jù)庫(kù)?的數(shù)據(jù)雙寫(xiě)一致性問(wèn)題,跟Mongodb和數(shù)據(jù)庫(kù)的數(shù)據(jù)雙寫(xiě)一致性問(wèn)題,是同一個(gè)問(wèn)題。

?前言

最近在我的技術(shù)群里,有位小伙伴問(wèn)了大家一個(gè)問(wèn)題:如何保證Mongodb和數(shù)據(jù)庫(kù)雙寫(xiě)的數(shù)據(jù)一致性?

群友們針對(duì)這個(gè)技術(shù)點(diǎn)討論的內(nèi)容,引起了我的興趣。

其實(shí)我在實(shí)際工作中的有些業(yè)務(wù)場(chǎng)景,也在使用Mongodb,也遇到過(guò)雙寫(xiě)的數(shù)據(jù)一致性問(wèn)題。

今天跟大家一起分享一下,這類問(wèn)題的解決辦法,希望對(duì)你會(huì)有所幫助。

1.常見(jiàn)誤區(qū)

很多小伙伴看到雙寫(xiě)數(shù)據(jù)一致性問(wèn)題,首先會(huì)想到的是Redis和數(shù)據(jù)庫(kù)的數(shù)據(jù)雙寫(xiě)一致性問(wèn)題。

有些小伙伴認(rèn)為,Redis和數(shù)據(jù)庫(kù)?的數(shù)據(jù)雙寫(xiě)一致性問(wèn)題,跟Mongodb和數(shù)據(jù)庫(kù)的數(shù)據(jù)雙寫(xiě)一致性問(wèn)題,是同一個(gè)問(wèn)題。

但如果你仔細(xì)想想它們的使用場(chǎng)景,就會(huì)發(fā)現(xiàn)有一些差異。

1.1 我們是如何用緩存的?

Redis緩存能提升我們系統(tǒng)的性能。

一般情況下,如果有用戶請(qǐng)求過(guò)來(lái),先查緩存,如果緩存中存在數(shù)據(jù),則直接返回。如果緩存中不存在,則再查數(shù)據(jù)庫(kù),如果數(shù)據(jù)庫(kù)中存在,則將數(shù)據(jù)放入緩存,然后返回。如果數(shù)據(jù)庫(kù)中也不存在,則直接返回失敗。

流程圖如下:

圖片

有了緩存之后,能夠減輕數(shù)據(jù)庫(kù)的壓力,提升系統(tǒng)性能。

通常情況下,保證緩存和數(shù)據(jù)雙寫(xiě)數(shù)據(jù)一致性,最常用的技術(shù)方案是:延遲雙刪。

感興趣的小伙伴,可以看看我的另一篇文章《如何保證數(shù)據(jù)庫(kù)和緩存雙寫(xiě)一致性?》,里面有非常詳細(xì)的介紹。

1.2 我們是如何用MongoDB的?

MongoDB?是一個(gè)高可用、分布式的文檔數(shù)據(jù)庫(kù)?,用于大容量數(shù)據(jù)存儲(chǔ)。文檔存儲(chǔ)一般用類似json的格式存儲(chǔ),存儲(chǔ)的內(nèi)容是文檔型的。

通常情況下,我們用來(lái)存儲(chǔ)大數(shù)據(jù)或者json格式的數(shù)據(jù)。

用戶寫(xiě)數(shù)據(jù)的請(qǐng)求,核心數(shù)據(jù)?會(huì)被寫(xiě)入數(shù)據(jù)庫(kù),json格式的非核心數(shù)據(jù),可能會(huì)寫(xiě)入MongoDB。

流程圖如下:

圖片

此外,在數(shù)據(jù)庫(kù)的表中,保存了MongoDB相關(guān)文檔的id。

用戶讀數(shù)據(jù)的請(qǐng)求,會(huì)先讀數(shù)據(jù)庫(kù)中的數(shù)據(jù),然后通過(guò)文檔的id,讀取MongoDB中的數(shù)據(jù)。

流程圖如下:

圖片

這樣可以保證核心屬性不會(huì)丟失,同時(shí)存儲(chǔ)用戶傳入的較大的數(shù)據(jù),兩全其美。

Redis和MongoDB在我們實(shí)際工作中的用途不一樣,導(dǎo)致了它們雙寫(xiě)數(shù)據(jù)一致性問(wèn)題的解決方案是不一樣的。

接下來(lái)我們一起看看,如何保證MongoDB和數(shù)據(jù)庫(kù)的雙寫(xiě)的數(shù)據(jù)一致性?

2.如何保證雙寫(xiě)一致性?

目前雙寫(xiě)MongoDB和數(shù)據(jù)庫(kù)的數(shù)據(jù),用的最多的就是下面這兩種方案。

2.1 先寫(xiě)數(shù)據(jù)庫(kù),再寫(xiě)MongoDB

該方案最簡(jiǎn)單,先在數(shù)據(jù)庫(kù)中寫(xiě)入核心數(shù)據(jù),再在MongoDB中寫(xiě)入非核心數(shù)據(jù)。

流程圖如下:

圖片

如果有些業(yè)務(wù)場(chǎng)景,對(duì)數(shù)據(jù)的完整性要求不高,即非核心數(shù)據(jù)可有可無(wú),使用該方案也是可以的。

但如果有些業(yè)務(wù)場(chǎng)景,對(duì)數(shù)據(jù)完整性要求比較高,用這套方案可能會(huì)有問(wèn)題。

當(dāng)數(shù)據(jù)庫(kù)剛保存了核心數(shù)據(jù),此時(shí)網(wǎng)絡(luò)出現(xiàn)異常,程序保存MongoDB的非核心數(shù)據(jù)時(shí)失敗了。

但MongoDB并沒(méi)有拋出異常,數(shù)據(jù)庫(kù)中已經(jīng)保存的數(shù)據(jù)沒(méi)法回滾,這樣會(huì)出現(xiàn)數(shù)據(jù)庫(kù)中保存了數(shù)據(jù),而MongoDB中沒(méi)保存數(shù)據(jù)的情況,從而導(dǎo)致MongoDB中的非核心數(shù)據(jù)丟失的問(wèn)題。

所以這套方案,在實(shí)際工作中使用不多。

2.2 先寫(xiě)MongoDB,再寫(xiě)數(shù)據(jù)庫(kù)

在該方案中,先在MongoDB中寫(xiě)入非核心數(shù)據(jù),再在數(shù)據(jù)庫(kù)中寫(xiě)入核心數(shù)據(jù)。

流程圖如下:

圖片

關(guān)鍵問(wèn)題來(lái)了:如果MongoDB中非核心數(shù)據(jù)寫(xiě)入成功了,但數(shù)據(jù)庫(kù)中的核心數(shù)據(jù)寫(xiě)入失敗了怎么辦?

這時(shí)候MongoDB中非核心數(shù)據(jù)不會(huì)回滾,可能存在MongoDB中保存了數(shù)據(jù),而數(shù)據(jù)庫(kù)中沒(méi)保存數(shù)據(jù)的問(wèn)題,同樣會(huì)出現(xiàn)數(shù)據(jù)不一致的問(wèn)題。

答:我們忘了一個(gè)前提,查詢MongoDB文檔中的數(shù)據(jù),必須通過(guò)數(shù)據(jù)庫(kù)的表中保存的mongo id?。但如果這個(gè)mongo id在數(shù)據(jù)庫(kù)中都沒(méi)有保存成功,那么,在MongoDB文檔中的數(shù)據(jù)是永遠(yuǎn)都查詢不到的。

也就是說(shuō),這種情況下MongoDB文檔中保存的是垃圾數(shù)據(jù),但對(duì)實(shí)際業(yè)務(wù)并沒(méi)有影響。

這套方案可以解決雙寫(xiě)數(shù)據(jù)一致性問(wèn)題,但它同時(shí)也帶來(lái)了兩個(gè)新問(wèn)題:

用戶修改操作如何保存數(shù)據(jù)?

如何清理垃圾數(shù)據(jù)?

3 用戶修改操作如何保存數(shù)據(jù)?

我之前聊的先寫(xiě)MongoDB,再寫(xiě)數(shù)據(jù)庫(kù),這套方案中的流程圖,其實(shí)主要說(shuō)的是新增數(shù)據(jù)的場(chǎng)景。

但如果在用戶修改數(shù)據(jù)的操作中,用戶先修改MongoDB文檔中的數(shù)據(jù),再修改數(shù)據(jù)庫(kù)表中的數(shù)據(jù)。

流程圖如下:

圖片

如果出現(xiàn)MongoDB文檔中的數(shù)據(jù)修改成功了,但數(shù)據(jù)庫(kù)表中的數(shù)據(jù)修改失敗了,不也出現(xiàn)問(wèn)題了?

那么,用戶修改操作時(shí)如何保存數(shù)據(jù)呢?

這就需要把流程調(diào)整一下,在修改MongoDB文檔時(shí),還是新增一條數(shù)據(jù),不直接修改,生成一個(gè)新的mongo id。然后在修改數(shù)據(jù)庫(kù)表中的數(shù)據(jù)時(shí),同時(shí)更新mongo id字段為這個(gè)新值。

流程圖如下:

圖片

這樣如果新增MongoDB文檔中的數(shù)據(jù)成功了,但修改數(shù)據(jù)庫(kù)表中的數(shù)據(jù)失敗了,也沒(méi)有關(guān)系,因?yàn)閿?shù)據(jù)庫(kù)中老的數(shù)據(jù),保存的是老的mongo id。通過(guò)該id,依然能從MongoDB文檔中查詢出數(shù)據(jù)。

使用該方案能夠解決修改數(shù)據(jù)時(shí),數(shù)據(jù)一致性問(wèn)題,但同樣會(huì)存在垃圾數(shù)據(jù)。

其實(shí)這個(gè)垃圾數(shù)據(jù)是可以即使刪除的,具體流程圖如下:

圖片

在之前的流程中,修改完數(shù)據(jù)庫(kù),更新了mongo id為新值,接下來(lái),就把MongoDB文檔中的那條老數(shù)據(jù)直接刪了。

該方案可以解決用戶修改操作中,99%的的垃圾數(shù)據(jù),但還有那1%的情況,即如果最后刪除失敗該怎么辦?

答:這就需要加重試機(jī)制了。

我們可以使用job?或者mq?進(jìn)行重試,優(yōu)先推薦使用mq增加重試功能。特別是想RocketMQ?,自帶了失敗重試機(jī)制,有專門(mén)的重試隊(duì)列?,我們可以設(shè)置重試次數(shù)。

流程圖優(yōu)化如下:

圖片

將之前刪除MongoDB文檔中的數(shù)據(jù)操作,改成發(fā)送mq消息,有個(gè)專門(mén)的mq消費(fèi)者,負(fù)責(zé)刪除數(shù)據(jù)工作,可以做成共用的功能。它包含了失敗重試機(jī)制,如果刪除5次還是失敗,則會(huì)把該消息保存到?死信隊(duì)列中。

然后專門(mén)有個(gè)程序監(jiān)控死信隊(duì)列中的數(shù)據(jù),如果發(fā)現(xiàn)有數(shù)據(jù),則發(fā)報(bào)警郵件。

這樣基本可以解決修改刪除垃圾數(shù)據(jù)失敗的問(wèn)題。

4 如何清理新增的垃圾數(shù)據(jù)?

還有一種垃圾數(shù)據(jù)還沒(méi)處理,即在用戶新增數(shù)據(jù)時(shí),如果寫(xiě)入MongoDB文檔成功了,但寫(xiě)入數(shù)據(jù)庫(kù)表失敗了。由于MongoDB不會(huì)回滾數(shù)據(jù),這時(shí)候MongoDB文檔就保存了垃圾數(shù)據(jù),那么這種數(shù)據(jù)該如何清理呢?

4.1 定時(shí)刪除

我們可以使用job定時(shí)掃描,比如:每天掃描一次MongoDB文檔,將mongo id取出來(lái),到數(shù)據(jù)庫(kù)查詢數(shù)據(jù),如果能查出數(shù)據(jù),則保留MongoDB文檔中的數(shù)據(jù)。

如果在數(shù)據(jù)庫(kù)中該mongo id不存在,則刪除MongoDB文檔中的數(shù)據(jù)。

如果MongoDB文檔中的數(shù)據(jù)量不多,是可以這樣處理的。但如果數(shù)據(jù)量太大,這樣處理會(huì)有性能問(wèn)題。

這就需要做優(yōu)化,常見(jiàn)的做法是:縮小掃描數(shù)據(jù)的范圍。

比如:掃描MongoDB文檔數(shù)據(jù)時(shí),根據(jù)創(chuàng)建時(shí)間,只查最近24小時(shí)的數(shù)據(jù),查出來(lái)之后,用mongo id去數(shù)據(jù)庫(kù)查詢數(shù)據(jù)。

如果直接查最近24小時(shí)的數(shù)據(jù),會(huì)有問(wèn)題,會(huì)把剛寫(xiě)入MongoDB文檔,但還沒(méi)來(lái)得及寫(xiě)入數(shù)據(jù)庫(kù)的數(shù)據(jù)也查出來(lái),這種數(shù)據(jù)可能會(huì)被誤刪。

可以把時(shí)間再整體提前一小時(shí),例如:

in_time < 當(dāng)前時(shí)間-1 and in_time >= 當(dāng)前時(shí)間-25

獲取25小時(shí)前到1小時(shí)前的數(shù)據(jù)。

這樣可以解決大部分系統(tǒng)中,因?yàn)閿?shù)據(jù)量過(guò)多,在一個(gè)定時(shí)任務(wù)的執(zhí)行周期內(nèi),job處理不完的問(wèn)題。

但如果根據(jù)時(shí)間縮小范圍之后,數(shù)據(jù)量還是太大,job還是處理不完該怎么辦?

答:我們可以在job用多線程刪除數(shù)據(jù)。

當(dāng)然我們還可以將job的執(zhí)行時(shí)間縮短,根據(jù)實(shí)際情況而定,比如每隔12小時(shí),查詢創(chuàng)建時(shí)間是13小時(shí)前到1小時(shí)前的數(shù)據(jù)。

或者每隔6小時(shí),查詢創(chuàng)建時(shí)間是7小時(shí)前到1小時(shí)前的數(shù)據(jù)。

或者每隔1小時(shí),查詢創(chuàng)建時(shí)間是2小時(shí)前到1小時(shí)前的數(shù)據(jù)等等。

4.2 隨機(jī)刪除

其實(shí)刪除垃圾數(shù)據(jù)還有另外一種思路。

不知道你了解過(guò)Redis?刪除數(shù)據(jù)的策略?嗎?它在處理大批量數(shù)據(jù)時(shí),為了防止使用過(guò)多的CPU資源,用了一種隨機(jī)刪除的策略。

我們?cè)谶@里可以借鑒一下。

有另外一個(gè)job,每隔500ms隨機(jī)獲取10條數(shù)據(jù)進(jìn)行批量處理,當(dāng)然獲取的數(shù)據(jù)也是根據(jù)時(shí)間縮小范圍的。

責(zé)任編輯:武曉燕 來(lái)源: 蘇三說(shuō)技術(shù)
相關(guān)推薦

2022-03-31 08:21:14

數(shù)據(jù)庫(kù)緩存雙寫(xiě)數(shù)據(jù)一致性

2024-01-22 08:52:00

AQS雙異步數(shù)據(jù)一致性

2024-10-28 12:41:25

2022-03-29 10:39:10

緩存數(shù)據(jù)庫(kù)數(shù)據(jù)

2020-09-03 09:45:38

緩存數(shù)據(jù)庫(kù)分布式

2024-12-26 15:01:29

2023-09-07 08:11:24

Redis管道機(jī)制

2025-03-27 08:20:54

2024-08-20 16:13:52

2023-05-26 07:34:50

RedisMySQL緩存

2021-06-11 09:21:58

緩存數(shù)據(jù)庫(kù)Redis

2021-12-14 07:15:57

MySQLRedis數(shù)據(jù)

2025-04-27 08:52:21

Redis數(shù)據(jù)庫(kù)緩存

2024-07-04 12:36:50

2023-09-15 14:24:54

ByteHouseClickHouse開(kāi)源

2021-12-01 08:26:27

數(shù)據(jù)庫(kù)緩存技術(shù)

2022-02-23 09:17:09

數(shù)據(jù)庫(kù)分離變更

2022-04-01 16:55:22

數(shù)據(jù)庫(kù)緩存日志

2022-08-23 07:46:45

數(shù)據(jù)一致性數(shù)據(jù)庫(kù)

2018-08-14 10:39:04

數(shù)據(jù)錯(cuò)誤DIX
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

中文字幕视频二区| 国产精品美女高潮无套| 91在线超碰| 久久蜜臀精品av| 成人国产精品免费视频| 久久亚洲国产成人精品性色| 99久久免费精品国产72精品九九| 黄网动漫久久久| 日韩欧美一区二区在线观看 | 欧美大片久久久| 日本一级理论片在线大全| 26uuu国产一区二区三区| 国产精品美女主播| 国产午夜精品无码| 国产精品亚洲片在线播放| 91精品国产欧美一区二区| 春日野结衣av| 成人av黄色| 国产欧美一区二区在线| 成人在线免费观看一区| 正在播放木下凛凛xv99| 亚洲精品乱码久久久久久蜜桃麻豆| 国产一区二区三区在线观看网站| 人妻换人妻仑乱| 91精品影视| 亚洲国产欧美在线人成| 亚洲欧洲在线一区| 五月激情婷婷综合| 国产精品亚洲成人| 国产视频999| 天堂网免费视频| 亚洲精选成人| 欧美国产亚洲精品久久久8v| 91视频免费看片| 亚洲素人在线| 亚洲精品电影网在线观看| 国产毛片久久久久久| 日本精品另类| 一本久道久久综合中文字幕| 日韩av新片网| 日韩欧美一起| 一区二区三区视频在线观看| 最新不卡av| melody高清在线观看| 久久理论电影网| 国产视频精品网| 亚洲欧美国产高清va在线播放| 蜜桃精品在线观看| 国产精品久久久久久中文字| www.com国产| 国产精品人人爽人人做我的可爱| 欧美激情综合色综合啪啪五月| www日韩在线| 99热在线成人| 久久久精品在线观看| 亚洲 欧美 国产 另类| 色琪琪久久se色| 日韩视频永久免费观看| 日韩av片在线免费观看| 成人a'v在线播放| 在线观看欧美日韩| 国产馆在线观看| 欧美黄色大片在线观看| 日韩少妇与小伙激情| 欧美做爰啪啪xxxⅹ性| 婷婷亚洲五月| 欧美乱妇高清无乱码| 精品无码一区二区三区电影桃花| 在线观看一区| 欧美亚洲国产日本| 久久青青草原亚洲av无码麻豆| 久久久久中文| 国产精品视频最多的网站| 一本一道精品欧美中文字幕| 国内精品写真在线观看| 粉嫩精品一区二区三区在线观看| 好吊视频一区二区三区| av在线免费不卡| 热re99久久精品国99热蜜月 | 久久久91精品国产| 久久精品99国产精| 午夜亚洲激情| 国产日韩欧美中文| www.97超碰| 91婷婷韩国欧美一区二区| 欧美久久久久久久| 久久日韩视频| 亚洲成av人片在线| 波多结衣在线观看| 亚洲精选av| 国产亚洲欧洲高清| 久久久精品视频免费观看| 国产午夜久久| 成人xvideos免费视频| 亚洲国产www| 国产亚洲精品超碰| 久久免费一级片| 一级毛片久久久| 欧美裸体一区二区三区| 亚洲啪av永久无码精品放毛片| 色先锋久久影院av| 久久久国产一区| 久久久久99精品成人片我成大片| 久久国产福利国产秒拍| 极品日韩久久| 黄色网页在线看| 欧美日韩中文在线观看| 日本黄色www| 免费视频国产一区| 欧美精品第一页在线播放| 亚洲高清视频免费观看| 国产99久久久久久免费看农村| 日韩欧美一区二区视频在线播放 | 5252色成人免费视频| 91麻豆一区二区| 久久新电视剧免费观看| 91精品国产吴梦梦| 巨胸喷奶水www久久久免费动漫| 欧美一区二区三区视频免费播放| 欧美做受xxxxxⅹ性视频| 欧美日韩一区二区三区四区在线观看 | 欧美日韩久久久| 泷泽萝拉在线播放| 日韩亚洲精品在线| 91人人爽人人爽人人精88v| 可以在线观看的黄色| 亚洲成人av中文| 国产男女无遮挡猛进猛出| 久久一区二区三区喷水| 欧美最猛性xxxx| 日本久久一级片| 一区二区三区不卡在线观看 | 成a人片亚洲日本久久| 椎名由奈jux491在线播放| 欧美动物xxx| 亚洲精品国产综合久久| 免费在线观看黄色av| 国产一区二区三区在线观看精品| 午夜一区二区三区| 精品免费av在线| 亚洲人成在线观看网站高清| 国产一级免费视频| 91在线云播放| 欧美 日韩 国产一区| 国产精品久av福利在线观看| 欧美疯狂做受xxxx高潮| 精品人妻一区二区三区四区不卡| 亚洲丝袜另类动漫二区| 色18美女社区| 亚洲精品成人无限看| 91手机视频在线观看| 大地资源网3页在线观看| 91麻豆精品国产91久久久资源速度| 战狼4完整免费观看在线播放版| 日韩高清不卡一区二区| 日韩三级电影网站| 青青国产精品| 欧美xxxx综合视频| 亚洲国产精品久久久久久6q| 亚洲国产另类精品专区| 9.1在线观看免费| 亚洲日产国产精品| 欧美日韩在线一二三| se69色成人网wwwsex| 综合欧美国产视频二区| 国产精品视频久久久久久| 亚洲女同一区二区| 成年人性生活视频| 亚洲国产91| 欧美福利精品| 九色成人搞黄网站| 欧美美女15p| 日本高清视频免费看| 色悠久久久久综合欧美99| 亚洲色图第四色| 国产在线日韩欧美| 人妻久久久一区二区三区| 亚洲+变态+欧美+另类+精品| 国产精品高潮粉嫩av| 麻豆系列在线观看| 精品久久久久久久久久久久久久久| 日韩精品一区二区不卡| 久久久精品欧美丰满| 天天操狠狠操夜夜操| 欧美区亚洲区| 欧美日韩国产综合视频在线| 美女视频一区| 97免费在线视频| 在线观看美女网站大全免费| 欧美一区二区三区喷汁尤物| 可以免费看的av毛片| 中文在线资源观看网站视频免费不卡 | 欧美福利精品| 99热这里有精品| 91tv亚洲精品香蕉国产一区7ujn| 1024国产在线| 亚洲第一网中文字幕| 亚洲综合五月天婷婷丁香| 亚洲一区在线视频观看| 免费看裸体网站| 福利一区二区在线观看| 男女男精品视频站| 亚洲福利电影| 蜜臀av.com| 九色精品91| 成人一区二区在线| 日韩一区二区三免费高清在线观看| 久久久欧美精品| 98在线视频| 精品视频在线观看日韩| 国产www免费观看| 欧美性高清videossexo| 免费观看一级视频| 中文字幕一区二区三区蜜月| av网站免费在线播放| 国产麻豆精品95视频| 免费看污黄网站| 一本久道久久综合狠狠爱| 国产奶头好大揉着好爽视频| 韩日一区二区三区| 黑人另类av| 五月亚洲婷婷| 91中文精品字幕在线视频| 成人视屏在线观看| 日本精品性网站在线观看| 黄色的视频在线观看| 大胆人体色综合| 91xxx在线观看| 亚洲毛片一区二区| 午夜视频福利在线观看| 日韩亚洲电影在线| 国产强被迫伦姧在线观看无码| 在线亚洲免费视频| 丰满人妻老熟妇伦人精品| 午夜一区二区三区在线观看| 久久免费播放视频| 亚洲丝袜自拍清纯另类| 国产美女福利视频| 亚洲人成亚洲人成在线观看图片| 超薄肉色丝袜一二三| 久久午夜电影网| mm131美女视频| 久久夜色精品一区| 一级性生活大片| 久久嫩草精品久久久精品| 丰满大乳奶做爰ⅹxx视频| av在线播放不卡| yy6080午夜| 久久影院电视剧免费观看| 国产在线观看无码免费视频| av电影一区二区| 日本少妇xxxx| 91麻豆蜜桃一区二区三区| 波多野结衣影院| 久久久影院官网| 久久成人激情视频| 亚洲国产激情av| 欧日韩不卡视频| 亚洲三级电影网站| 久久成人在线观看| 精品高清一区二区三区| 精品人妻一区二区三区免费看 | 国产精品主播一区二区| 777色狠狠一区二区三区| 精品毛片在线观看| 亚洲成人亚洲激情| 四虎影院在线域名免费观看| 亚洲欧美日韩视频一区| 久久伊伊香蕉| 色视频www在线播放国产成人 | 91高清免费在线观看| 色戒汤唯在线观看| 国产精品电影网| 伊人久久一区| 国产精品综合久久久久久| 婷婷综合福利| 夜夜爽www精品| 欧美成人一品| 精品中文字幕av| 麻豆国产精品一区二区三区| 成人三级做爰av| 99精品一区二区| 久久视频一区二区三区| 一区二区久久久久久| 欧美a视频在线观看| 欧美精品丝袜中出| 黄色片网站免费在线观看| 亚洲少妇激情视频| 操你啦视频在线| 欧美亚洲成人xxx| 91精品国产一区二区在线观看 | 免费成人在线看| 亚洲天堂影视av| 1区2区在线观看| 日本人成精品视频在线| 精品国模一区二区三区欧美| 久久99精品久久久久久秒播放器| 99tv成人| 女性女同性aⅴ免费观女性恋| 老司机免费视频一区二区| 影音先锋人妻啪啪av资源网站| 国产精品卡一卡二| 中国一级特黄毛片| 91精品国产91久久综合桃花| 男人的天堂在线| 欧美精品第一页在线播放| 日韩黄色三级在线观看| 久久精品国产精品青草色艺| 一区二区中文| 男人舔女人下面高潮视频| 国产成人8x视频一区二区| 手机看片国产日韩| 色综合激情久久| 人成网站在线观看| 日韩在线观看成人| 亚洲成人看片| 精品国产综合久久| 欧美日一区二区三区在线观看国产免| 成人午夜激情av| 久久综合色一综合色88| 久久久一二三区| 91精品国产麻豆| 无遮挡的视频在线观看| 国产成人福利视频| 欧美一区自拍| 人妻少妇精品久久| 国产成人午夜视频| 日本在线一级片| 欧美亚洲愉拍一区二区| 日夜干在线视频| 91精品国产色综合久久不卡98口 | 欧美一区二区在线| 在线精品一区二区| wwwxxxx在线观看| 亚洲同性gay激情无套| 久久精品视频2| 亚洲人成77777在线观看网| 涩涩网在线视频| 九九九九九九精品| 一区二区三区福利| 污片免费在线观看| 欧美日韩国产页| 亚洲人成色777777精品音频| 国产+人+亚洲| 日韩av影院| 日日鲁鲁鲁夜夜爽爽狠狠视频97 | 免费国产在线精品一区二区三区| 国产精品第十页| 2018国产精品| 亚洲国产精品天堂| 天天操天天舔天天干| 国模gogo一区二区大胆私拍| 国产精品极品| 男人的天堂99| 国产色一区二区| 中文字幕有码视频| 久久亚洲精品网站| 精品一区二区三区中文字幕| 蜜桃网站在线观看| 风间由美一区二区三区在线观看| 久久精品视频国产| 精品无人区乱码1区2区3区在线| 一区二区三区短视频| 欧美不卡在线一区二区三区| 爽好多水快深点欧美视频| 精品熟妇无码av免费久久| 欧美二区乱c少妇| 手机在线免费av| 久久久com| 麻豆精品一区二区| 18精品爽视频在线观看| 亚洲精品www| xxxxx.日韩| 特级西西444| 97国产一区二区| 中文字幕黄色av| 久久99久久久久久久噜噜| 精品视频在线你懂得| 成人3d动漫一区二区三区| 亚洲视频在线一区观看| 黄色a在线观看| 国产精品久久久久久久久久| 亚洲一级淫片| 中文在线一区二区三区| 欧美私模裸体表演在线观看| 在线中文字幕-区二区三区四区| 国产欧美日本在线| 日本伊人精品一区二区三区观看方式| 极品美妇后花庭翘臀娇吟小说| 日韩亚洲欧美高清| 亚洲第一二三四区| 丰满人妻一区二区三区53号| 久久九九99视频| 亚洲精品网站在线| 国产精品男女猛烈高潮激情| 亚洲婷婷在线| 手机看片国产日韩| 亚洲精品电影网在线观看| 成人亚洲精品| 999精品网站|