精品欧美一区二区三区在线观看 _久久久久国色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)

高清一区二区三区av| 免费网站免费进入在线| 在线亚洲伦理| 中文字幕亚洲一区二区三区| 久久综合在线观看| 欧美私密网站| 中文字幕色av一区二区三区| 国产伦精品一区二区三区四区视频| 久久久久久久久久久久久久久| 三级中文字幕在线观看| 国产精品伦理一区二区| 成人xxxxx色| 久久综合成人网| 欧美手机视频| 亚洲成人av在线| 国产精品久久久毛片| 免费不卡av| 国产精品美女久久久久aⅴ | 久久伊人国产| 五月天欧美精品| 男插女免费视频| 成人18在线| av一本久道久久综合久久鬼色| 91高清视频在线免费观看| 国产人妻黑人一区二区三区| 欧美视频精品| 欧美午夜无遮挡| 亚洲国产成人不卡| 青青草视频免费在线观看| 国产精品亚洲第一区在线暖暖韩国| 欧美国产日韩一区二区在线观看| 怡红院一区二区| av日韩在线免费观看| 欧美羞羞免费网站| 亚洲熟妇av一区二区三区| 1区2区3区在线| 亚洲一区二区三区四区在线观看| 久久久综合亚洲91久久98| 夜夜爽妓女8888视频免费观看| 99九九热只有国产精品| 国产亚洲一区二区在线| 蜜桃精品成人影片| 琪琪久久久久日韩精品| 亚洲成年人影院在线| 少妇精品无码一区二区| 精品国产一区二区三区2021| 欧美乱妇15p| www.国产视频.com| 只有精品亚洲| 欧美一区二区播放| 少妇丰满尤物大尺度写真| 久久精品一级| 日韩视频永久免费| 波多野结衣三级视频| 亚洲专区**| 亚洲成人网av| 制服丝袜第一页在线观看| 9999久久久久| 亚洲精品久久久久国产| 久久久久久久无码| 国产精品亚洲欧美一级在线 | 日本www在线视频| 高端美女服务在线视频播放| 午夜精品福利在线| 免费观看日韩毛片| 欧美性爽视频| 婷婷六月综合亚洲| 日批视频在线免费看| 日本精品另类| 欧美一区二区三区系列电影| 性生交大片免费看l| 精品国产乱子伦一区二区| 欧美日韩免费不卡视频一区二区三区| 国产av国片精品| 麻豆视频在线看| 日本久久一区二区三区| 午夜两性免费视频| 欧美一区一区| 日韩精品视频中文在线观看| 久久成人激情视频| 亚洲午夜久久| 日韩中文字幕视频在线| 成人激情五月天| 91精品亚洲| 91国语精品自产拍在线观看性色 | 有坂深雪av一区二区精品| 欧美这里只有精品| caoporn免费在线| 性做久久久久久久久| 日韩欧美精品在线观看视频| 最新欧美色图| 欧美精品自拍偷拍动漫精品| 久久久久中文字幕亚洲精品| 西瓜成人精品人成网站| 日韩在线视频线视频免费网站| 精品国产成人亚洲午夜福利| 欧美一区综合| 国产成+人+综合+亚洲欧洲| 国产精品一品二区三区的使用体验| 日韩精品五月天| 日韩av三级在线观看| 国产老女人乱淫免费| 91玉足脚交白嫩脚丫在线播放| 久久亚洲高清| av片在线观看永久免费| 色噜噜偷拍精品综合在线| 999热精品视频| 影音先锋欧美激情| 国产一区二区三区四区福利| 精品视频一区二区在线观看| 美女网站一区二区| 久久国产精品精品国产色婷婷| 欧美日韩国产综合视频| 一区二区三区美女| 色免费在线视频| 伊人成综合网伊人222| 欧美日本精品在线| 亚洲中文字幕在线观看| 久久综合视频网| 精品国偷自产一区二区三区| 欧美性生活一级| 一本色道久久综合亚洲精品小说| 国产一级淫片久久久片a级| 亚洲伦伦在线| 国产99久久精品一区二区永久免费 | 亚洲午夜三级在线| 欧美在线观看成人| 亚洲精品黑牛一区二区三区| www.午夜精品| 亚洲天堂男人网| 久久久久久久精| 97精品国产97久久久久久粉红| 福利影院在线看| 亚洲第一av网站| 久久精品亚洲无码| 国产成人av电影| 在线观看av的网址| 北岛玲精品视频在线观看| 中文字幕亚洲欧美日韩高清| 日韩黄色片网站| 国产日韩欧美精品在线| www一区二区www免费| 久久精品亚洲成在人线av网址| 中文字幕精品av| 成人黄色免费网| 中文字幕成人网| 九九九在线观看视频| 欧美军人男男激情gay| 国产成人精品免高潮在线观看| 国产av一区二区三区| 亚洲免费观看高清在线观看| 不卡中文字幕在线观看| 日韩av网址大全| 欧美中文字幕第一页| 视频国产一区二区三区| 色婷婷国产精品| 熟妇高潮一区二区| 久久一区91| 成人国产在线视频| 可以在线观看的av| 欧美综合视频在线观看| 美女av免费看| 国产一区二区三区黄视频| 日本一区视频在线观看免费| 先锋欧美三级| 日韩在线免费av| 精品久久久久成人码免费动漫| 国产日韩精品久久久| 一级黄色特级片| 欧美一区高清| 精品九九九九| 91精品国产经典在线观看| 色偷偷av亚洲男人的天堂| 国产av无码专区亚洲av麻豆| 亚洲成a人片在线不卡一二三区| 免费人成视频在线播放| 亚洲国产一区二区三区a毛片| 亚洲综合小说区| 爱啪啪综合导航| 精品欧美一区二区久久| 欧美a∨亚洲欧美亚洲| 久久精品视频免费| 欧美日韩激情视频在线观看| 欧美午夜精品一区二区三区电影| 青青在线视频一区二区三区| 日本福利专区在线观看| 精品少妇一区二区三区免费观看 | 色综合天天综合网天天狠天天| 亚洲成年人av| 三级影片在线观看欧美日韩一区二区 | 国产精品女同一区二区| 亚洲成a人片综合在线| 中文字幕免费视频| 福利一区二区在线观看| 国产精品久久久久9999小说| 欧美99在线视频观看| 日本不卡一区| 精品欧美日韩精品| 久久久亚洲影院你懂的| 1769在线观看| 91精品一区二区三区久久久久久 | 福利在线视频导航| 日韩欧美国产综合一区 | 一区二区日韩免费看| 亚洲人体一区| 日韩av影院| 国产成人一区二区| eeuss影院www在线观看| 精品久久久久久综合日本欧美| 日韩av免费网址| 中文字幕在线视频一区| 免费人成视频在线播放| 秋霞电影一区二区| 欧美日韩精品在线一区二区| 午夜精品久久99蜜桃的功能介绍| 波多野结衣精品久久| 精精国产xxxx视频在线播放| 久久不射电影网| 国产91免费看| 日本道色综合久久| 日韩欧美亚洲视频| 亚洲日本青草视频在线怡红院| 深夜视频在线观看| 极品美女销魂一区二区三区免费| 黄色成人在线免费观看| 先锋资源久久| 一区二区三区四区免费视频| 精品国内自产拍在线观看视频| 成人网在线观看| 久久精品xxxxx| 国产a级全部精品| 亚洲深夜视频| 欧美专区在线播放| 日韩伦理福利| 2019国产精品自在线拍国产不卡| 国产成人天天5g影院在线观看| 欧美一级片免费看| 一区二区日韩在线观看| 欧美色视频一区| 中文字幕+乱码+中文| 欧美性猛交xxxxxxxx| 国产黄色免费视频| 欧美羞羞免费网站| 亚洲一区精品在线观看| 欧美另类一区二区三区| 国产精品乱码久久久| 91精品中文字幕一区二区三区 | 欧美日韩中字一区| 真实新婚偷拍xxxxx| 欧美乱熟臀69xxxxxx| 国产乱色精品成人免费视频| 538在线一区二区精品国产| 国产又黄又粗又长| 91精品国产91综合久久蜜臀| av片免费播放| 精品美女在线观看| 香蕉av在线播放| 亚洲女人天堂av| 91最新在线| 久久伊人色综合| 久久免费电影| 热久久这里只有精品| 99精品国自产在线| 欧美重口另类videos人妖| 国产精品久久久久av电视剧| 国产日韩欧美中文| 国产综合色在线观看| 成人国产精品av| 91精品丝袜国产高跟在线| 九九九九精品九九九九| 精品一区av| 国产午夜精品视频一区二区三区| 日韩欧美高清在线播放| 欧美日韩精品综合| 久久人人88| av日韩一区二区三区| 丝袜a∨在线一区二区三区不卡 | a日韩av网址| 国产精品专区一| 91大神精品| 日韩av电影免费观看| 色棕色天天综合网| 中文字幕日韩一区二区三区| 精品999成人| 日韩肉感妇bbwbbwbbw| 日本伊人精品一区二区三区观看方式| 免费av手机在线观看| 日本欧美韩国一区三区| 成年人在线观看视频免费| 日韩专区在线视频| 黄色片子免费看| 久久久久国产精品免费免费搜索| 色婷婷在线影院| 亚洲免费电影在线| 国产精品suv一区| 91福利在线导航| www.精品久久| 伊人久久久久久久久久久| 欧洲成人综合网| 国产在线一区二区三区| 欧美变态挠脚心| 永久免费网站视频在线观看| 丝瓜av网站精品一区二区| 国产三级三级三级看三级| 成人在线视频一区二区| 欧美性猛交xxxx乱大交少妇| 五月激情综合网| 国产av一区二区三区精品| 中文日韩电影网站| 亚洲黄色免费看| 国产精品国产三级国产专区53| 美女呻吟一区| 国产一级大片免费看| 麻豆国产精品777777在线| 亚洲第九十七页| 亚洲国产美国国产综合一区二区| 精品成人av一区二区在线播放| 一本色道久久综合精品竹菊| www.国产.com| 久久影院模特热| 国产成人免费精品| 日本在线观看一区二区| 国产亚洲福利| 99精品一区二区三区无码吞精| 久久精品欧美一区二区三区不卡| 欧美xxxooo| 欧美性视频一区二区三区| 精品美女视频在线观看免费软件| 久久天天躁狠狠躁夜夜爽蜜月| www视频在线观看| 动漫3d精品一区二区三区 | 日韩免费高清av| free性欧美hd另类精品| 91久久精品国产91久久性色| 久久国产中文字幕| 69久久久久久| 国产精品乱码人人做人人爱| 69av视频在线观看| 亚洲网在线观看| 国产嫩草在线视频| 成人欧美一区二区三区视频| 午夜欧美精品| 精品无码av一区二区三区| 亚洲一区二区视频在线观看| 丰满人妻一区二区三区免费视频| 中国china体内裑精亚洲片| 成人在线爆射| 午夜一区二区三视频在线观看| 亚洲国产mv| avtt香蕉久久| 色先锋资源久久综合| 国产视频三级在线观看播放| 国产精品美女网站| 久久美女精品| 免费黄色在线播放| 午夜精品成人在线视频| 日本黄在线观看| 国产成人精品一区| 久久精品国产68国产精品亚洲| 日本精品一区二区三区四区| 国产超碰在线一区| 亚洲日本韩国在线| 日韩精品一区二区三区中文不卡| 在线免费观看黄色网址| 国产一区二区色| 国内精品福利| 丝袜美腿中文字幕| 欧美日韩五月天| 日本欧美电影在线观看| 韩国成人一区| 日本午夜一区二区| 欧美黑人性猛交xxx| 亚洲第一精品久久忘忧草社区| 五月花成人网| 久久99精品久久久久久秒播放器 | 欧美日韩国产在线播放| 日本福利片在线| 欧美一区二区三区免费观看| 成人18夜夜网深夜福利网| 欧洲黄色一级视频| 91麻豆福利精品推荐| 最近中文字幕在线视频| 欧美成人激情图片网| 欧洲亚洲视频| 中文字幕日韩综合| 午夜日韩在线电影| 秋霞午夜在线观看| 国产美女被下药99| 欧美电影《睫毛膏》| 超碰超碰在线观看| 亚洲第一精品在线| 91精彩视频在线观看| 成人国内精品久久久久一区| 亚洲激精日韩激精欧美精品| 色噜噜噜噜噜噜| 精品小视频在线| 日韩成人精品| 看欧美ab黄色大片视频免费| 日本一区二区三区在线观看| 黑人乱码一区二区三区av|