久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

SQLITE中原子提交的实现

發(fā)布時(shí)間:2025/5/22 数据库 17 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SQLITE中原子提交的实现 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

轉(zhuǎn)自:http://blog.csdn.net/LocalVar/archive/2008/02/13/3620555.aspx

?

1.??? 引言

像SQLITE這樣支持事務(wù)的數(shù)據(jù)庫的一個(gè)重要特性是“原子提交”。原子提交意味著,一個(gè)事務(wù)中的所有修改動作要么全都發(fā)生,要么一個(gè)都不發(fā)生。有了原子提交,對一個(gè)數(shù)據(jù)庫文件不同部分的多次寫操作,就會像瞬間同時(shí)完成了一樣。當(dāng)然,現(xiàn)實(shí)中的存儲器硬件會把寫操作串行化,并且寫每個(gè)扇區(qū)都會花上那么一小段時(shí)間,所以,絕對意義上的“瞬間同時(shí)完成”是不可能的。但SQLITE的原子提交邏輯還是讓整個(gè)過程看起來像那么回事。

SQLITE保證,即使事務(wù)執(zhí)行過程中發(fā)生了操作系統(tǒng)崩潰或掉電,整個(gè)事務(wù)也是原子的。本文描述了SQLITE實(shí)現(xiàn)原子提交時(shí)所采用的技術(shù)。

2.??? 對硬件的假設(shè)

雖然有的時(shí)候會使用閃存,但下文中,我們將把存儲設(shè)備稱為“磁盤”。

我們假設(shè)對磁盤的寫操作是以“扇區(qū)”為單位的,也就是說不可能直接對磁盤進(jìn)行小于一個(gè)扇區(qū)的修改,要想進(jìn)行這類修改,你必須把整個(gè)扇區(qū)讀進(jìn)內(nèi)存,進(jìn)行所需的修改,然后再把整個(gè)扇區(qū)寫回去。

對真正“磁盤”來說,讀寫操作的最小單位都是一個(gè)扇區(qū);但閃存有些不同,它們的最小讀單位一般遠(yuǎn)小于最小寫單位。SQLITE只關(guān)心最小寫單位,所以,在本文中,我們說“扇區(qū)”的時(shí)候,指的是向存儲器中寫數(shù)據(jù)時(shí)的最小數(shù)據(jù)量。

3.3.14版之前,SQLITE在任何情況下都認(rèn)為一個(gè)扇區(qū)的大小是512字節(jié),有一個(gè)編譯期選項(xiàng)能改變這個(gè)值,但從未有人用更大一些的值測試過相關(guān)代碼。直到不久以前,把這個(gè)值定為512都是合理的,因?yàn)樗械拇疟P驅(qū)動器都在內(nèi)部使用512字節(jié)的扇區(qū)。但最近,有人把磁盤扇區(qū)的大小提升到了4096字節(jié),而且,閃存的扇區(qū)一般也是大于512字節(jié)的。由于這些原因,從3.3.14版開始,SQLITE的操作系統(tǒng)接口層提供了一種可以從文件系統(tǒng)獲取真實(shí)扇區(qū)大小的方法。不過,到目前為止(3.5.0版),這一方法仍然只是返回一個(gè)硬編碼的512字節(jié),因?yàn)椴徽撌莣in32系統(tǒng)還是unix系統(tǒng),都沒有一個(gè)標(biāo)準(zhǔn)的機(jī)制來獲得實(shí)際的值。但這種方法給了嵌入式設(shè)備的提供商們根據(jù)實(shí)際情況進(jìn)行調(diào)整的能力,也讓我們未來在win32和unix上給出一個(gè)更有意義的實(shí)現(xiàn)成了可能。

SQLITE并不假設(shè)對扇區(qū)的寫操作是原子的,它僅假設(shè)這種寫是“線性”的。所謂線性是指:寫一個(gè)扇區(qū)時(shí),硬件總是從扇區(qū)一端開始,一個(gè)字節(jié)一個(gè)字節(jié)的寫到另一端結(jié)束,中間不會后退,硬件可以從頭向尾寫,也可以從尾向頭寫。如果掉電發(fā)生時(shí)只寫到了扇區(qū)的中間,則可能出現(xiàn)扇區(qū)一部分修改了而另一部分沒被修改的情況。SQLITE在這里做的一個(gè)關(guān)鍵假設(shè)是:只要扇區(qū)被修改了,那么它的第一個(gè)字節(jié)和最后一個(gè)字節(jié)中的至少一個(gè)會被修改,也就是說,硬件絕不會從中間開始向兩端寫。我們不清楚這個(gè)假設(shè)是否總是對的,但它看起來是合理的。

在上一段中,我們說“SQLITE沒有假設(shè)寫扇區(qū)是原子的”。默認(rèn)情況下,這是正確的,但在3.5.0版中,我們增加了一個(gè)叫做“虛擬文件系統(tǒng)(VFS)”的接口,它是SQLITE和底層文件系統(tǒng)通訊的唯一路徑。代碼中包含了用于unix和windows的默認(rèn)VFS實(shí)現(xiàn),同時(shí)提供了一種在運(yùn)行時(shí)創(chuàng)建新VFS實(shí)現(xiàn)的機(jī)制。在這個(gè)新的VFS接口中有一個(gè)稱為“xDeviceCharacteristics”的方法,它通過詢問文件系統(tǒng)來判斷文件系統(tǒng)是否支持某些特性。如果文件系統(tǒng)支持某個(gè)特性,SQLITE就會試著利用這個(gè)特性進(jìn)行某種優(yōu)化。默認(rèn)的xDeviceCharacteristics不會指出文件系統(tǒng)支持原子的寫扇區(qū)操作,所以與此相關(guān)的優(yōu)化都是關(guān)閉的。

SQLITE假設(shè)操作系統(tǒng)會緩沖寫操作,并且寫操作會在數(shù)據(jù)被真正寫到磁盤上之前返回。SQLITE還假設(shè)寫操作會被操作系統(tǒng)記錄下來。因此,SQLITE會在關(guān)鍵點(diǎn)上執(zhí)行“flush”或“fsync”,并假設(shè)“flush”和“fsync”會等所有正在進(jìn)行的“寫操作”真正執(zhí)行完畢后才返回。在某些版本的windows和unix上,“flush”和“fsync”原語會被打斷,這非常不幸,在這些系統(tǒng)上,如果提交的過程中發(fā)生了掉電,SQLITE的數(shù)據(jù)庫有可能崩潰掉,而SQLITE自己則對此無能為力。SQLITE假設(shè)操作系統(tǒng)能像廣告宣傳的那樣完美,如果事實(shí)并非如此,你只好祈求老天保佑不要經(jīng)常掉電了。

SQLITE假設(shè)文件增長時(shí),新增加的部分最初包含的是垃圾數(shù)據(jù),然后它們會被實(shí)際的數(shù)據(jù)覆蓋掉。換句話說,SQLITE假設(shè)文件大小的變化發(fā)生在文件內(nèi)容變化之前。這是個(gè)悲觀的假設(shè),為了保證在從“文件大小改變”開始到“文件內(nèi)容寫完”為止的這段時(shí)間內(nèi),系統(tǒng)掉電不會導(dǎo)致數(shù)據(jù)庫崩潰,SQLITE要做一些額外的工作。VFS的xDeviceCharacteristics也可能會指出文件系統(tǒng)總是先寫數(shù)據(jù)后更新文件的大小,這種情況下,SQLITE可以跳過一些過于小心的數(shù)據(jù)庫保護(hù)操作,從而減少一次提交所需的磁盤I/O數(shù)量。但目前windows和unix上的VFS實(shí)現(xiàn)都沒有做這個(gè)假設(shè)。

SQLITE假設(shè)文件刪除是原子的,至少從用戶程序的角度來看要是這樣。也就是說,如果SQLITE要刪除一個(gè)文件,并且刪除的過程中掉電了,那么電力恢復(fù)后,文件要么不能從文件系統(tǒng)中找到,要么它的內(nèi)容和刪除之前一模一樣。如果文件還能從文件系統(tǒng)中找到,但內(nèi)容被修改或清空了,那么數(shù)據(jù)庫極有可能會崩潰。

SQLITE假設(shè)檢測由宇宙射線、熱噪聲、驅(qū)動程序bug等引起的位錯(cuò)誤(bit error)是操作系統(tǒng)和硬件的責(zé)任。SQLITE沒有在數(shù)據(jù)庫文件中增加任何冗余信息來檢測或糾正這類問題。SQLITE假設(shè)它所讀的數(shù)據(jù)與它上次所寫的數(shù)據(jù)總是完全相同。

3.??? 單文件提交

我們先來從整體上看看SQLITE在一個(gè)單獨(dú)的數(shù)據(jù)庫文件上操作時(shí),要保證事務(wù)提交的原子性需要哪些步驟。為防止掉電時(shí)文件被破壞,文件格式在設(shè)計(jì)時(shí)也有相應(yīng)考慮,相關(guān)細(xì)節(jié)和多數(shù)據(jù)庫提交技術(shù)將在后續(xù)章節(jié)討論。

3.1.??? 初始狀態(tài)

下圖給出了數(shù)據(jù)庫連接剛剛打開時(shí)計(jì)算機(jī)的狀態(tài)。圖的最右側(cè)是存儲在磁盤上的數(shù)據(jù),每個(gè)小格代表一個(gè)扇區(qū),藍(lán)色表示扇區(qū)存儲的是原始數(shù)據(jù);圖的中間部分是操作系統(tǒng)的緩存,在當(dāng)前的例子中,緩存是“冷”的,所以它的每個(gè)格都沒有著色;最左側(cè)是使用SQLITE的進(jìn)程(譯注:本文的作者可能更喜歡unix,所以在windows上,原文中的部分“進(jìn)程”用“線程”替換一下會更好,我沒有做這種替換,故需要您在閱讀過程中結(jié)合上下文判斷“進(jìn)程”的具體含義)的內(nèi)存,數(shù)據(jù)庫連接剛剛創(chuàng)建,還沒有讀任何數(shù)據(jù),所以用戶的內(nèi)存空間中什么也沒有。

3.2.??? 獲取一個(gè)“讀鎖”

SQLITE寫數(shù)據(jù)庫之前,必須先讀,這樣它才能知道數(shù)據(jù)庫中已經(jīng)有些什么了。即使是單純的追加數(shù)據(jù),SQLITE也要先從sqlite_master表中讀出數(shù)據(jù)庫的表結(jié)構(gòu),從而知道如何去解析INSERT語句,以及新數(shù)據(jù)應(yīng)該保存到文件的哪個(gè)位置。

讀操作的第一步是獲取一個(gè)數(shù)據(jù)庫文件的“共享鎖”。這個(gè)共享鎖允許兩個(gè)或多個(gè)數(shù)據(jù)庫連接同時(shí)讀數(shù)據(jù)庫文件,但不許其他數(shù)據(jù)庫連接寫這個(gè)文件。這個(gè)鎖非常重要,因?yàn)?#xff0c;如果在讀數(shù)據(jù)的過程中另一個(gè)連接寫了數(shù)據(jù),我們就可能讀到一個(gè)新數(shù)據(jù)和舊數(shù)據(jù)的混合體,這會讓其他連接的寫操作失去原子性。

請注意,共享鎖是操作系統(tǒng)的磁盤緩存實(shí)現(xiàn)的,而不是磁盤本身。一般來說,文件鎖僅僅是操作系統(tǒng)內(nèi)核中的一些標(biāo)志(細(xì)節(jié)取決于具體操作系統(tǒng)的接口層)。所以,當(dāng)系統(tǒng)崩潰或掉電后,這個(gè)鎖就自動消失了。并且,通常情況下,創(chuàng)建這個(gè)鎖的進(jìn)程退出后,鎖也會自動消失。

3.3.??? 從數(shù)據(jù)庫中讀數(shù)據(jù)

獲得共享鎖后,我們開始從數(shù)據(jù)庫文件中讀出數(shù)據(jù)。在這個(gè)例子中,由于我們假設(shè)最初的緩存是“冷”的,所以要先把數(shù)據(jù)從磁盤讀到操作系統(tǒng)的緩存,再把它們從緩存復(fù)制到用戶空間。后續(xù)的讀操作,由于部分或全部數(shù)據(jù)可能已經(jīng)在緩存中了,或許就只需要從緩存復(fù)制到用戶空間這一步了。

一般情況下,我們不會需要數(shù)據(jù)庫文件的所有頁(譯注:頁是SQLITE對數(shù)據(jù)進(jìn)行緩沖的最小單位,但本文中有時(shí)它和扇區(qū)是一個(gè)意思,請注意結(jié)合上下文區(qū)分),所以我們讀的只是它的一個(gè)子集。本例中,我們的數(shù)據(jù)庫文件有8個(gè)頁,而我們需要的是其中的3個(gè)。一個(gè)真實(shí)的數(shù)據(jù)庫可能有數(shù)千個(gè)頁,但每次查詢要訪問的一般只是其中很小的一部分。

3.4.??? 獲取一個(gè)預(yù)定(Reserved)鎖

在對數(shù)據(jù)庫做任何修改之前,SQLITE需要獲得一個(gè)預(yù)定鎖。預(yù)定鎖和共享鎖很像,它們都允許其他進(jìn)程讀數(shù)據(jù)庫文件。并且,預(yù)定鎖也可以和多個(gè)共享鎖共存。但是,一個(gè)數(shù)據(jù)庫文件某一時(shí)刻只能有一個(gè)預(yù)定鎖,也就是只允許一個(gè)進(jìn)程有寫數(shù)據(jù)的意圖。

預(yù)定鎖的目的是告訴整個(gè)系統(tǒng):有一個(gè)進(jìn)程要在不久的將來修改數(shù)據(jù)庫文件了,但它目前還沒有任何實(shí)際行動。由于僅僅是個(gè)“意圖”,其他進(jìn)程還可以繼續(xù)自己的讀操作,但是它們不能也有這個(gè)意圖了。

3.5.??? 創(chuàng)建回滾日志(Journal)文件

在任何實(shí)質(zhì)性的修改之前,SQLITE還需要創(chuàng)建一個(gè)獨(dú)立的回滾日志文件,并把所有要被替換的數(shù)據(jù)庫頁的原始內(nèi)容寫到這個(gè)文件中去。實(shí)際上,日志文件將保存將數(shù)據(jù)庫文件恢復(fù)到原始狀態(tài)所需的全部信息。

日志文件有一個(gè)不大的文件頭(圖中用綠色表示),它記錄了數(shù)據(jù)庫文件的原始大小。如果數(shù)據(jù)庫文件因?yàn)樾薷淖兇罅?#xff0c;我們?nèi)匀豢梢詰{它來獲得文件的原始大小。數(shù)據(jù)庫頁和它們的對應(yīng)的頁號會被放在一起寫到日志文件中去。

創(chuàng)建新文件時(shí),大多數(shù)操作系統(tǒng)(windows、linux、macOSX等)并不會立即向磁盤寫數(shù)據(jù)。新文件一開始只存在于操作系統(tǒng)的緩存中,直到操作系統(tǒng)有空閑的時(shí)候,它才會真的去在磁盤上創(chuàng)建這個(gè)文件。這種方式讓用戶覺得文件創(chuàng)建非常快,起碼比真的去做磁盤I/O快多了。在下圖中,為了表示這一情形,我們只在操作系統(tǒng)緩存中畫了這個(gè)日志文件。

3.6.??? 在用戶空間中修改數(shù)據(jù)庫

數(shù)據(jù)庫頁的原始內(nèi)容保存到日志文件后,就可以在用戶空間中修改了。每個(gè)數(shù)據(jù)庫連接有一份私有的用戶空間拷貝,所以這些修改只會被當(dāng)前的連接看到,其他連接看到的仍然是操作系統(tǒng)緩存中未被修改的內(nèi)容。在這種情況下,雖然有一個(gè)進(jìn)程正在對數(shù)據(jù)庫進(jìn)行修改,其他進(jìn)程仍然可以繼續(xù)讀數(shù)據(jù)庫的原始內(nèi)容。

3.7.??? 把日志文件“刷”到磁盤

下一步是把回滾日志文件的內(nèi)容刷到具有持久性的存儲器上。后面你會看到,這是讓數(shù)據(jù)庫能夠在掉電情況下存活的關(guān)鍵之一。它可能要花不少時(shí)間,因?yàn)橥志眯源鎯ζ魃蠈憱|西一般是很慢的。

這一步通常比僅僅把回滾日志刷到磁盤上復(fù)雜的多。在大多數(shù)平臺上,你要刷(flush或fsync)兩次才行。第一次是日志文件的基本內(nèi)容。然后修改日志文件的頭部,以反應(yīng)日志文件中實(shí)際的頁面數(shù)。接著刷第二次,把文件頭刷上去。至于為什么要修改文件頭并多刷一次,我們將在后續(xù)章節(jié)討論。

3.8.??? 獲取一個(gè)獨(dú)占鎖

為了對數(shù)據(jù)庫文件進(jìn)行真正的修改,我們需要一個(gè)獨(dú)占鎖。獲取這個(gè)鎖需要兩步,首先是獲取一個(gè)待決(Pending)鎖,然后再把它提升為獨(dú)占鎖。

待決鎖允許其他已經(jīng)有了共享鎖的進(jìn)程繼續(xù)讀數(shù)據(jù)庫文件,但它不允許創(chuàng)建新的共享鎖。設(shè)計(jì)它的目的是為了避免一大堆讀進(jìn)程把寫進(jìn)程給餓到。系統(tǒng)中可能會有幾十甚至上百個(gè)進(jìn)程想讀數(shù)據(jù)庫文件,每個(gè)這樣的進(jìn)程都要經(jīng)歷一個(gè)“獲得共享鎖、讀數(shù)據(jù)、釋放鎖”的過程。如果很多進(jìn)程都想讀同一個(gè)數(shù)據(jù)庫文件,那么一個(gè)極有可能現(xiàn)象是:新進(jìn)程總是在已有的進(jìn)程釋放共享鎖之前獲得一個(gè)新的共享鎖。這樣一來,數(shù)據(jù)庫文件就上就總有共享鎖了,要寫數(shù)據(jù)的進(jìn)程可能會一直沒有機(jī)會得到自己的獨(dú)占鎖。通過禁止創(chuàng)建新的共享鎖,待決鎖解決了這個(gè)問題,已有的共享鎖會逐漸被釋放,最終,當(dāng)它們?nèi)勘会尫藕?#xff0c;待決鎖就可以升級到獨(dú)占鎖了。

3.9.??? 更新數(shù)據(jù)庫文件

一旦獲得獨(dú)占鎖,就可以保證沒有其他進(jìn)程在讀這個(gè)數(shù)據(jù)庫文件了,這時(shí)更新它就是安全的了。一般來說,這里的更新只會影響到操作系統(tǒng)磁盤緩存這一層,而不會影響磁盤上的物理文件。

3.10.??? 把變化刷到存儲器

為了把數(shù)據(jù)庫的變化寫到持久性存儲器,我們還要再刷一次。這也是保證數(shù)據(jù)庫在掉電情況下不崩潰的關(guān)鍵。當(dāng)然,向磁盤或閃存寫數(shù)據(jù)實(shí)在是太慢了,這一步和3.7節(jié)中的刷日志文件加在一起會消耗掉SQLITE一次事務(wù)提交的絕大部分時(shí)間。

3.11.??? 刪除日志文件

把所有變化都安全的寫到存儲器上以后,回滾日志文件就可以刪除了。這是提交事務(wù)的那個(gè)時(shí)間點(diǎn)。如果掉電或系統(tǒng)崩潰發(fā)生在這之前,后面將要介紹的恢復(fù)過程會讓數(shù)據(jù)庫文件回到修改之前的狀態(tài),就好像什么都沒發(fā)生過一樣。如果掉電或系統(tǒng)崩潰發(fā)生在日志文件被刪除之后,那么所有的修改都會生效。所以,SQLITE對數(shù)據(jù)庫的修改全部有效還是全部無效,實(shí)際上是取決于這個(gè)日志文件是否存在。

刪除文件不一定真的是原子操作,但從用戶程序的角度來看,它卻好像總是原子的。進(jìn)程總可以詢問操作系統(tǒng)“這個(gè)文件存在嗎?”并等到是或否的回答。如果事務(wù)提交過程中發(fā)生了掉電,SQLITE就會問操作系統(tǒng)是否存在回滾日志文件,存在則事務(wù)是不完整的,需要回滾,不存在則說明事務(wù)確實(shí)成功提交了。

SQLITE事務(wù)的實(shí)現(xiàn)依賴于回滾日志文件是否存在和用戶程序眼中的原子的文件刪除。所以,事務(wù)也是一個(gè)原子操作。

3.12.??? 釋放鎖

最后一步是釋放獨(dú)占鎖,這樣其他進(jìn)程就又能訪問數(shù)據(jù)庫文件了。

在下圖中,我們看到,用戶空間中的數(shù)據(jù)在鎖被釋放后就清除了。如果是較早版本的SQLITE,這是實(shí)際情況。但從最近幾版開始,SQLITE不這么做了,因?yàn)橄聜€(gè)操作可能還會用到它們。比起從操作系統(tǒng)的緩存或磁盤中讀數(shù)據(jù)來,重用這些已經(jīng)在本地內(nèi)存中的數(shù)據(jù)的性能要高得多。再次使用它們之前,我們要先得到一個(gè)共享鎖,然后再檢查一下在我們沒有鎖的這段時(shí)間內(nèi)是否有別的進(jìn)程修改了數(shù)據(jù)庫文件。數(shù)據(jù)庫的第一頁有一個(gè)計(jì)數(shù)器,每次對數(shù)據(jù)庫進(jìn)行修改時(shí)都會遞增它。檢查這個(gè)計(jì)數(shù)器,就能知道數(shù)據(jù)庫是否被別的進(jìn)程修改過了。如果修改過,就必須清除用戶空間中的數(shù)據(jù)并把新數(shù)據(jù)讀進(jìn)來。但更大的可能是沒有任何修改,這樣就可以重用原有的數(shù)據(jù),從而大幅提高效率。

4.??? 回滾

原子提交看起來是瞬間完成的,但很明顯,前面介紹的過程需要一定的時(shí)間才能完成。如果在提交過程中電源被切斷,為了讓整個(gè)過程看起來是瞬時(shí)的,我們必須回滾那些不完整的修改,并把數(shù)據(jù)庫恢復(fù)到事務(wù)開始之前的狀態(tài)。

4.1.??? 如果出了問題…

假設(shè)掉電發(fā)生在3.10節(jié)所講的那一步,也就是把數(shù)據(jù)庫變化刷到磁盤中去的時(shí)侯。電力恢復(fù)后,情況可能會像下圖所示的那樣。我們要修改三頁數(shù)據(jù),但只成功完成了一頁,有一頁只寫了一部分,另一頁則一點(diǎn)都沒寫。

電力恢復(fù)后日志文件是完整的,這是個(gè)關(guān)鍵。3.7節(jié)中的操作就是為了保證在對數(shù)據(jù)文件做任何改變之前回滾日志的所有內(nèi)容已經(jīng)安全的寫到持久性存儲器中去了。

4.2.??? “熱的”回滾日志

任何進(jìn)程第一次訪問數(shù)據(jù)庫文件之前,必須獲得一個(gè)3.2節(jié)中描述的共享鎖。然后,如果發(fā)現(xiàn)還有一個(gè)日志文件,SQLITE就會檢查這個(gè)回滾日志是不是“熱的”。我們必須回放熱日志文件,從而把數(shù)據(jù)庫恢復(fù)到一致的狀態(tài)。只有在一個(gè)程序正在提交事務(wù)時(shí)發(fā)生掉電或崩潰的情況下,才會出現(xiàn)熱日志文件。

日志文件在符合以下所有條件時(shí)才是熱的:
● 日志文件是存在的
● 日志文件不是空文件
● 數(shù)據(jù)庫文件上沒有預(yù)定鎖
● 日志文件頭中沒有主日志文件的文件名,或者,如果有主日志文件名的話,主日志文件是存在的。

熱日志文件告訴我們:之前有進(jìn)程試圖提交一個(gè)事務(wù),但由于某種原因,這個(gè)提交沒有完成。也就是說:數(shù)據(jù)庫處于一種不一致的狀態(tài),使用之前必須修復(fù)(回滾)。

4.3.??? 獲取數(shù)據(jù)庫上的獨(dú)占鎖

處理熱日志的第一步是獲得數(shù)據(jù)庫文件上的獨(dú)占鎖,這可以防止兩個(gè)或更多的進(jìn)程同時(shí)回放一個(gè)熱日志。

4.4.??? 回滾不完整的修改

獲得了獨(dú)占鎖,進(jìn)程就有權(quán)力修改數(shù)據(jù)庫文件了。它從日志中讀出頁面的原有內(nèi)容,然后把它們分別寫回到其在數(shù)據(jù)庫文件中的原始位置上去。前面說過,日志文件的頭部記錄了數(shù)據(jù)庫文件在事務(wù)開始前的大小,如果修改讓數(shù)據(jù)庫文件變大了,SQLITE會使用這一信息把文件截?cái)嗟皆即笮 _@一步結(jié)束之后,數(shù)據(jù)庫文件就應(yīng)該和事務(wù)開始前一樣大,并且包含和那時(shí)完全一樣的數(shù)據(jù)了。

4.5.??? 刪除熱日志文件

日志中的所有信息都回放到數(shù)據(jù)庫文件,并將數(shù)據(jù)庫文件刷到磁盤(回滾時(shí)可能會再次掉電)以后,就可以刪除熱日志文件了。

4.6.??? 繼續(xù)前進(jìn),就像那個(gè)中斷了的事務(wù)根本沒發(fā)生過一樣

回滾的最后一步是把獨(dú)占鎖降級為共享鎖。此后,數(shù)據(jù)庫的狀態(tài)看起來就像那個(gè)中斷了的事務(wù)根本沒有開始過一樣了。由于整個(gè)回滾過程是完全自動、透明的,使用SQLITE的那個(gè)程序根本就不會知道有一個(gè)事務(wù)中斷并回滾了。

5.??? 多文件提交

通過ATTACHDATABASE命令,SQLITE允許一個(gè)數(shù)據(jù)庫連接使用多個(gè)數(shù)據(jù)庫文件。當(dāng)在一個(gè)事務(wù)中修改多個(gè)文件時(shí),所有文件都會被原子的更新。換句話說,或者所有文件都會被更新,或者一個(gè)也不會被更新。在多個(gè)文件上實(shí)現(xiàn)原子提交比在單個(gè)文件上實(shí)現(xiàn)更復(fù)雜,本章將解釋SQLITE是如何做到這一點(diǎn)的。

5.1.??? 每個(gè)數(shù)據(jù)庫一個(gè)日志

當(dāng)一個(gè)事務(wù)涉及了多個(gè)數(shù)據(jù)庫文件時(shí),每個(gè)數(shù)據(jù)庫都有自己回滾日志,并且對它們的鎖也是各自獨(dú)立的。下圖展示了三個(gè)數(shù)據(jù)庫文件在一個(gè)事務(wù)中被修改的情況,它所描述的狀態(tài)相當(dāng)于單文件事務(wù)在第3.6節(jié)中的狀態(tài)。每個(gè)數(shù)據(jù)庫文件有各自的預(yù)定鎖,它們將要被修改的那些頁的原始內(nèi)容已經(jīng)寫進(jìn)回滾日志了,但還沒有刷到磁盤上。用戶內(nèi)存中的數(shù)據(jù)已經(jīng)被修改了,不過數(shù)據(jù)庫文件本身還沒有任何變化。
相比之前,下圖做了一些簡化。在這張圖上,藍(lán)色仍然代表原始數(shù)據(jù),粉紅色仍然代表新數(shù)據(jù)。但上面沒有畫出回滾日志和數(shù)據(jù)庫的頁,并且也沒有明確區(qū)分操作系統(tǒng)緩存中的數(shù)據(jù)和磁盤上的數(shù)據(jù)。所有這些在這張圖上仍然適用,不過即使把它們畫出來我們也學(xué)不到什么新的東西,所以,為了縮小圖幅,我們把它們省略掉了。

5.2.??? 主日志文件

多文件提交中的下一步是創(chuàng)建一個(gè)“主日志文件”。這個(gè)文件的名字是最初的數(shù)據(jù)庫文件名(也就是用sqlite3_open()打開的那個(gè)數(shù)據(jù)庫,而不是之后附加上來的那些)加上后綴“-mjHHHHHHHH”。其中HHHHHHHH是一個(gè)32位16進(jìn)制隨機(jī)數(shù),每次生成新的主日志文件時(shí),它都會不同。

(注意:上面一段中用來生成主日志文件名的方法是3.5.0版中使用的方法。這個(gè)方法并沒有規(guī)范化,也不是SQLITE對外接口的一部分,在未來版本中,我們可能會修改它。)

主日志中沒有與原始數(shù)據(jù)庫頁面內(nèi)容相關(guān)的信息,它里面保存的是所有參與到這個(gè)事務(wù)中的回滾日志文件的完整路徑。

主日志生成完畢后,會被立即刷到磁盤上,中間沒有任何別的操作。在unix系統(tǒng)上,主日志所在的目錄,也會被同步一下,以確保掉電后它也會出現(xiàn)在這個(gè)目錄下。

5.3.??? 更新回滾日志文件頭

下一步是把主日志的路徑記錄到回滾日志的文件頭中去,回滾日志創(chuàng)建時(shí)在文件頭預(yù)留了相應(yīng)的空間。

主日志路徑寫到回滾日志文件頭之前和之后,要分別把回滾日志的內(nèi)容往磁盤上刷一次。這可能有些效率損失,但非常重要,而且,幸運(yùn)的是,刷第二次時(shí)一般只有一頁(最開始的那頁)數(shù)據(jù)有變化,所以整個(gè)操作可能并沒有想象的那么慢。

這個(gè)操作大致相當(dāng)于單文件提交時(shí)的第7步,也就是第3.7節(jié)中的內(nèi)容。

5.4.??? 更新數(shù)據(jù)庫文件

把回滾日志刷到磁盤上后,就可以安全的更新數(shù)據(jù)庫文件了。我們需要獲得所有數(shù)據(jù)庫文件上的獨(dú)占鎖,然后寫數(shù)據(jù),并把這些數(shù)據(jù)刷到磁盤上去。這一步相當(dāng)于單文件提交時(shí)的第8、9和10步。

5.5.??? 刪除主日志文件

下一步是刪除主日志文件,這是多文件事務(wù)被實(shí)際提交的時(shí)間點(diǎn)。它相當(dāng)于單文件提交時(shí)的第11步,也就是刪除日志文件的那一步。
如果掉電或系統(tǒng)崩潰發(fā)生在這之后,重啟時(shí),即使存在回滾日志文件,事務(wù)也不會被回滾。這里的區(qū)別在于回滾日志的文件頭里面有主日志的路徑。SQLITE只認(rèn)為文件頭中沒有主日志文件路徑的回滾日志(單文件提交的情況)或主日志文件仍然存在的回滾日志是“熱的”,并且只會回放熱的回滾日志。

5.6.??? 清理回滾日志文件

最后是刪除所有的回滾日志文件,釋放獨(dú)占鎖以便其他進(jìn)程發(fā)現(xiàn)數(shù)據(jù)的變化。這一步對應(yīng)的是單文件提交時(shí)的第12步。

由于事務(wù)已經(jīng)提交了,所以刪除這些文件在時(shí)間上并不是非常緊迫。當(dāng)前的實(shí)現(xiàn)是刪除一個(gè)日志文件,并釋放其對應(yīng)的數(shù)據(jù)庫文件上的獨(dú)占鎖,然后再接著處理下一個(gè)。今后,我們可能把它改成先刪除所有日志文件,再釋放獨(dú)占鎖。這里,只要保證刪除日志文件在前,釋放其對應(yīng)的鎖在后就行,文件被刪除的順序或鎖被釋放的順序并不重要。

6.??? 提交中的更多細(xì)節(jié)

第3章從總體上介紹了SQLITE原子提交的實(shí)現(xiàn)方法,但漏掉了幾個(gè)重要的細(xì)節(jié),本章將對它們進(jìn)行一些補(bǔ)充說明。

6.1.??? 總是日志中記錄整個(gè)扇區(qū)

在把數(shù)據(jù)庫頁面的原始內(nèi)容寫進(jìn)回滾日志時(shí),即使頁面比扇區(qū)小,SQLITE也會把完整的扇區(qū)寫進(jìn)去。從前,SQLITE中的扇區(qū)大小是硬編碼的512字節(jié),而最小頁面也是512字節(jié),所以不會有什么問題。但從3.3.14版開始,SQLITE也支持扇區(qū)大小超過512字節(jié)的存儲器了,所以,從這一版起,當(dāng)某個(gè)扇區(qū)中的任何頁面被寫進(jìn)日志時(shí),這個(gè)扇區(qū)中的其它頁面也會被一同寫進(jìn)去。

掉電可能在寫扇區(qū)時(shí)發(fā)生,總是記錄整個(gè)扇區(qū)可以在這種情況下保證數(shù)據(jù)庫不被破壞。例如,我們假設(shè)每個(gè)扇區(qū)有四個(gè)頁面,現(xiàn)在2號頁面被修改了,為了把變化寫入這個(gè)頁面,底層硬件,因?yàn)樗荒軐懲暾纳葏^(qū),也會把1、3、4號頁面重新寫一遍,如果寫操作被打斷,這三個(gè)頁面的數(shù)據(jù)可能就不對了。為了避免這種情況,必須把扇區(qū)中的所有頁面寫到回滾日志中去。

6.2.??? 日志文件中的垃圾數(shù)據(jù)

向日志文件末尾追加數(shù)據(jù)時(shí),SQLITE一般悲觀的假設(shè)文件系統(tǒng)會先用垃圾數(shù)據(jù)把文件撐大,再用正確的數(shù)據(jù)覆蓋這些垃圾。換句話說,SQLITE假設(shè)文件體積先變大,之后才是寫入實(shí)際內(nèi)容。如果掉電發(fā)生在文件已經(jīng)變大但數(shù)據(jù)還未寫入時(shí),回滾日志中就會包含垃圾數(shù)據(jù)。電力恢復(fù)后,另一個(gè)SQLITE進(jìn)程會發(fā)現(xiàn)這個(gè)日志文件,并試圖恢復(fù)它,這就有可能把垃圾數(shù)據(jù)拷貝到數(shù)據(jù)庫文件,進(jìn)而對其造成破壞。

為對付這個(gè)問題,SQLITE建立了兩道防線。首先,SQLITE在回滾日志的文件頭中記錄了實(shí)際的頁面數(shù)。這個(gè)數(shù)字一開始是0,所以,在回放一個(gè)不完整的回滾日志時(shí),SQLITE會發(fā)現(xiàn)文件中沒有包含任何頁面,也就不會對數(shù)據(jù)庫做任何修改。提交之前,回滾日志會被刷到磁盤上,以保證其中沒有任何垃圾。之后,文件頭中的頁面數(shù)才會被改成實(shí)際的數(shù)值。文件頭總是保存在一個(gè)單獨(dú)的扇區(qū)去,所以,如果在覆蓋它或把它刷到磁盤上時(shí)發(fā)生掉電,其它頁面是不會被破壞的。注意回滾日志要往磁盤上刷兩次:第一次是寫頁面的原始內(nèi)容,第二次是寫文件頭中的頁面數(shù)。

上一段描述的是同步選項(xiàng)設(shè)置為“full”(PRAGMAsynchronous=FULL)時(shí)的情形,這也是默認(rèn)的設(shè)置。不過,當(dāng)同步選項(xiàng)低于“normal”時(shí),SQLITE只會刷一次日志文件,也就是修改完頁面數(shù)后的那一次。由于(大于0的)頁面數(shù)可能先于其它數(shù)據(jù)到達(dá)磁盤,這樣做有一定的風(fēng)險(xiǎn)。SQLITE假設(shè)文件系統(tǒng)會記錄寫請求,所以即使先寫數(shù)據(jù)后寫頁面數(shù),頁面數(shù)也可能會先被磁盤記錄下來。所以,作為第二道防線,SQLITE在日志文件中為每頁數(shù)據(jù)都記錄了一個(gè)32位的校驗(yàn)碼。回滾日志文件時(shí),SQLITE會檢查這個(gè)校驗(yàn)碼,一旦發(fā)現(xiàn)錯(cuò)誤,就會放棄回滾操作。要注意的是,校驗(yàn)碼無法完全保證頁面數(shù)據(jù)的正確性,數(shù)據(jù)有錯(cuò)誤但校驗(yàn)碼正確的概率雖然極小,卻不是零.。不過,校驗(yàn)碼機(jī)制至少讓類似的事情看起來不那么容易發(fā)生了。

在同步選項(xiàng)設(shè)置為“full”時(shí),就沒有必要用校驗(yàn)碼了,我們只在同步選項(xiàng)低于“normal”時(shí)才需要它。然而,鑒于校驗(yàn)碼是無害的,故不管同步選項(xiàng)如何設(shè)置,它們總是出現(xiàn)在回滾日志中的。

6.3.??? 提交之前的緩存溢出

第三章描述的過程假設(shè)提交之前所有的數(shù)據(jù)庫變化都能保存在內(nèi)存中。一般來說就是這樣的,但特殊情況也會出現(xiàn)。這時(shí),數(shù)據(jù)庫變化會在事務(wù)提交之前用完用戶緩存,需要把緩存中的內(nèi)容提前寫入數(shù)據(jù)庫才行。

操作之前,數(shù)據(jù)庫連接處于第3.6步時(shí)的狀態(tài):原始頁面的內(nèi)容已經(jīng)保存到回滾日志了,修改后的頁面位于用戶內(nèi)存中。為了回收緩存,SQLITE執(zhí)行第3.7到3.9步,也就是把回滾日志刷到磁盤上,獲取獨(dú)占鎖,然后把變化寫入數(shù)據(jù)庫。但后續(xù)步驟在事務(wù)真正提交之前都有所不同。SQLITE會在日志文件的最后追加一個(gè)文件頭(使用一個(gè)單獨(dú)的扇區(qū)),獨(dú)占鎖繼續(xù)保留,而執(zhí)行流程將跳到第3.6步。當(dāng)事務(wù)提交或再次回收緩存時(shí),將重復(fù)執(zhí)行第3.7和3.9步(由于第一次回收緩存時(shí)獲得了獨(dú)占鎖且一直沒有釋放,3.8步將被跳過)。

把預(yù)定鎖提升為獨(dú)占鎖將降低并發(fā)度,額外的刷磁盤操作也非常慢,所以回收緩存會嚴(yán)重影響系統(tǒng)效率。因此,只要有可能,SQLITE就不會使用它。

7.??? 優(yōu)化

對程序的性能分析顯示,在絕大多數(shù)系統(tǒng)和絕大多數(shù)情況下,SQLITE把絕大部分時(shí)間消耗在了磁盤I/O上。所以,減少磁盤I/O的數(shù)量是最有可能大幅提升效率的方法。本章將介紹SQLITE在保證原子提交的前提下,為減少磁盤I/O而使用的一些技術(shù)。

7.1.??? 在事務(wù)之間保持緩存數(shù)據(jù)

在3.12節(jié)中,我們說過當(dāng)釋放共享鎖時(shí)會丟棄所有已經(jīng)在用戶緩存中的數(shù)據(jù)庫信息。之所以這樣做,是因?yàn)闆]有共享鎖的時(shí)候其他進(jìn)程能夠隨意修改數(shù)據(jù)庫文件的內(nèi)容,從而導(dǎo)致已經(jīng)緩存的數(shù)據(jù)過時(shí)。所以,每當(dāng)一個(gè)新事務(wù)開始時(shí),SQLITE都必須重新讀一次以前讀過的東西。這個(gè)操作并不像大家想象的那么糟糕,因?yàn)橐匦伦x的數(shù)據(jù)極有可能仍在操作系統(tǒng)的緩存中,所謂的“重讀”一般僅僅是把數(shù)據(jù)從內(nèi)核空間拷貝到用戶空間而已。不過,即使如此,也是需要一些時(shí)間的。

從3.3.14版開始,我們在SQLITE中增加了一個(gè)機(jī)制來避免不必要的重讀。這些版本中,釋放共享鎖后,用戶緩存的頁面繼續(xù)保留。等到SQLITE啟動下一個(gè)事務(wù)并獲得共享鎖后,它會檢查是否有其他進(jìn)程修改了數(shù)據(jù)庫文件。如果自上次釋放鎖后有修改,用戶緩存會被清空并重讀。但一般不會有任何修改,所以用戶緩存仍然有效,這樣很多不必要的讀操作就被避免了。

為了判斷數(shù)據(jù)庫文件是否被修改,SQLITE在文件頭(第24到27字節(jié))中使用了一個(gè)計(jì)數(shù)器,每個(gè)修改操作都會遞增它。釋放數(shù)據(jù)庫鎖之前,SQLITE會記下這個(gè)計(jì)數(shù)器的值,等到再次獲得鎖以后,它比較記錄的值和實(shí)際的值,相同則重用已有的緩存數(shù)據(jù),不同則清空緩存并重讀。

7.2.??? 獨(dú)占訪問模式

自3.3.14版開始,SQLITE中增加了“獨(dú)占訪問模式”。在這種模式下,SQLITE會在事務(wù)提交后繼續(xù)保留獨(dú)占鎖。這樣一來,其他進(jìn)程就不能訪問數(shù)據(jù)庫了。不過,由于大多數(shù)的部署方案都只有一個(gè)進(jìn)程訪問數(shù)據(jù)庫,所以一般不會有什么問題。獨(dú)占訪問模式讓以下三個(gè)減少磁盤I/O的方法成為了可能:
1)??? 除了第一個(gè)事務(wù),不必每次遞增數(shù)據(jù)庫文件頭中的計(jì)數(shù)器。這通常意味著在數(shù)據(jù)庫文件和回滾日志中各自少刷一次1號頁面。?
2)??? 因?yàn)闆]有別的進(jìn)程能訪問數(shù)據(jù)庫,所以沒必要每次啟動事務(wù)時(shí)檢查計(jì)數(shù)器和清空用戶緩存。
3)??? 事務(wù)結(jié)束后可以截?cái)?#xff08;譯注:把文件長度設(shè)置為0字節(jié))回滾日志文件,而不是刪除它。在很多操作系統(tǒng)上,截?cái)啾葎h除快的多。

第三項(xiàng)優(yōu)化,也就是用截?cái)啻鎰h除,并不要求一直擁有獨(dú)占鎖。理論上說,總是實(shí)現(xiàn)它,而不是只在獨(dú)占訪問模式下實(shí)現(xiàn)它是可能的,也許我們會在未來版本中讓其成為現(xiàn)實(shí)。不過,到目前為止(3.5.0版),這項(xiàng)優(yōu)化仍然只在獨(dú)占訪問模式下有效。

7.3.??? 不記錄空閑頁面

從數(shù)據(jù)庫中刪除數(shù)據(jù)時(shí),那些不再使用的頁面會被加到“空閑頁表”里去。之后的插入操作將首先使用這些頁面,而不是擴(kuò)大數(shù)據(jù)庫文件。一些空閑頁面中也有重要數(shù)據(jù),比如說其他空閑頁面的位置等等。但大多數(shù)空閑頁面的內(nèi)容沒有用,我們把這些頁面稱為“葉頁”。修改葉頁的內(nèi)容對數(shù)據(jù)庫沒有任何影響。

由于葉頁的內(nèi)容沒用,SQLITE不會把它們在提交過程的第3.5步中記錄到回滾日志里去。也就是說,修改葉頁,但不在回滾過程中恢復(fù)它們對數(shù)據(jù)庫無害。同樣的,一個(gè)新葉頁的內(nèi)容既不會在第3.9步中寫入數(shù)據(jù)庫也不會在第3.3步中被讀出來。在數(shù)據(jù)庫文件有空閑空間時(shí),這項(xiàng)優(yōu)化大幅減少了磁盤I/O的數(shù)量。

7.4.??? 單頁更新和原子扇區(qū)寫

從3.5.0版開始,新的VFS接口包含了一個(gè)名叫xDeviceCharacteristics的方法,它可以報(bào)告底層存儲器是否支持一些特性。這些特性中,有一個(gè)是“原子扇區(qū)寫”。

我們前面說過,SQLITE假設(shè)寫扇區(qū)是線性的,而不是原子的。線性寫從扇區(qū)的一端開始,逐字節(jié)寫到另一端結(jié)束。如果在線性寫的中間發(fā)生掉電,則可能扇區(qū)的一端被修改了,另一端卻保持不變。但在原子寫的情況下,扇區(qū)或者被完全更新了,或者完全沒有變化。

我們相信大多數(shù)現(xiàn)在磁盤驅(qū)動器實(shí)現(xiàn)了原子扇區(qū)寫。掉電時(shí),驅(qū)動器使用電容中的電能和(或)盤片旋轉(zhuǎn)的動能完成正在進(jìn)行的操作。然而,在系統(tǒng)寫調(diào)用與磁盤電子元件之間存在太多的層次,所以我們在Unix和windows的默認(rèn)VFS實(shí)現(xiàn)上做了一個(gè)保守的假設(shè),認(rèn)為寫扇區(qū)不是原子的。另一方面,能對其使用的文件系統(tǒng)有更多發(fā)言權(quán)的設(shè)備廠商,如果它們的硬件確實(shí)支持原子扇區(qū)寫,也許會選擇打開xDeviceCharacteristics中的這個(gè)選項(xiàng)。

當(dāng)寫扇區(qū)是原子的、數(shù)據(jù)庫頁面和扇區(qū)一樣大,而且數(shù)據(jù)庫的變化只涉及到一個(gè)頁面時(shí),SQLITE會跳過整個(gè)記日志和同步過程,直接把修改后的頁面寫到數(shù)據(jù)庫文件上。數(shù)據(jù)庫文件第一頁上的修改計(jì)數(shù)器也會獨(dú)立修改,因?yàn)榧词乖诟滤暗綦娨彩菬o害的。
譯注:個(gè)人認(rèn)為,如果硬件不支持原子扇區(qū)寫,是無法在軟件層次上實(shí)現(xiàn)絕對意義上的原子提交的。

7.5.??? 支持安全追加的文件系統(tǒng)

3.5.0版加入的另一項(xiàng)優(yōu)化措施是基于文件系統(tǒng)的“安全追加”功能的。SQLITE假設(shè)向文件(特別是回滾日志文件)追加數(shù)據(jù)時(shí),文件大小的改變早于文件內(nèi)容增加。所以,如果掉電發(fā)生在文件變大之后,數(shù)據(jù)寫完之前,文件中就會包含垃圾數(shù)據(jù)。也可以通過VFS中的xDeviceCharacteristics方法指出文件系統(tǒng)支持“安全追加”功能,這意味著內(nèi)容的增加早于大小的改變,所以掉電或系統(tǒng)崩潰不可能向日志文件中引入垃圾。

文件系統(tǒng)支持安全追加時(shí),SQLITE總是在日志文件頭的頁面數(shù)字段中填入-1,表示回滾時(shí)要處理的頁面數(shù)應(yīng)該根據(jù)日志文件的大小自動計(jì)算。這個(gè)-1不會被修改,所以提交時(shí),我們可以不用單獨(dú)刷一次日志文件的第一頁。而且,當(dāng)回收緩存時(shí),也沒有必要在日志文件末尾再寫一個(gè)新的文件頭了,我們只要繼續(xù)在已有的日志文件上追加新頁面即可。

8.??? 對原子提交的測試

我們作為SQLITE的開發(fā)者,對其在掉電和系統(tǒng)崩潰時(shí)的健壯性充滿自信,因?yàn)?#xff0c;我們的自動測試過程在模擬的掉電故障下,對它的恢復(fù)能力進(jìn)行了非常多的檢測。我們把這種模擬的故障稱為“崩潰測試”。

崩潰測試使用了一個(gè)修改過的VFS,以便模擬掉電或崩潰時(shí)可能出現(xiàn)的各種文件系統(tǒng)錯(cuò)誤。它可以模擬出沒有完整寫入的扇區(qū)、因?yàn)閷懖僮鳑]有完成而包含垃圾數(shù)據(jù)的頁面、順序錯(cuò)誤的寫操作等,這些錯(cuò)誤在測試場景的各個(gè)路徑點(diǎn)上都會出現(xiàn)。崩潰測試不停地執(zhí)行事務(wù),讓模擬的掉電或系統(tǒng)崩潰發(fā)生在各個(gè)不同的時(shí)刻,造成各種不同的數(shù)據(jù)損壞。在模擬的崩潰事件發(fā)生之后,測試程序重新打開數(shù)據(jù)庫,檢測事務(wù)是否完全完成或者(看起來)根本沒有啟動,也就是數(shù)據(jù)庫是否處于一個(gè)一致的狀態(tài)。

SQLITE的崩潰測試幫助我們發(fā)現(xiàn)了恢復(fù)機(jī)制中的很多小問題(現(xiàn)在都已經(jīng)修復(fù)了)。其中的一部分非常隱晦,單單通過代碼檢查和分析可能是發(fā)現(xiàn)不了的。這些經(jīng)驗(yàn)讓SQLITE的開發(fā)者相信:那些沒有使用類似崩潰測試的數(shù)據(jù)庫系統(tǒng),非常有可能包含在系統(tǒng)崩潰或掉電時(shí)導(dǎo)致數(shù)據(jù)庫損壞的BUG。

9.??? 可能發(fā)生的問題

雖然SQLITE的原子提交機(jī)制本身是健壯的,但它卻有可能被惡意的對手或不那么完善的操作系統(tǒng)實(shí)現(xiàn)給打垮。本章將介紹幾個(gè)可能在掉電或系統(tǒng)崩潰時(shí)導(dǎo)致數(shù)據(jù)庫損壞的情形。

9.1.??? 有問題的鎖

SQLITE使用文件系統(tǒng)的鎖來保證某一時(shí)刻只有一個(gè)進(jìn)程和數(shù)據(jù)庫連接可以修改數(shù)據(jù)庫。文件系統(tǒng)的鎖機(jī)制是在VFS層實(shí)現(xiàn)的,并且在每種操作系統(tǒng)上都有所不同。SQLITE自身的正確性依賴于這個(gè)實(shí)現(xiàn)的正確性。如果它出了問題,導(dǎo)致兩個(gè)或更多進(jìn)程能同時(shí)修改一個(gè)數(shù)據(jù)庫文件,肯定會嚴(yán)重?fù)p壞數(shù)據(jù)庫。

有人向我們報(bào)告說windows的網(wǎng)絡(luò)文件系統(tǒng)和(Unix的,譯注)NFS的鎖都有些問題。我們驗(yàn)證不了這些報(bào)告,但是考慮到在網(wǎng)絡(luò)文件系統(tǒng)上實(shí)現(xiàn)一個(gè)正確的鎖的難度,我們也無法否定它們。由于網(wǎng)絡(luò)文件系統(tǒng)的效率也很低,所以我們建議你最好是避免在其上使用SQLITE。如果一定要這么做的話,請考慮使用一個(gè)附加的鎖機(jī)制來保證即使文件系統(tǒng)自身的鎖機(jī)制不起作用時(shí),也不會出現(xiàn)多個(gè)進(jìn)程同時(shí)寫一個(gè)數(shù)據(jù)庫文件的情況。

蘋果Mac OSX計(jì)算機(jī)上預(yù)裝的SQLITE進(jìn)行了一個(gè)擴(kuò)展,可以在蘋果支持的所有網(wǎng)絡(luò)文件系統(tǒng)上使用一個(gè)替代的加鎖策略。只要所有進(jìn)程使用統(tǒng)一的方式訪問數(shù)據(jù)庫文件,這個(gè)擴(kuò)展就工作的很好。但不幸的是,這些加鎖機(jī)制是相互獨(dú)立的,如果一個(gè)進(jìn)程用AFP鎖,另一個(gè)用點(diǎn)文件(dot-file)鎖,那這兩個(gè)進(jìn)程就可能發(fā)生沖突,因?yàn)锳FP鎖并不能禁止點(diǎn)文件鎖,反之亦然。

9.2.??? 不完整的刷磁盤操作

在第3.7節(jié)和3.10節(jié)中你已經(jīng)看到,SQLITE要把系統(tǒng)緩存刷到磁盤上。在unix系統(tǒng)上,這是用fsync()系統(tǒng)調(diào)用來完成的,windows上則是用FlushFileBuffers()。可是,我們收到的報(bào)告顯示,很多系統(tǒng)上的這些接口沒有廣告宣傳的那么好。我們聽說,在一些windows版本上,通過修改注冊表,可以完全禁用FlushFileBuffers();而linux的某些歷史版本中的fsync僅僅是個(gè)什么也不干的空操作。我們還知道,即使是在FlushFileBuffers()或fsync()可以正常工作的系統(tǒng)上,IDE磁盤控制器也經(jīng)常會在數(shù)據(jù)仍處在自己的緩存中時(shí),撒謊說數(shù)據(jù)已經(jīng)到達(dá)磁盤表面了。

在蘋果的系統(tǒng)上,如果你把fullsync選項(xiàng)打開(PRAGMAfullsync=ON),它可以保證數(shù)據(jù)確實(shí)刷到磁盤上了。Fullsync本身就很慢,而fullsync的實(shí)現(xiàn)還需要重置磁盤控制器,這會讓其他根本不相關(guān)的磁盤I/O也變慢,所以我們不建議你這樣做。

9.3.??? 文件刪除只完成了一半

SQLITE假設(shè)從用戶程序的角度看文件刪除是原子操作。如果刪除文件時(shí)掉電,電力恢復(fù)后,SQLITE期望這個(gè)文件或者不存在,或者是一個(gè)完整的、和刪除前一模一樣的文件。如果操作系統(tǒng)做不到這一點(diǎn),事務(wù)就有可能不是原子的。

9.4.??? 文件中的垃圾

SQLITE的數(shù)據(jù)庫文件是普通的文件,其它用戶程序也可以打開它并任意的往里面寫數(shù)據(jù),一些流氓程序就可能這樣做。垃圾數(shù)據(jù)的來源也可能是操作系統(tǒng)或磁盤控制器的BUG,尤其是那些會在掉電時(shí)觸發(fā)的BUG。對此類問題,SQLITE無能為力。

9.5.??? 刪除或重命名熱日志文件

如果發(fā)生了掉電或崩潰,并且生成了熱日志文件,那么,在另一個(gè)SQLITE進(jìn)程打開它和數(shù)據(jù)庫文件并完成回滾之前,這兩個(gè)文件的名字絕對不能改變。在第4.2步時(shí),SQLITE會在打開的數(shù)據(jù)庫文件所在的目錄下,尋找熱日志文件,這個(gè)文件的名字是從數(shù)據(jù)庫文件名派生而來的。所以,只要這兩個(gè)文件中的任何一個(gè)被移走或改名,就會找不到熱日志,也就不會進(jìn)行回滾。

我們認(rèn)為SQLITE恢復(fù)過程的失敗模式一般是這樣的:發(fā)生了掉電;電力恢復(fù)后,一位好心的用戶或者系統(tǒng)管理員開始清點(diǎn)損失;他們發(fā)現(xiàn)有一個(gè)名為“important.data”的文件,他們可能很熟悉這個(gè)文件,所以沒有對其進(jìn)行任何操作;但崩潰后,磁盤上還有一個(gè)名為“important.data-journal”的熱日志文件,用戶把它刪除了,因?yàn)樗麄冋J(rèn)為這個(gè)文件是系統(tǒng)中的垃圾。防止此類事件的唯一方法可能就是加強(qiáng)用戶教育了。

如果有多個(gè)鏈接(硬鏈接或符號鏈接)指向一個(gè)數(shù)據(jù)庫文件,那么生成的日志文件會依據(jù)打開數(shù)據(jù)庫文件時(shí)使用鏈接名來命名。如果發(fā)生了崩潰,并且下次打開數(shù)據(jù)庫時(shí)使用了另一個(gè)鏈接,則也會因?yàn)檎也坏綗崛罩疚募贿M(jìn)行回滾。

某些時(shí)候,掉電會導(dǎo)致文件系統(tǒng)出錯(cuò),以致新更改的文件名無法記錄,這時(shí),文件就會被移動到“/lost+found”目錄下。為防止此類錯(cuò)誤,SQLITE會在同步日志文件的同時(shí),打開并同步一下這個(gè)文件所在的目錄。但是,一些八竿子打不著的程序,在數(shù)據(jù)庫文件所在目錄下創(chuàng)建其他文件的操作,也可能會導(dǎo)致文件被移動到“/lost+found”里去,這是SQLITE控制不了的,所以SQLITE對它也沒什么辦法。如果你正在使用此類名字空間易被損壞的文件系統(tǒng)(我們相信大多數(shù)現(xiàn)代的日志文件系統(tǒng)沒有此問題),我們建議你把SQLITE的數(shù)據(jù)庫文件放在單獨(dú)的子目錄中。

10.??? 總結(jié)和展望

不論是過去還是現(xiàn)在,總有人能發(fā)現(xiàn)一些SQLITE原子提交機(jī)制的失敗模式,開發(fā)者也不得不為此做一些補(bǔ)丁。但這類事情發(fā)生的已經(jīng)越來越少了,失敗模式也變得越來越隱晦。不過,如果藉此認(rèn)為SQLITE的原子提交邏輯已經(jīng)無懈可擊了,肯定是相當(dāng)愚蠢的。開發(fā)者們能承諾的只是盡量快速的修復(fù)新發(fā)現(xiàn)的BUG。

同時(shí),我們也在尋找新的方法來優(yōu)化這個(gè)提交機(jī)制。在Linux、MacOSX和windows上,當(dāng)前的VFS實(shí)現(xiàn)都做了悲觀的假設(shè)。也許在與一些熟悉這些系統(tǒng)工作原理的專家交流之后,我們能放寬一些限制,讓它跑得更快些。特別的,我們猜測大部分現(xiàn)代文件系統(tǒng)已經(jīng)具有了“安全追加”和“原子扇區(qū)寫”這兩個(gè)特性,但在確認(rèn)之前,我們?nèi)詴J氐淖鲎顗募僭O(shè)。

轉(zhuǎn)載于:https://www.cnblogs.com/lanru/archive/2010/09/06/1819405.html

總結(jié)

以上是生活随笔為你收集整理的SQLITE中原子提交的实现的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

久久久中文字幕日本无吗 | 无码中文字幕色专区 | 99麻豆久久久国产精品免费 | 久久久久成人精品免费播放动漫 | 久热国产vs视频在线观看 | 熟妇人妻激情偷爽文 | 人人超人人超碰超国产 | 中文无码精品a∨在线观看不卡 | 久久亚洲国产成人精品性色 | 亚洲午夜福利在线观看 | 国产特级毛片aaaaaaa高清 | 18无码粉嫩小泬无套在线观看 | 性啪啪chinese东北女人 | 日韩 欧美 动漫 国产 制服 | 麻豆人妻少妇精品无码专区 | 午夜无码人妻av大片色欲 | 无套内谢的新婚少妇国语播放 | 中文字幕色婷婷在线视频 | 亚洲国产精华液网站w | 小泽玛莉亚一区二区视频在线 | 午夜理论片yy44880影院 | 色狠狠av一区二区三区 | 免费无码午夜福利片69 | 人人妻人人藻人人爽欧美一区 | 最近免费中文字幕中文高清百度 | 亚洲人成影院在线观看 | 久久久久亚洲精品男人的天堂 | 亚洲狠狠色丁香婷婷综合 | 牲欲强的熟妇农村老妇女 | 四虎永久在线精品免费网址 | 在线看片无码永久免费视频 | 亚洲欧美综合区丁香五月小说 | 人人妻人人澡人人爽人人精品 | 成人欧美一区二区三区 | 亚洲一区二区三区偷拍女厕 | 亚洲欧美日韩成人高清在线一区 | 色老头在线一区二区三区 | 内射欧美老妇wbb | 日日躁夜夜躁狠狠躁 | 青青青手机频在线观看 | 国内少妇偷人精品视频 | 亚洲色无码一区二区三区 | 无码人妻出轨黑人中文字幕 | 国产精品办公室沙发 | 亚洲无人区午夜福利码高清完整版 | 天堂а√在线地址中文在线 | 久久婷婷五月综合色国产香蕉 | 亚洲精品中文字幕久久久久 | 亚洲国产精品无码一区二区三区 | 一二三四在线观看免费视频 | 国产麻豆精品精东影业av网站 | 六月丁香婷婷色狠狠久久 | 中文字幕乱妇无码av在线 | 亚洲日韩乱码中文无码蜜桃臀网站 | 亚洲一区二区三区偷拍女厕 | av人摸人人人澡人人超碰下载 | 亚洲熟女一区二区三区 | 亚洲色欲色欲欲www在线 | 久久久久se色偷偷亚洲精品av | 欧美丰满熟妇xxxx性ppx人交 | 国产香蕉尹人视频在线 | 成年美女黄网站色大免费视频 | 久久人人97超碰a片精品 | 国产手机在线αⅴ片无码观看 | 国产黄在线观看免费观看不卡 | 青青草原综合久久大伊人精品 | 国产乱码精品一品二品 | 永久免费精品精品永久-夜色 | 亚欧洲精品在线视频免费观看 | 高清无码午夜福利视频 | 免费看少妇作爱视频 | 亚洲成av人片天堂网无码】 | 亚洲另类伦春色综合小说 | 国产激情一区二区三区 | 欧美老人巨大xxxx做受 | 亚洲爆乳精品无码一区二区三区 | 少妇人妻大乳在线视频 | 日韩精品无码一区二区中文字幕 | 亚洲小说图区综合在线 | 亚洲 日韩 欧美 成人 在线观看 | 中文字幕乱妇无码av在线 | 在线a亚洲视频播放在线观看 | 国产av无码专区亚洲a∨毛片 | 性欧美大战久久久久久久 | 亚洲s色大片在线观看 | 少妇性l交大片欧洲热妇乱xxx | 成人性做爰aaa片免费看不忠 | 欧美喷潮久久久xxxxx | 亚洲自偷自拍另类第1页 | 一个人看的视频www在线 | 中文字幕亚洲情99在线 | 日韩亚洲欧美精品综合 | 免费国产成人高清在线观看网站 | av在线亚洲欧洲日产一区二区 | 狠狠色噜噜狠狠狠7777奇米 | 精品国偷自产在线 | 亚洲 日韩 欧美 成人 在线观看 | 最新国产麻豆aⅴ精品无码 | 人人澡人摸人人添 | 亚洲人成影院在线无码按摩店 | 亚洲呦女专区 | 国产卡一卡二卡三 | 久久久久99精品成人片 | 日本精品高清一区二区 | 国产欧美精品一区二区三区 | 乌克兰少妇性做爰 | 午夜福利不卡在线视频 | 国产三级久久久精品麻豆三级 | 啦啦啦www在线观看免费视频 | 熟女俱乐部五十路六十路av | 日本一区二区三区免费播放 | 欧美丰满少妇xxxx性 | 99久久久无码国产精品免费 | 欧美丰满熟妇xxxx性ppx人交 | 亚洲人成网站在线播放942 | 国产精品亚洲lv粉色 | 久久久久99精品国产片 | 性色欲情网站iwww九文堂 | 久久亚洲中文字幕无码 | 国产成人精品视频ⅴa片软件竹菊 | 国产九九九九九九九a片 | 大乳丰满人妻中文字幕日本 | 日韩成人一区二区三区在线观看 | 亚洲精品成人福利网站 | 成人精品视频一区二区三区尤物 | 少妇愉情理伦片bd | 女人被男人爽到呻吟的视频 | 欧美 日韩 亚洲 在线 | 精品久久久无码中文字幕 | 亚洲人亚洲人成电影网站色 | 国产日产欧产精品精品app | 最近免费中文字幕中文高清百度 | 狠狠色丁香久久婷婷综合五月 | 精品无码一区二区三区爱欲 | 久久综合给久久狠狠97色 | 久久久久久国产精品无码下载 | √8天堂资源地址中文在线 | 成人三级无码视频在线观看 | 国产无套内射久久久国产 | 亚洲国产精品成人久久蜜臀 | 日欧一片内射va在线影院 | 日日天日日夜日日摸 | 亚洲国产精品一区二区第一页 | 麻豆精品国产精华精华液好用吗 | 精品久久久无码人妻字幂 | 中文字幕无码av激情不卡 | 丰满少妇女裸体bbw | 国产综合久久久久鬼色 | 欧美阿v高清资源不卡在线播放 | 一本色道久久综合亚洲精品不卡 | 99riav国产精品视频 | 男人的天堂2018无码 | 四虎影视成人永久免费观看视频 | 久久天天躁狠狠躁夜夜免费观看 | 精品乱子伦一区二区三区 | 欧美阿v高清资源不卡在线播放 | 免费无码的av片在线观看 | 亚洲色欲色欲欲www在线 | 久久99精品久久久久婷婷 | 国产午夜手机精彩视频 | 俺去俺来也在线www色官网 | 国产精品.xx视频.xxtv | 在线亚洲高清揄拍自拍一品区 | 水蜜桃色314在线观看 | 激情人妻另类人妻伦 | 97se亚洲精品一区 | 欧美老人巨大xxxx做受 | 中文字幕乱码中文乱码51精品 | 人人妻人人澡人人爽精品欧美 | 欧美 丝袜 自拍 制服 另类 | 牲欲强的熟妇农村老妇女视频 | 日本乱人伦片中文三区 | 性生交片免费无码看人 | 国语自产偷拍精品视频偷 | 精品人妻人人做人人爽夜夜爽 | 欧美日韩人成综合在线播放 | 国内揄拍国内精品少妇国语 | 亚洲高清偷拍一区二区三区 | 丁香啪啪综合成人亚洲 | 一个人看的视频www在线 | 国产情侣作爱视频免费观看 | www国产精品内射老师 | 无码人妻少妇伦在线电影 | 老司机亚洲精品影院 | 青草青草久热国产精品 | 夜先锋av资源网站 | 精品国产乱码久久久久乱码 | 亚洲精品成人福利网站 | 日本丰满护士爆乳xxxx | 国产激情无码一区二区 | 久久综合激激的五月天 | 日韩亚洲欧美中文高清在线 | 又大又黄又粗又爽的免费视频 | 久久精品国产一区二区三区 | 六十路熟妇乱子伦 | 正在播放老肥熟妇露脸 | 国产午夜精品一区二区三区嫩草 | 日韩少妇内射免费播放 | 日日噜噜噜噜夜夜爽亚洲精品 | 中文字幕无码人妻少妇免费 | 亚洲码国产精品高潮在线 | 少妇无码吹潮 | 亚洲精品中文字幕 | 300部国产真实乱 | 国产成人人人97超碰超爽8 | 日产精品99久久久久久 | 亚洲欧美日韩综合久久久 | 国产精品鲁鲁鲁 | 国产美女极度色诱视频www | 亚洲精品成人福利网站 | 熟妇人妻激情偷爽文 | 中文字幕亚洲情99在线 | 免费观看又污又黄的网站 | 国产特级毛片aaaaaaa高清 | 国产精品高潮呻吟av久久 | 男女爱爱好爽视频免费看 | 人人妻人人澡人人爽精品欧美 | 欧美刺激性大交 | 四虎永久在线精品免费网址 | 免费观看又污又黄的网站 | 少妇人妻av毛片在线看 | 成人无码视频在线观看网站 | 老司机亚洲精品影院无码 | 无码人妻精品一区二区三区下载 | 蜜桃无码一区二区三区 | 欧美日韩人成综合在线播放 | av小次郎收藏 | 免费无码av一区二区 | 亚洲另类伦春色综合小说 | 国产电影无码午夜在线播放 | 日韩成人一区二区三区在线观看 | 99er热精品视频 | 亚洲色欲久久久综合网东京热 | 色婷婷久久一区二区三区麻豆 | 扒开双腿疯狂进出爽爽爽视频 | 国产激情一区二区三区 | 亚洲七七久久桃花影院 | 久久99精品久久久久婷婷 | 强奷人妻日本中文字幕 | 欧美丰满熟妇xxxx性ppx人交 | 日日噜噜噜噜夜夜爽亚洲精品 | 999久久久国产精品消防器材 | 偷窥村妇洗澡毛毛多 | 97色伦图片97综合影院 | 午夜理论片yy44880影院 | 欧美阿v高清资源不卡在线播放 | 高潮喷水的毛片 | 在线а√天堂中文官网 | 国产精品久久久久久亚洲影视内衣 | 最近中文2019字幕第二页 | 色欲av亚洲一区无码少妇 | 国产口爆吞精在线视频 | 欧美日本免费一区二区三区 | 国产成人av免费观看 | yw尤物av无码国产在线观看 | 中文字幕无码免费久久99 | 伊人久久大香线蕉午夜 | 无遮无挡爽爽免费视频 | 丰满妇女强制高潮18xxxx | 欧洲熟妇精品视频 | 国产亚洲精品久久久久久国模美 | 大肉大捧一进一出好爽视频 | 丰满人妻精品国产99aⅴ | 国产成人无码区免费内射一片色欲 | 成人免费无码大片a毛片 | 在教室伦流澡到高潮hnp视频 | 亚洲日本在线电影 | 国产极品美女高潮无套在线观看 | 中文字幕 亚洲精品 第1页 | 中文字幕乱妇无码av在线 | 国产午夜福利亚洲第一 | 免费男性肉肉影院 | 日本熟妇浓毛 | 男人和女人高潮免费网站 | 九九热爱视频精品 | 性啪啪chinese东北女人 | 成人动漫在线观看 | 成熟妇人a片免费看网站 | 性欧美videos高清精品 | 国产人妖乱国产精品人妖 | 给我免费的视频在线观看 | 欧美激情内射喷水高潮 | 久久精品人人做人人综合 | 精品国产av色一区二区深夜久久 | 性色欲网站人妻丰满中文久久不卡 | 久久久精品人妻久久影视 | 一个人看的www免费视频在线观看 | 色综合久久久无码中文字幕 | 捆绑白丝粉色jk震动捧喷白浆 | 亚洲gv猛男gv无码男同 | 国产成人无码专区 | 领导边摸边吃奶边做爽在线观看 | 久久人人爽人人爽人人片av高清 | 国产 精品 自在自线 | 日本熟妇人妻xxxxx人hd | 国产女主播喷水视频在线观看 | 国精品人妻无码一区二区三区蜜柚 | 久久人人爽人人爽人人片ⅴ | 国产成人亚洲综合无码 | 国产精品久久久 | 中文字幕精品av一区二区五区 | 成年美女黄网站色大免费全看 | 国产成人一区二区三区在线观看 | 131美女爱做视频 | 国内精品人妻无码久久久影院蜜桃 | 国产av无码专区亚洲awww | 俺去俺来也在线www色官网 | 夜夜躁日日躁狠狠久久av | 欧美日本日韩 | 妺妺窝人体色www在线小说 | 国产一区二区三区精品视频 | 粉嫩少妇内射浓精videos | 日本一本二本三区免费 | 午夜丰满少妇性开放视频 | 日韩人妻无码中文字幕视频 | 久久午夜无码鲁丝片 | 国产成人精品三级麻豆 | 国产成人无码午夜视频在线观看 | 国产av无码专区亚洲awww | 无码精品国产va在线观看dvd | 成人aaa片一区国产精品 | 最近中文2019字幕第二页 | 在线播放亚洲第一字幕 | 亚洲男人av香蕉爽爽爽爽 | 国产肉丝袜在线观看 | 丰满妇女强制高潮18xxxx | 无人区乱码一区二区三区 | 久久99精品久久久久婷婷 | 人人澡人人透人人爽 | 少女韩国电视剧在线观看完整 | 亚洲色大成网站www | 内射欧美老妇wbb | 性做久久久久久久久 | 99久久精品无码一区二区毛片 | 国产精品无套呻吟在线 | 国产深夜福利视频在线 | 中国女人内谢69xxxxxa片 | 成熟女人特级毛片www免费 | 四虎永久在线精品免费网址 | 成人片黄网站色大片免费观看 | 亚洲国产精品毛片av不卡在线 | 最新国产乱人伦偷精品免费网站 | 牲欲强的熟妇农村老妇女 | 欧美成人免费全部网站 | 国产无遮挡吃胸膜奶免费看 | 精品国产aⅴ无码一区二区 | 九九在线中文字幕无码 | 精品国产av色一区二区深夜久久 | 中文字幕av日韩精品一区二区 | 成年美女黄网站色大免费全看 | aⅴ亚洲 日韩 色 图网站 播放 | 国产精品无码永久免费888 | 久久久www成人免费毛片 | 极品尤物被啪到呻吟喷水 | 国产精品自产拍在线观看 | 好爽又高潮了毛片免费下载 | 久久亚洲精品成人无码 | 国产精品怡红院永久免费 | 免费观看的无遮挡av | 国产精品久免费的黄网站 | 久久午夜无码鲁丝片 | 日韩在线不卡免费视频一区 | 久久精品国产一区二区三区 | 久久国产精品偷任你爽任你 | 日本在线高清不卡免费播放 | 久久亚洲日韩精品一区二区三区 | 成在人线av无码免观看麻豆 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 无码人妻少妇伦在线电影 | 午夜精品久久久内射近拍高清 | 日日噜噜噜噜夜夜爽亚洲精品 | 人人妻人人澡人人爽欧美精品 | 国产一区二区三区四区五区加勒比 | 亚洲成a人片在线观看无码 | 熟女少妇人妻中文字幕 | 67194成是人免费无码 | 爆乳一区二区三区无码 | 免费乱码人妻系列无码专区 | 一二三四社区在线中文视频 | 国产精品高潮呻吟av久久4虎 | 国产精品毛多多水多 | 成人免费无码大片a毛片 | 国产乱子伦视频在线播放 | 4hu四虎永久在线观看 | 狂野欧美性猛交免费视频 | 亚洲国产日韩a在线播放 | 免费无码av一区二区 | 亚洲精品一区二区三区大桥未久 | 亚洲欧美日韩成人高清在线一区 | 白嫩日本少妇做爰 | 日欧一片内射va在线影院 | 夜夜高潮次次欢爽av女 | 亚洲s色大片在线观看 | 午夜福利不卡在线视频 | 国产亚洲视频中文字幕97精品 | 亚洲精品成人av在线 | 一个人免费观看的www视频 | 欧美性猛交xxxx富婆 | 伊人久久大香线蕉亚洲 | 亚洲精品一区三区三区在线观看 | 精品熟女少妇av免费观看 | 国产三级久久久精品麻豆三级 | 欧美日韩在线亚洲综合国产人 | 人人爽人人爽人人片av亚洲 | 国产欧美熟妇另类久久久 | 国产真实乱对白精彩久久 | 少妇人妻大乳在线视频 | 欧洲美熟女乱又伦 | 国精产品一品二品国精品69xx | 熟女少妇在线视频播放 | 成人试看120秒体验区 | 玩弄少妇高潮ⅹxxxyw | 久久国内精品自在自线 | 国产人妻人伦精品1国产丝袜 | 久久久精品国产sm最大网站 | 乌克兰少妇xxxx做受 | 免费国产成人高清在线观看网站 | 中文字幕无码热在线视频 | 中文字幕无线码 | 欧美日本免费一区二区三区 | 亚洲一区二区三区无码久久 | 欧美兽交xxxx×视频 | 性色欲网站人妻丰满中文久久不卡 | 国产精品沙发午睡系列 | 夫妻免费无码v看片 | 免费无码一区二区三区蜜桃大 | 亚洲成av人在线观看网址 | 亚洲精品一区国产 | 亚洲熟妇色xxxxx亚洲 | 无码人妻丰满熟妇区毛片18 | 日本高清一区免费中文视频 | 成人性做爰aaa片免费看不忠 | 乱人伦中文视频在线观看 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产精品亚洲一区二区三区喷水 | 女高中生第一次破苞av | 亚洲欧洲日本综合aⅴ在线 | 欧美亚洲国产一区二区三区 | 精品久久久无码中文字幕 | 熟妇女人妻丰满少妇中文字幕 | 国产精品亚洲综合色区韩国 | 九九久久精品国产免费看小说 | 无码免费一区二区三区 | 久久国语露脸国产精品电影 | v一区无码内射国产 | 高清国产亚洲精品自在久久 | 亚洲小说图区综合在线 | 亚洲成av人在线观看网址 | 欧美日本日韩 | 亚洲国产成人av在线观看 | 水蜜桃av无码 | 大肉大捧一进一出视频出来呀 | 天堂а√在线地址中文在线 | 人人爽人人澡人人高潮 | 国产激情一区二区三区 | 日本大乳高潮视频在线观看 | 亚洲欧美精品aaaaaa片 | 久久无码专区国产精品s | 成人三级无码视频在线观看 | 国产午夜福利100集发布 | 秋霞特色aa大片 | 精品国产一区二区三区四区在线看 | 国产人成高清在线视频99最全资源 | 人妻夜夜爽天天爽三区 | 久久zyz资源站无码中文动漫 | 少妇无套内谢久久久久 | 人人妻人人澡人人爽欧美一区九九 | 精品国产一区av天美传媒 | 日本护士毛茸茸高潮 | 国产免费观看黄av片 | 国产人成高清在线视频99最全资源 | 欧美第一黄网免费网站 | 精品国产一区二区三区av 性色 | 成人欧美一区二区三区黑人 | 全球成人中文在线 | 日日摸天天摸爽爽狠狠97 | 九九综合va免费看 | 在线成人www免费观看视频 | 日本免费一区二区三区最新 | 亚洲午夜福利在线观看 | 无码人妻av免费一区二区三区 | 双乳奶水饱满少妇呻吟 | 亚洲国产精品一区二区美利坚 | 国产口爆吞精在线视频 | 宝宝好涨水快流出来免费视频 | a片免费视频在线观看 | 少妇性俱乐部纵欲狂欢电影 | 高清不卡一区二区三区 | 午夜性刺激在线视频免费 | 99久久精品午夜一区二区 | 乌克兰少妇xxxx做受 | 九月婷婷人人澡人人添人人爽 | 中文字幕无码av波多野吉衣 | 精品少妇爆乳无码av无码专区 | 午夜无码区在线观看 | 欧美日本日韩 | 国产一区二区三区日韩精品 | 久久无码中文字幕免费影院蜜桃 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 无码人妻丰满熟妇区毛片18 | 亚洲精品综合五月久久小说 | 无套内谢的新婚少妇国语播放 | 日韩精品a片一区二区三区妖精 | 精品欧洲av无码一区二区三区 | 亚洲中文字幕乱码av波多ji | 免费观看黄网站 | 精品久久久久香蕉网 | 秋霞成人午夜鲁丝一区二区三区 | 久久综合香蕉国产蜜臀av | 天堂一区人妻无码 | 天天综合网天天综合色 | 久久久久av无码免费网 | 无码人妻av免费一区二区三区 | 亚洲 a v无 码免 费 成 人 a v | 国产午夜福利亚洲第一 | 中文字幕人妻无码一夲道 | 蜜桃无码一区二区三区 | 亚洲国产一区二区三区在线观看 | 俄罗斯老熟妇色xxxx | 奇米影视888欧美在线观看 | 色欲av亚洲一区无码少妇 | 精品一二三区久久aaa片 | 中文字幕精品av一区二区五区 | 日韩少妇内射免费播放 | 国产亚洲美女精品久久久2020 | 欧美亚洲日韩国产人成在线播放 | 欧美亚洲国产一区二区三区 | 人妻有码中文字幕在线 | 亚洲日韩精品欧美一区二区 | 午夜肉伦伦影院 | 激情内射亚州一区二区三区爱妻 | 乌克兰少妇性做爰 | 国产午夜福利100集发布 | 国産精品久久久久久久 | 国产精品对白交换视频 | 在线观看国产午夜福利片 | 精品成在人线av无码免费看 | 欧美阿v高清资源不卡在线播放 | 国产综合色产在线精品 | 国产婷婷色一区二区三区在线 | 国产乱人伦偷精品视频 | 国产精品毛多多水多 | 欧美第一黄网免费网站 | 日本大香伊一区二区三区 | 亚洲伊人久久精品影院 | 兔费看少妇性l交大片免费 | 精品偷拍一区二区三区在线看 | 永久免费观看国产裸体美女 | 无套内谢的新婚少妇国语播放 | 99久久久无码国产aaa精品 | 波多野42部无码喷潮在线 | a在线观看免费网站大全 | 精品久久久无码中文字幕 | 窝窝午夜理论片影院 | 一本久道久久综合婷婷五月 | 老熟女乱子伦 | 国产办公室秘书无码精品99 | 精品国产国产综合精品 | 色婷婷av一区二区三区之红樱桃 | 欧美阿v高清资源不卡在线播放 | 天天做天天爱天天爽综合网 | 成人亚洲精品久久久久软件 | 999久久久国产精品消防器材 | 日日夜夜撸啊撸 | 亚洲欧洲无卡二区视頻 | 永久黄网站色视频免费直播 | 超碰97人人做人人爱少妇 | 精品无码国产一区二区三区av | 亚洲综合另类小说色区 | 牲欲强的熟妇农村老妇女视频 | 欧美精品一区二区精品久久 | 国产精品亚洲一区二区三区喷水 | 网友自拍区视频精品 | 日韩精品a片一区二区三区妖精 | 精品欧美一区二区三区久久久 | 国产明星裸体无码xxxx视频 | 蜜臀aⅴ国产精品久久久国产老师 | 色一情一乱一伦一区二区三欧美 | 日韩av无码中文无码电影 | 久久久久久亚洲精品a片成人 | 欧美成人午夜精品久久久 | 超碰97人人做人人爱少妇 | 国产一精品一av一免费 | 夜先锋av资源网站 | 国产色视频一区二区三区 | 熟女少妇在线视频播放 | 中文字幕人妻无码一区二区三区 | 人人妻人人澡人人爽人人精品浪潮 | 久久久成人毛片无码 | 亚洲精品一区三区三区在线观看 | av香港经典三级级 在线 | 亚拍精品一区二区三区探花 | 欧美日韩人成综合在线播放 | 在线天堂新版最新版在线8 | 成 人 免费观看网站 | 99国产精品白浆在线观看免费 | 狂野欧美性猛xxxx乱大交 | 97无码免费人妻超级碰碰夜夜 | 性史性农村dvd毛片 | 国产成人无码专区 | 精品国产福利一区二区 | 欧美兽交xxxx×视频 | 两性色午夜视频免费播放 | 小泽玛莉亚一区二区视频在线 | 亚洲日韩av一区二区三区中文 | 国产午夜无码精品免费看 | 国产成人精品必看 | 国产午夜精品一区二区三区嫩草 | 国产麻豆精品一区二区三区v视界 | 永久黄网站色视频免费直播 | 免费男性肉肉影院 | 亚洲国精产品一二二线 | 欧美 丝袜 自拍 制服 另类 | av在线亚洲欧洲日产一区二区 | 最近的中文字幕在线看视频 | 一本久久a久久精品亚洲 | 一本色道久久综合狠狠躁 | 亚洲国产综合无码一区 | 99麻豆久久久国产精品免费 | 午夜丰满少妇性开放视频 | 国产精品沙发午睡系列 | 国产猛烈高潮尖叫视频免费 | 狠狠噜狠狠狠狠丁香五月 | 亚洲综合另类小说色区 | 欧美性猛交内射兽交老熟妇 | 亚洲伊人久久精品影院 | 红桃av一区二区三区在线无码av | 欧美三级不卡在线观看 | 婷婷综合久久中文字幕蜜桃三电影 | 一本精品99久久精品77 | 无人区乱码一区二区三区 | 真人与拘做受免费视频一 | 日本丰满护士爆乳xxxx | 国产精品亚洲а∨无码播放麻豆 | 男女超爽视频免费播放 | 国产偷抇久久精品a片69 | 成人精品视频一区二区 | 中文字幕无码视频专区 | 狂野欧美性猛xxxx乱大交 | 中文亚洲成a人片在线观看 | 日日天日日夜日日摸 | 国产午夜福利100集发布 | 亚洲爆乳无码专区 | 无码人妻精品一区二区三区不卡 | 欧美熟妇另类久久久久久不卡 | 国产亚洲视频中文字幕97精品 | 国产手机在线αⅴ片无码观看 | 性欧美熟妇videofreesex | 久久久av男人的天堂 | 亚洲成色www久久网站 | 99久久婷婷国产综合精品青草免费 | 人妻少妇被猛烈进入中文字幕 | 婷婷色婷婷开心五月四房播播 | 国产疯狂伦交大片 | 久久久久se色偷偷亚洲精品av | 日韩在线不卡免费视频一区 | 熟女少妇人妻中文字幕 | 亚洲日本一区二区三区在线 | 久久午夜无码鲁丝片 | 双乳奶水饱满少妇呻吟 | 国产婷婷色一区二区三区在线 | 综合网日日天干夜夜久久 | 无码人妻精品一区二区三区下载 | 久久久久久久女国产乱让韩 | 欧美 丝袜 自拍 制服 另类 | 在线а√天堂中文官网 | 久久人人爽人人爽人人片ⅴ | 中文字幕无码av激情不卡 | 亚洲国产精品一区二区第一页 | 久久精品中文闷骚内射 | 秋霞特色aa大片 | 亚洲日本va午夜在线电影 | 欧美激情内射喷水高潮 | 人人妻人人澡人人爽欧美一区九九 | 蜜臀av无码人妻精品 | 3d动漫精品啪啪一区二区中 | 久久久久av无码免费网 | 欧美丰满熟妇xxxx性ppx人交 | 国产精品久久久久无码av色戒 | 激情五月综合色婷婷一区二区 | 亚洲男人av天堂午夜在 | 四十如虎的丰满熟妇啪啪 | 国产内射爽爽大片视频社区在线 | 亚洲精品成人av在线 | 国产av一区二区精品久久凹凸 | 少妇性l交大片 | 久久久久久九九精品久 | 欧美一区二区三区 | √天堂资源地址中文在线 | 国产精品第一区揄拍无码 | 精品一区二区三区波多野结衣 | 99精品国产综合久久久久五月天 | 国产精品成人av在线观看 | 少妇无码一区二区二三区 | 人妻少妇精品久久 | 人妻体内射精一区二区三四 | 亚洲成色在线综合网站 | 亚洲中文字幕va福利 | 亚洲国产精华液网站w | 波多野42部无码喷潮在线 | 国产午夜福利100集发布 | 荫蒂被男人添的好舒服爽免费视频 | 少妇性荡欲午夜性开放视频剧场 | 成人无码精品一区二区三区 | 亚洲精品综合五月久久小说 | 丝袜足控一区二区三区 | 天天躁日日躁狠狠躁免费麻豆 | 国产成人人人97超碰超爽8 | 人人爽人人爽人人片av亚洲 | 娇妻被黑人粗大高潮白浆 | 久在线观看福利视频 | 国产精品资源一区二区 | 精品一二三区久久aaa片 | 人妻中文无码久热丝袜 | 正在播放东北夫妻内射 | 久久精品国产日本波多野结衣 | 国产成人无码av片在线观看不卡 | 免费中文字幕日韩欧美 | 人妻无码αv中文字幕久久琪琪布 | 亚洲精品久久久久avwww潮水 | 天下第一社区视频www日本 | 国产女主播喷水视频在线观看 | 久久婷婷五月综合色国产香蕉 | 少妇无码吹潮 | 精品无码国产自产拍在线观看蜜 | 国产明星裸体无码xxxx视频 | 久久久精品人妻久久影视 | 国产精品久久国产三级国 | 久久精品国产一区二区三区 | 黑人巨大精品欧美一区二区 | 国产成人综合美国十次 | 荫蒂添的好舒服视频囗交 | av人摸人人人澡人人超碰下载 | 中国女人内谢69xxxxxa片 | 久久精品无码一区二区三区 | 成年美女黄网站色大免费全看 | 天天摸天天透天天添 | 成年美女黄网站色大免费视频 | 欧美午夜特黄aaaaaa片 | 国产欧美熟妇另类久久久 | 伊人久久大香线蕉亚洲 | 国产精品自产拍在线观看 | 亚洲а∨天堂久久精品2021 | 亚洲熟妇自偷自拍另类 | 亚洲娇小与黑人巨大交 | 国产高清不卡无码视频 | 亚洲狠狠色丁香婷婷综合 | 国内丰满熟女出轨videos | 无码任你躁久久久久久久 | 国产精品第一区揄拍无码 | 久久综合九色综合97网 | 免费男性肉肉影院 | 蜜桃av抽搐高潮一区二区 | 中文字幕亚洲情99在线 | 国产精品美女久久久 | 国产午夜福利亚洲第一 | 377p欧洲日本亚洲大胆 | 女人和拘做爰正片视频 | 最近中文2019字幕第二页 | 乱中年女人伦av三区 | 国产精品人人妻人人爽 | 无码av中文字幕免费放 | 亚洲色欲久久久综合网东京热 | 欧美野外疯狂做受xxxx高潮 | 精品国精品国产自在久国产87 | av无码不卡在线观看免费 | 久久精品视频在线看15 | 亚洲精品中文字幕乱码 | 久久97精品久久久久久久不卡 | 亚洲娇小与黑人巨大交 | 久久99精品久久久久久动态图 | 成熟女人特级毛片www免费 | 中文字幕人妻丝袜二区 | 十八禁真人啪啪免费网站 | 久久国产精品_国产精品 | 一本加勒比波多野结衣 | 无码国产乱人伦偷精品视频 | 天海翼激烈高潮到腰振不止 | 亚洲色无码一区二区三区 | 国产真人无遮挡作爱免费视频 | 精品久久久久久人妻无码中文字幕 | 在教室伦流澡到高潮hnp视频 | 欧美怡红院免费全部视频 | 无码国产激情在线观看 | 日日橹狠狠爱欧美视频 | 亚洲精品国偷拍自产在线麻豆 | 麻豆人妻少妇精品无码专区 | 人人澡人人透人人爽 | 亚洲精品一区二区三区婷婷月 | 欧美丰满少妇xxxx性 | 精品国产一区二区三区av 性色 | 又大又紧又粉嫩18p少妇 | 少妇太爽了在线观看 | 国产精品多人p群无码 | 色婷婷久久一区二区三区麻豆 | 久久www免费人成人片 | 色婷婷综合激情综在线播放 | 日本熟妇人妻xxxxx人hd | 国产av人人夜夜澡人人爽麻豆 | 国产两女互慰高潮视频在线观看 | 强伦人妻一区二区三区视频18 | 夜精品a片一区二区三区无码白浆 | 内射白嫩少妇超碰 | 国语精品一区二区三区 | 人人妻人人澡人人爽欧美一区九九 | 精品无码国产一区二区三区av | 水蜜桃亚洲一二三四在线 | 国产成人无码午夜视频在线观看 | 蜜桃av抽搐高潮一区二区 | 国产农村乱对白刺激视频 | 日韩av激情在线观看 | 人人妻人人澡人人爽欧美精品 | 成年美女黄网站色大免费全看 | 亚洲国产一区二区三区在线观看 | 精品人妻av区 | 精品偷拍一区二区三区在线看 | 高潮毛片无遮挡高清免费 | 最新版天堂资源中文官网 | 国产福利视频一区二区 | 特大黑人娇小亚洲女 | 亚洲欧洲无卡二区视頻 | 老熟妇仑乱视频一区二区 | 玩弄人妻少妇500系列视频 | 国产凸凹视频一区二区 | 在线观看欧美一区二区三区 | 亚洲中文字幕无码一久久区 | 熟女体下毛毛黑森林 | 国产香蕉97碰碰久久人人 | 人人爽人人澡人人高潮 | 少妇被黑人到高潮喷出白浆 | 人妻熟女一区 | 国产一区二区三区精品视频 | 久久久亚洲欧洲日产国码αv | 人人超人人超碰超国产 | 久久国产精品_国产精品 | 久久国产36精品色熟妇 | 国产在线无码精品电影网 | 夜夜躁日日躁狠狠久久av | 正在播放老肥熟妇露脸 | 曰韩无码二三区中文字幕 | 国产精品第一区揄拍无码 | 国产精品无码一区二区三区不卡 | 国产乱人偷精品人妻a片 | 欧美真人作爱免费视频 | 久久久亚洲欧洲日产国码αv | 国产三级久久久精品麻豆三级 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | a国产一区二区免费入口 | 日韩精品一区二区av在线 | 午夜男女很黄的视频 | 日本肉体xxxx裸交 | 久久久久亚洲精品中文字幕 | 亚洲经典千人经典日产 | 呦交小u女精品视频 | 无码成人精品区在线观看 | 婷婷六月久久综合丁香 | 亚洲午夜福利在线观看 | 免费中文字幕日韩欧美 | 成 人影片 免费观看 | 狠狠噜狠狠狠狠丁香五月 | 国产无遮挡又黄又爽又色 | 黑人粗大猛烈进出高潮视频 | 日本一区二区三区免费播放 | 日本大乳高潮视频在线观看 | 精品一区二区三区无码免费视频 | 人妻夜夜爽天天爽三区 | 国产亚洲精品久久久ai换 | 亚洲国产欧美在线成人 | 国产人妻精品午夜福利免费 | 欧美成人免费全部网站 | 精品一区二区三区波多野结衣 | 亚洲色欲色欲欲www在线 | 麻豆国产丝袜白领秘书在线观看 | 国产高清av在线播放 | 中文无码成人免费视频在线观看 | 日本又色又爽又黄的a片18禁 | 久久99精品国产.久久久久 | 俺去俺来也www色官网 | 东京热一精品无码av | 国产内射老熟女aaaa | 久久精品一区二区三区四区 | 又大又紧又粉嫩18p少妇 | 无套内谢的新婚少妇国语播放 | 日本大乳高潮视频在线观看 | 内射爽无广熟女亚洲 | 国产熟妇高潮叫床视频播放 | 精品无人区无码乱码毛片国产 | 亚洲精品综合一区二区三区在线 | 亚洲熟妇自偷自拍另类 | 亚洲另类伦春色综合小说 | 欧美国产亚洲日韩在线二区 | 久久久久久久女国产乱让韩 | 奇米影视7777久久精品人人爽 | 精品国偷自产在线视频 | 女人被男人爽到呻吟的视频 | 久久视频在线观看精品 | 久久国产精品精品国产色婷婷 | 婷婷五月综合激情中文字幕 | 免费无码一区二区三区蜜桃大 | 亚洲第一无码av无码专区 | 国产午夜精品一区二区三区嫩草 | 又色又爽又黄的美女裸体网站 | 亚洲自偷自拍另类第1页 | 亚洲欧洲日本综合aⅴ在线 | 麻豆蜜桃av蜜臀av色欲av | 青春草在线视频免费观看 | 99国产精品白浆在线观看免费 | 一二三四在线观看免费视频 | 国产suv精品一区二区五 | 久久午夜无码鲁丝片午夜精品 | 久久精品国产日本波多野结衣 | 久久www免费人成人片 | 国产亚洲精品精品国产亚洲综合 | 亚洲乱码中文字幕在线 | 亚洲一区二区三区四区 | 夜夜高潮次次欢爽av女 | 午夜成人1000部免费视频 | 国内丰满熟女出轨videos | 久久久久久a亚洲欧洲av冫 | 东京热无码av男人的天堂 | 久久久久久久久888 | 亚洲高清偷拍一区二区三区 | 日韩精品久久久肉伦网站 | 久久精品女人天堂av免费观看 | 国产高清不卡无码视频 | 国产在线aaa片一区二区99 | 四虎4hu永久免费 | 亚洲综合精品香蕉久久网 | 国产在线一区二区三区四区五区 | 中国女人内谢69xxxxxa片 | 波多野结衣av在线观看 | 少妇厨房愉情理9仑片视频 | 亚无码乱人伦一区二区 | 亚洲码国产精品高潮在线 | 十八禁真人啪啪免费网站 | 捆绑白丝粉色jk震动捧喷白浆 | 日本一区二区三区免费播放 | 桃花色综合影院 | 免费国产黄网站在线观看 | 夜精品a片一区二区三区无码白浆 | 国产又粗又硬又大爽黄老大爷视 | 中文字幕 人妻熟女 | 国产午夜福利亚洲第一 | 国产成人精品久久亚洲高清不卡 | 欧美阿v高清资源不卡在线播放 | 亚洲码国产精品高潮在线 | 色综合久久网 | 又湿又紧又大又爽a视频国产 | 亚洲国产精品久久久久久 | 黑人巨大精品欧美黑寡妇 | 国产成人无码av在线影院 | 大屁股大乳丰满人妻 | 精品国产福利一区二区 | 国产av一区二区精品久久凹凸 | 日韩精品a片一区二区三区妖精 | 亚洲综合精品香蕉久久网 | 高中生自慰www网站 | 激情内射亚州一区二区三区爱妻 | 无码国产色欲xxxxx视频 | 国产精品美女久久久久av爽李琼 | 精品无码国产自产拍在线观看蜜 | 日韩精品无码免费一区二区三区 | 中文字幕色婷婷在线视频 | 日韩av激情在线观看 | 日韩亚洲欧美精品综合 | 无人区乱码一区二区三区 | 日韩精品久久久肉伦网站 | 狂野欧美性猛xxxx乱大交 | 日韩精品乱码av一区二区 | 久久综合色之久久综合 | 国产99久久精品一区二区 | 欧美日韩色另类综合 | 国产亚洲人成在线播放 | 日本大乳高潮视频在线观看 | 风流少妇按摩来高潮 | 日本精品人妻无码免费大全 | 熟妇女人妻丰满少妇中文字幕 | 日本成熟视频免费视频 | 亚洲熟妇色xxxxx欧美老妇 | 少妇人妻大乳在线视频 | 免费视频欧美无人区码 | 丰满妇女强制高潮18xxxx | 99国产精品白浆在线观看免费 | 成人动漫在线观看 | 亚洲色欲久久久综合网东京热 | 亚洲性无码av中文字幕 | 成人精品天堂一区二区三区 | 清纯唯美经典一区二区 | 好爽又高潮了毛片免费下载 | 青春草在线视频免费观看 | 国产一区二区三区精品视频 | 美女张开腿让人桶 | 伊人久久大香线蕉午夜 | 2020久久超碰国产精品最新 | 国产97在线 | 亚洲 | 久久久久久亚洲精品a片成人 | 无码av最新清无码专区吞精 | 中文字幕av无码一区二区三区电影 | 一个人免费观看的www视频 | 最新国产乱人伦偷精品免费网站 | 精品无人区无码乱码毛片国产 | 亚洲中文字幕无码中文字在线 | 色综合视频一区二区三区 | 久久久久成人精品免费播放动漫 | 色综合久久久无码中文字幕 | 亚洲色欲久久久综合网东京热 | 久久久亚洲欧洲日产国码αv | 色老头在线一区二区三区 | 精品成在人线av无码免费看 | 日韩人妻无码一区二区三区久久99 | 日日碰狠狠躁久久躁蜜桃 | 亚洲狠狠婷婷综合久久 | 波多野42部无码喷潮在线 | 久久精品丝袜高跟鞋 | 久久精品中文字幕大胸 | 女人和拘做爰正片视频 | 成人综合网亚洲伊人 | 中文字幕精品av一区二区五区 | 午夜无码区在线观看 | 丰满人妻精品国产99aⅴ | 少妇太爽了在线观看 | 永久免费观看国产裸体美女 | 国产精品丝袜黑色高跟鞋 | 欧美成人午夜精品久久久 | 国语精品一区二区三区 | 国产亚洲人成在线播放 | 人人妻人人澡人人爽人人精品 | 无码任你躁久久久久久久 | 最近免费中文字幕中文高清百度 | 色情久久久av熟女人妻网站 | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲精品午夜无码电影网 | 一二三四社区在线中文视频 | 亚洲 a v无 码免 费 成 人 a v | 国产亚洲精品久久久久久 | 蜜臀av在线播放 久久综合激激的五月天 | 成人无码影片精品久久久 | 正在播放老肥熟妇露脸 | 无码纯肉视频在线观看 | 97色伦图片97综合影院 | 性生交大片免费看女人按摩摩 | 欧美黑人巨大xxxxx | 亚洲一区av无码专区在线观看 | 熟女体下毛毛黑森林 | 欧美肥老太牲交大战 | 国产9 9在线 | 中文 | 亚洲成av人影院在线观看 | 99久久精品日本一区二区免费 | 成人一在线视频日韩国产 | 国产精品18久久久久久麻辣 | av无码电影一区二区三区 | 国产成人精品视频ⅴa片软件竹菊 | 玩弄人妻少妇500系列视频 | 亚洲色欲久久久综合网东京热 | 国产成人精品视频ⅴa片软件竹菊 | 狠狠色色综合网站 | 日本一区二区三区免费高清 | 精品国产成人一区二区三区 | 国产成人亚洲综合无码 | 久久综合色之久久综合 | 免费播放一区二区三区 | 久久aⅴ免费观看 | 亚洲午夜久久久影院 | 国产超级va在线观看视频 | 内射白嫩少妇超碰 | 亚洲精品一区二区三区大桥未久 | 亚洲国产精品毛片av不卡在线 | 无码福利日韩神码福利片 | 亚洲精品国产品国语在线观看 | 亚洲 日韩 欧美 成人 在线观看 | 欧美色就是色 | 欧美日韩一区二区免费视频 | 亚洲精品鲁一鲁一区二区三区 | 国产一区二区三区精品视频 | 综合人妻久久一区二区精品 | 国内精品九九久久久精品 | 超碰97人人射妻 | 国产成人精品一区二区在线小狼 | 国产偷自视频区视频 | 精品无码国产自产拍在线观看蜜 | 国产国语老龄妇女a片 | 久久人人爽人人爽人人片ⅴ | 自拍偷自拍亚洲精品被多人伦好爽 | 亚洲欧洲无卡二区视頻 | 未满小14洗澡无码视频网站 | 丰满肥臀大屁股熟妇激情视频 | 久久久久久久久蜜桃 | 天天爽夜夜爽夜夜爽 | 久久亚洲精品成人无码 | 国产精品va在线观看无码 | 男人和女人高潮免费网站 | 男女猛烈xx00免费视频试看 | 无码人妻少妇伦在线电影 | 黑人巨大精品欧美一区二区 | 国产suv精品一区二区五 | 欧美精品一区二区精品久久 | 午夜福利试看120秒体验区 | 日韩av无码中文无码电影 | 日韩亚洲欧美精品综合 | 成人一在线视频日韩国产 | 牲欲强的熟妇农村老妇女视频 | 麻豆国产97在线 | 欧洲 | 大肉大捧一进一出视频出来呀 | 狠狠躁日日躁夜夜躁2020 | 人妻少妇被猛烈进入中文字幕 | 成人精品视频一区二区三区尤物 | 精品国产福利一区二区 | 最近的中文字幕在线看视频 | 高清无码午夜福利视频 | 中文字幕av日韩精品一区二区 | 99精品无人区乱码1区2区3区 | 久久综合九色综合欧美狠狠 | 激情五月综合色婷婷一区二区 | 色综合天天综合狠狠爱 | a在线亚洲男人的天堂 | 欧美怡红院免费全部视频 | 亚洲成色在线综合网站 | 中文无码成人免费视频在线观看 | 亚洲色在线无码国产精品不卡 | 久久精品无码一区二区三区 | 国产精品久久久久无码av色戒 | 国产莉萝无码av在线播放 | 波多野42部无码喷潮在线 | 成人免费视频在线观看 | a在线观看免费网站大全 | 久久综合香蕉国产蜜臀av | 色一情一乱一伦一视频免费看 | 55夜色66夜色国产精品视频 | 精品成在人线av无码免费看 | 精品夜夜澡人妻无码av蜜桃 | 久久综合九色综合97网 | 中文字幕无码热在线视频 | 亚洲欧美日韩国产精品一区二区 | 久久久精品456亚洲影院 | 一本加勒比波多野结衣 | 国产人妻精品午夜福利免费 | 国产精品丝袜黑色高跟鞋 | 午夜嘿嘿嘿影院 | 激情国产av做激情国产爱 | 国产精品久久久久7777 | 亚洲一区二区观看播放 | 国产成人人人97超碰超爽8 | 中国女人内谢69xxxxxa片 | 精品国产麻豆免费人成网站 | 精品夜夜澡人妻无码av蜜桃 | 国内精品九九久久久精品 | 欧洲精品码一区二区三区免费看 | 国产亲子乱弄免费视频 | 亚洲欧美综合区丁香五月小说 | 一本加勒比波多野结衣 | 亚洲日韩av一区二区三区四区 | 性欧美疯狂xxxxbbbb | 国产激情艳情在线看视频 | 在线观看国产午夜福利片 | 九九久久精品国产免费看小说 | 好屌草这里只有精品 | 亚洲 激情 小说 另类 欧美 | 精品人妻人人做人人爽夜夜爽 | 久久久久成人片免费观看蜜芽 | 国产精品第一国产精品 | 国产麻豆精品精东影业av网站 | 久久久www成人免费毛片 | 在线 国产 欧美 亚洲 天堂 | 搡女人真爽免费视频大全 | 男女猛烈xx00免费视频试看 | 熟女少妇人妻中文字幕 | 亚洲国产精品一区二区第一页 | 日本精品人妻无码免费大全 | 一本久久伊人热热精品中文字幕 | 欧美丰满少妇xxxx性 | 狠狠噜狠狠狠狠丁香五月 | 纯爱无遮挡h肉动漫在线播放 | 久久精品视频在线看15 | 国产人妻久久精品二区三区老狼 | 领导边摸边吃奶边做爽在线观看 | 四虎4hu永久免费 | yw尤物av无码国产在线观看 | 夜夜高潮次次欢爽av女 | 亚洲成av人片天堂网无码】 | 精品欧美一区二区三区久久久 | 欧美日韩视频无码一区二区三 | 少妇性俱乐部纵欲狂欢电影 | 丰腴饱满的极品熟妇 | а√天堂www在线天堂小说 | 麻豆成人精品国产免费 | 精品人妻av区 | 成人免费无码大片a毛片 | а天堂中文在线官网 | 人人爽人人澡人人高潮 | 激情内射亚州一区二区三区爱妻 | 性欧美videos高清精品 | 日日噜噜噜噜夜夜爽亚洲精品 | 国产后入清纯学生妹 | 久久婷婷五月综合色国产香蕉 | 色一情一乱一伦一视频免费看 | 国产成人无码午夜视频在线观看 | 樱花草在线社区www | 亚洲а∨天堂久久精品2021 | 国产午夜亚洲精品不卡 | 国产精品久久久午夜夜伦鲁鲁 | 人人澡人人透人人爽 | 天天摸天天透天天添 | 动漫av网站免费观看 | 鲁鲁鲁爽爽爽在线视频观看 | 欧美放荡的少妇 | 红桃av一区二区三区在线无码av | 无码播放一区二区三区 | 激情人妻另类人妻伦 | 久久久精品456亚洲影院 | 中文无码成人免费视频在线观看 | 成人免费无码大片a毛片 | 国产美女精品一区二区三区 | 青青青爽视频在线观看 | 日本乱人伦片中文三区 | 亚洲色大成网站www | 性生交片免费无码看人 | 色婷婷综合中文久久一本 | 国产精品18久久久久久麻辣 | 呦交小u女精品视频 | 久久人人爽人人爽人人片av高清 | 成 人 免费观看网站 | 亚洲中文字幕无码中字 | 免费播放一区二区三区 | 久久久久亚洲精品男人的天堂 | 女人被男人躁得好爽免费视频 | 狠狠综合久久久久综合网 | 中文亚洲成a人片在线观看 | 亚洲伊人久久精品影院 | 男女作爱免费网站 | 国产在线一区二区三区四区五区 | 亚洲人成网站在线播放942 | 亚洲大尺度无码无码专区 | 久久久久免费精品国产 | 国产人成高清在线视频99最全资源 | 最新版天堂资源中文官网 | 久久久婷婷五月亚洲97号色 | 国产后入清纯学生妹 | 无码国产色欲xxxxx视频 | 国产精品美女久久久网av | 中文久久乱码一区二区 | 久久99精品国产麻豆 | 老子影院午夜精品无码 | 青青久在线视频免费观看 | 欧美三级不卡在线观看 | 红桃av一区二区三区在线无码av | 无码乱肉视频免费大全合集 | 人妻有码中文字幕在线 | 丝袜美腿亚洲一区二区 | 荫蒂被男人添的好舒服爽免费视频 | 久久99精品久久久久婷婷 | 国产在线精品一区二区三区直播 | 久久精品人人做人人综合试看 | 精品偷自拍另类在线观看 | 久久精品中文字幕一区 | 老头边吃奶边弄进去呻吟 | 一本精品99久久精品77 | 中文字幕日韩精品一区二区三区 | 亚洲成a人片在线观看无码3d | 国产成人一区二区三区别 | 精品国产av色一区二区深夜久久 | 欧美人与物videos另类 | 国产成人无码av在线影院 | 成人三级无码视频在线观看 | 亚洲精品久久久久avwww潮水 | 国内少妇偷人精品视频免费 | 国产内射爽爽大片视频社区在线 | 在线播放免费人成毛片乱码 | 亚洲成av人影院在线观看 | 日韩av无码中文无码电影 | 人妻尝试又大又粗久久 | 免费乱码人妻系列无码专区 | 久久精品无码一区二区三区 | 亚洲欧美国产精品久久 | 久久综合狠狠综合久久综合88 | 色一情一乱一伦一视频免费看 | 最新国产麻豆aⅴ精品无码 | 色综合久久88色综合天天 | 夜夜影院未满十八勿进 | 亚洲自偷精品视频自拍 | 老熟女乱子伦 | 野外少妇愉情中文字幕 | 精品偷拍一区二区三区在线看 | 日本精品少妇一区二区三区 | 久久婷婷五月综合色国产香蕉 | 国产精品igao视频网 | 久9re热视频这里只有精品 | 欧美人与禽zoz0性伦交 | 国产人妻精品午夜福利免费 | 国产成人综合在线女婷五月99播放 | 狠狠噜狠狠狠狠丁香五月 | 国产一区二区不卡老阿姨 | 欧美熟妇另类久久久久久不卡 | 国内精品一区二区三区不卡 | 中文字幕无码免费久久99 | 色 综合 欧美 亚洲 国产 | 亚洲一区二区三区国产精华液 | 欧美人妻一区二区三区 | 国产黑色丝袜在线播放 | 一区二区传媒有限公司 | 久久久久亚洲精品男人的天堂 | 99久久无码一区人妻 | 色诱久久久久综合网ywww | 国内少妇偷人精品视频免费 | 国产在线精品一区二区三区直播 | 国内精品九九久久久精品 | 无码吃奶揉捏奶头高潮视频 | 日本大乳高潮视频在线观看 | 少妇久久久久久人妻无码 | 无码成人精品区在线观看 | 国产香蕉尹人综合在线观看 | 学生妹亚洲一区二区 | 无遮无挡爽爽免费视频 | 呦交小u女精品视频 | 暴力强奷在线播放无码 | 一本色道婷婷久久欧美 | 无码中文字幕色专区 | 人妻少妇被猛烈进入中文字幕 | 伊人久久大香线焦av综合影院 | 国产片av国语在线观看 | 亚洲日本va中文字幕 | 丰满岳乱妇在线观看中字无码 | 日韩人妻无码一区二区三区久久99 | 性欧美熟妇videofreesex | 曰韩少妇内射免费播放 | 欧美日韩色另类综合 | 国产乡下妇女做爰 | 午夜福利试看120秒体验区 | 精品厕所偷拍各类美女tp嘘嘘 | 亚洲综合久久一区二区 | 国产suv精品一区二区五 | 国产午夜无码精品免费看 | 国产精品亚洲а∨无码播放麻豆 | 国产av剧情md精品麻豆 | 亚洲男女内射在线播放 | 国产精品办公室沙发 | 国产精品美女久久久网av | 中文字幕精品av一区二区五区 | 亚洲日韩av一区二区三区四区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 国产做国产爱免费视频 | 99久久人妻精品免费二区 | 自拍偷自拍亚洲精品被多人伦好爽 | 狠狠噜狠狠狠狠丁香五月 | 一本久久伊人热热精品中文字幕 | 中文字幕无线码 | 国产精品美女久久久久av爽李琼 | 国产熟妇另类久久久久 | 亚洲精品一区二区三区四区五区 | 国产69精品久久久久app下载 | 欧美熟妇另类久久久久久多毛 | 美女黄网站人色视频免费国产 | 女人高潮内射99精品 | 欧美黑人乱大交 | www一区二区www免费 | 麻豆蜜桃av蜜臀av色欲av | 欧美精品在线观看 | 国产av无码专区亚洲awww | 国产片av国语在线观看 | 人人妻人人澡人人爽人人精品 | 国精产品一区二区三区 | 精品熟女少妇av免费观看 | 东京无码熟妇人妻av在线网址 | 国产精品对白交换视频 | 国产手机在线αⅴ片无码观看 | 亚洲日韩精品欧美一区二区 | 亚洲色偷偷男人的天堂 | 女高中生第一次破苞av | 无码国内精品人妻少妇 | 性啪啪chinese东北女人 | 超碰97人人做人人爱少妇 | 亚洲第一网站男人都懂 | 免费观看的无遮挡av | 国产亚洲精品久久久久久久久动漫 | 夜夜影院未满十八勿进 | 美女极度色诱视频国产 | 亚洲国产成人av在线观看 | 亚洲欧洲中文日韩av乱码 | 亚洲精品国偷拍自产在线麻豆 | 蜜桃无码一区二区三区 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产在线aaa片一区二区99 | 欧美熟妇另类久久久久久不卡 | 欧美老人巨大xxxx做受 | 狠狠色噜噜狠狠狠7777奇米 | 午夜丰满少妇性开放视频 | 久久无码中文字幕免费影院蜜桃 | www国产亚洲精品久久网站 | 欧美成人免费全部网站 | 国产精品高潮呻吟av久久 | 一区二区三区高清视频一 | 丰满人妻一区二区三区免费视频 | 小泽玛莉亚一区二区视频在线 | 久久无码人妻影院 | 欧美xxxxx精品 | 亚洲日本va午夜在线电影 | 帮老师解开蕾丝奶罩吸乳网站 | 永久免费观看国产裸体美女 | 亚洲精品午夜国产va久久成人 | 日韩人妻少妇一区二区三区 | 国产午夜亚洲精品不卡 | 无套内射视频囯产 | 婷婷色婷婷开心五月四房播播 | 亚洲天堂2017无码 | 最新版天堂资源中文官网 | 水蜜桃亚洲一二三四在线 | 少妇被黑人到高潮喷出白浆 | 国产又爽又黄又刺激的视频 | 永久免费观看美女裸体的网站 | 中文字幕人成乱码熟女app | 色综合久久中文娱乐网 | 98国产精品综合一区二区三区 | 乱中年女人伦av三区 | 在线播放免费人成毛片乱码 | 沈阳熟女露脸对白视频 | 亚洲日韩精品欧美一区二区 | 日本乱偷人妻中文字幕 | 亚洲精品国产精品乱码视色 | 午夜无码区在线观看 | 噜噜噜亚洲色成人网站 | 久久久精品人妻久久影视 | 激情内射日本一区二区三区 | 一本大道久久东京热无码av | 亚洲色偷偷男人的天堂 | 亚洲精品一区二区三区在线 | 午夜肉伦伦影院 | 欧美高清在线精品一区 | 无码人妻黑人中文字幕 | 中文字幕av无码一区二区三区电影 | 麻花豆传媒剧国产免费mv在线 | 国内丰满熟女出轨videos | 日本一卡2卡3卡四卡精品网站 | 四十如虎的丰满熟妇啪啪 | 亚洲色偷偷偷综合网 | 国产69精品久久久久app下载 | 国产精品二区一区二区aⅴ污介绍 | 亚洲另类伦春色综合小说 | 亚洲无人区午夜福利码高清完整版 | 中文字幕无线码 | 青青青爽视频在线观看 | 四虎国产精品一区二区 | 亚洲精品成人福利网站 | 无码任你躁久久久久久久 | 一本久道高清无码视频 | 夜先锋av资源网站 | 亚洲 激情 小说 另类 欧美 | 麻豆国产丝袜白领秘书在线观看 | 牛和人交xxxx欧美 | 日日摸天天摸爽爽狠狠97 | 人妻少妇精品无码专区二区 | 欧美熟妇另类久久久久久不卡 | 成人免费视频视频在线观看 免费 | 乱人伦人妻中文字幕无码久久网 | 激情内射亚州一区二区三区爱妻 | 日本精品少妇一区二区三区 | 精品久久久无码人妻字幂 | 未满成年国产在线观看 | 免费视频欧美无人区码 | 欧美怡红院免费全部视频 | 无码国产色欲xxxxx视频 | 欧美日韩一区二区免费视频 | 国产在热线精品视频 | 国产福利视频一区二区 | 全黄性性激高免费视频 | a在线观看免费网站大全 | 日日橹狠狠爱欧美视频 | 爆乳一区二区三区无码 | 熟妇人妻激情偷爽文 | 色婷婷久久一区二区三区麻豆 | 2020最新国产自产精品 | 久青草影院在线观看国产 | 熟妇激情内射com | 精品一区二区不卡无码av | 亚洲国产精品无码久久久久高潮 | 中文字幕人成乱码熟女app | 少妇高潮喷潮久久久影院 | 色婷婷av一区二区三区之红樱桃 | 自拍偷自拍亚洲精品被多人伦好爽 | 亚洲 a v无 码免 费 成 人 a v | 久久久久久九九精品久 | 国产精品.xx视频.xxtv | 国产人妻久久精品二区三区老狼 | a片免费视频在线观看 | 亚洲欧洲日本综合aⅴ在线 | 国产无遮挡又黄又爽又色 | 久久精品女人的天堂av | 小sao货水好多真紧h无码视频 | 午夜福利电影 | 精品无码一区二区三区的天堂 | 蜜桃av抽搐高潮一区二区 | 欧美日韩综合一区二区三区 | 亚洲国产欧美国产综合一区 | 国产激情无码一区二区app | 国产精品毛多多水多 | 日日干夜夜干 | 国产 浪潮av性色四虎 | 在线a亚洲视频播放在线观看 | 日本成熟视频免费视频 | 欧美日韩人成综合在线播放 | 人人妻人人藻人人爽欧美一区 | 日日橹狠狠爱欧美视频 | 亚洲熟妇色xxxxx欧美老妇 | 国产黄在线观看免费观看不卡 | 东京一本一道一二三区 | 国产精品理论片在线观看 | 日日躁夜夜躁狠狠躁 | 久久久精品国产sm最大网站 | 久久精品女人天堂av免费观看 | 欧美精品无码一区二区三区 | 国产手机在线αⅴ片无码观看 | 午夜精品久久久久久久 | 丰满少妇人妻久久久久久 | 国产一区二区三区精品视频 | 夜夜高潮次次欢爽av女 | 男女作爱免费网站 | 欧美精品免费观看二区 | 国产香蕉尹人综合在线观看 | 无码午夜成人1000部免费视频 | 国产精品亚洲专区无码不卡 | 日本欧美一区二区三区乱码 | 国产精品-区区久久久狼 | 国产成人精品优优av | 白嫩日本少妇做爰 | 四虎国产精品一区二区 | 熟女少妇在线视频播放 | 国内揄拍国内精品少妇国语 | 天天躁日日躁狠狠躁免费麻豆 | 亚洲欧洲中文日韩av乱码 | 无码av免费一区二区三区试看 | 男女猛烈xx00免费视频试看 | 精品水蜜桃久久久久久久 | 一本一道久久综合久久 | 牲欲强的熟妇农村老妇女 | 国产激情无码一区二区app | 日本xxxx色视频在线观看免费 | 国产亚洲精品精品国产亚洲综合 | 一本色道久久综合亚洲精品不卡 | 我要看www免费看插插视频 | 特级做a爰片毛片免费69 | 全球成人中文在线 | 成人性做爰aaa片免费看 | 丰满少妇弄高潮了www | 九九在线中文字幕无码 | 未满小14洗澡无码视频网站 | 澳门永久av免费网站 | 亚洲区小说区激情区图片区 | 国产超级va在线观看视频 | 久久久久久a亚洲欧洲av冫 | 国产一区二区三区精品视频 | 欧美性生交xxxxx久久久 | 欧美大屁股xxxxhd黑色 | 18黄暴禁片在线观看 | 亚洲色成人中文字幕网站 | 亚洲国产精品无码久久久久高潮 | 女人色极品影院 | 国产成人综合色在线观看网站 | 亚洲精品一区二区三区在线观看 | 亚洲国产av精品一区二区蜜芽 | 国产亚洲美女精品久久久2020 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 久久精品人人做人人综合试看 | 欧美兽交xxxx×视频 | 帮老师解开蕾丝奶罩吸乳网站 | 中文亚洲成a人片在线观看 | 免费网站看v片在线18禁无码 | 亚洲国产精品美女久久久久 | av在线亚洲欧洲日产一区二区 | 乌克兰少妇xxxx做受 | 亚洲精品无码国产 | 性史性农村dvd毛片 | 国产亚洲精品久久久久久国模美 | 国产亚洲精品久久久ai换 | 黑人粗大猛烈进出高潮视频 | 欧美丰满老熟妇xxxxx性 | √天堂资源地址中文在线 | 漂亮人妻洗澡被公强 日日躁 | 国产色在线 | 国产 | 丰满人妻一区二区三区免费视频 | 蜜桃臀无码内射一区二区三区 | 婷婷五月综合缴情在线视频 | 激情内射亚州一区二区三区爱妻 | 99精品国产综合久久久久五月天 | 狠狠躁日日躁夜夜躁2020 | 免费无码av一区二区 | 3d动漫精品啪啪一区二区中 | 日韩视频 中文字幕 视频一区 | а√资源新版在线天堂 | 国产精品办公室沙发 | 国产高潮视频在线观看 | 亚洲无人区午夜福利码高清完整版 | 亚洲人亚洲人成电影网站色 | 国产午夜视频在线观看 | 秋霞成人午夜鲁丝一区二区三区 | 久久久久久久女国产乱让韩 | 成人精品天堂一区二区三区 | 日本熟妇浓毛 | 久久久国产精品无码免费专区 | 国内精品人妻无码久久久影院蜜桃 | 少妇的肉体aa片免费 | 无码纯肉视频在线观看 | 激情五月综合色婷婷一区二区 | 免费播放一区二区三区 | 中文字幕色婷婷在线视频 | 丁香啪啪综合成人亚洲 | 少妇厨房愉情理9仑片视频 | 精品人妻人人做人人爽夜夜爽 | 日韩欧美群交p片內射中文 | 99久久99久久免费精品蜜桃 | 少妇性l交大片欧洲热妇乱xxx | 奇米影视888欧美在线观看 | 日本xxxx色视频在线观看免费 | 国内精品人妻无码久久久影院蜜桃 | 日本护士xxxxhd少妇 | 沈阳熟女露脸对白视频 | 亚洲一区二区三区国产精华液 | 亚洲乱码中文字幕在线 | 亚洲一区二区三区香蕉 | 两性色午夜视频免费播放 | 国产一区二区三区四区五区加勒比 | 啦啦啦www在线观看免费视频 | 老头边吃奶边弄进去呻吟 | 欧美喷潮久久久xxxxx | 午夜熟女插插xx免费视频 | 日韩亚洲欧美精品综合 | 一区二区三区高清视频一 | 国产色精品久久人妻 | 亚洲成a人片在线观看日本 | 国产精品久久久久9999小说 | 国产综合色产在线精品 | 性啪啪chinese东北女人 | 日韩av无码中文无码电影 | 性做久久久久久久免费看 | 亚洲经典千人经典日产 | 久久精品国产日本波多野结衣 | 大地资源网第二页免费观看 | 亚洲国产成人a精品不卡在线 | 亚洲小说图区综合在线 | 亚洲成av人综合在线观看 | 欧美国产日韩亚洲中文 | 性欧美videos高清精品 | 狠狠色噜噜狠狠狠7777奇米 | 无码乱肉视频免费大全合集 | 国产av无码专区亚洲a∨毛片 | 欧美国产日韩久久mv | 欧美激情一区二区三区成人 | 国产精品无码mv在线观看 | 欧美35页视频在线观看 | 国产真实夫妇视频 | 黑人粗大猛烈进出高潮视频 | 又大又黄又粗又爽的免费视频 | 东京无码熟妇人妻av在线网址 | 成在人线av无码免费 | 初尝人妻少妇中文字幕 | 久热国产vs视频在线观看 | 久久久久se色偷偷亚洲精品av | 无套内谢老熟女 | 亚洲自偷精品视频自拍 | 麻豆精品国产精华精华液好用吗 | 装睡被陌生人摸出水好爽 | 精品一区二区三区波多野结衣 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 久久精品人妻少妇一区二区三区 | 久久天天躁夜夜躁狠狠 | 国产成人综合色在线观看网站 | 少妇性俱乐部纵欲狂欢电影 | 日产国产精品亚洲系列 | 亚洲伊人久久精品影院 | 亚洲成av人片天堂网无码】 | 国产午夜无码精品免费看 | 亚洲呦女专区 | 久久久久99精品成人片 | 国产莉萝无码av在线播放 | 久久久国产精品无码免费专区 | 亚洲中文字幕成人无码 | 久久久久久国产精品无码下载 | 波多野结衣 黑人 | 国产精品高潮呻吟av久久4虎 |