3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

當(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ò),歡迎將生活随笔推薦給好友。

亚洲精品一区三区三区在线观看 | 中文精品久久久久人妻不卡 | 97se亚洲精品一区 | 性生交大片免费看l | 精品欧洲av无码一区二区三区 | 日日躁夜夜躁狠狠躁 | 中文字幕无码热在线视频 | 亚洲精品中文字幕久久久久 | 狂野欧美激情性xxxx | 国产熟女一区二区三区四区五区 | 亚洲精品综合五月久久小说 | 国产人妻精品一区二区三区不卡 | 国产97在线 | 亚洲 | 国产偷自视频区视频 | 久久久久99精品成人片 | 麻豆果冻传媒2021精品传媒一区下载 | 麻豆人妻少妇精品无码专区 | 婷婷综合久久中文字幕蜜桃三电影 | 亚洲另类伦春色综合小说 | 日欧一片内射va在线影院 | 无遮无挡爽爽免费视频 | 久久99精品久久久久婷婷 | 欧美国产日产一区二区 | 无码福利日韩神码福利片 | 欧美性黑人极品hd | 精品国产av色一区二区深夜久久 | 亚洲熟妇色xxxxx欧美老妇y | 伊在人天堂亚洲香蕉精品区 | aa片在线观看视频在线播放 | 无遮无挡爽爽免费视频 | 人妻天天爽夜夜爽一区二区 | 婷婷丁香五月天综合东京热 | 亚洲色偷偷男人的天堂 | 一个人免费观看的www视频 | 曰韩少妇内射免费播放 | 在线观看国产一区二区三区 | 午夜福利不卡在线视频 | 日韩人妻无码中文字幕视频 | 欧美xxxx黑人又粗又长 | 丰满人妻翻云覆雨呻吟视频 | 人妻熟女一区 | 日本va欧美va欧美va精品 | 亚洲成av人影院在线观看 | 国产精品香蕉在线观看 | 中文字幕无线码 | 国产精品-区区久久久狼 | 国产亚洲人成a在线v网站 | 国内精品一区二区三区不卡 | 97精品国产97久久久久久免费 | 成人精品视频一区二区三区尤物 | 日本www一道久久久免费榴莲 | 亚洲国产精品无码久久久久高潮 | 国产 精品 自在自线 | 人人澡人人妻人人爽人人蜜桃 | 成人免费视频视频在线观看 免费 | 一本大道久久东京热无码av | 久久精品视频在线看15 | 亚洲综合无码一区二区三区 | 国产成人精品一区二区在线小狼 | 久久亚洲国产成人精品性色 | 欧美丰满熟妇xxxx性ppx人交 | 东京无码熟妇人妻av在线网址 | 日本大香伊一区二区三区 | 少妇性俱乐部纵欲狂欢电影 | 露脸叫床粗话东北少妇 | 人人妻人人澡人人爽人人精品 | 亚洲国产精品成人久久蜜臀 | 丰满护士巨好爽好大乳 | 男女下面进入的视频免费午夜 | 国产农村妇女高潮大叫 | 成熟妇人a片免费看网站 | 亚洲欧美中文字幕5发布 | 人人妻人人藻人人爽欧美一区 | 成人av无码一区二区三区 | 丰满护士巨好爽好大乳 | 樱花草在线播放免费中文 | 国产极品美女高潮无套在线观看 | 亚洲精品成人福利网站 | 日本熟妇乱子伦xxxx | 日本精品人妻无码77777 天堂一区人妻无码 | 亚洲中文字幕成人无码 | 无码帝国www无码专区色综合 | 亚洲中文无码av永久不收费 | 东京热男人av天堂 | 人妻少妇被猛烈进入中文字幕 | aⅴ在线视频男人的天堂 | 夜先锋av资源网站 | 国产精品久久久久久亚洲毛片 | 精品乱子伦一区二区三区 | 大乳丰满人妻中文字幕日本 | 色偷偷人人澡人人爽人人模 | 国产av剧情md精品麻豆 | 成熟妇人a片免费看网站 | 日韩人妻系列无码专区 | 日本www一道久久久免费榴莲 | 丝袜 中出 制服 人妻 美腿 | 欧美日韩视频无码一区二区三 | 亚洲成a人片在线观看无码 | 欧美精品一区二区精品久久 | 久久这里只有精品视频9 | 中文字幕乱码人妻二区三区 | 中文久久乱码一区二区 | 婷婷丁香五月天综合东京热 | 久久久久久a亚洲欧洲av冫 | 97夜夜澡人人双人人人喊 | 欧美日韩综合一区二区三区 | 波多野结衣乳巨码无在线观看 | 成人无码精品1区2区3区免费看 | 男人的天堂2018无码 | 国产精品99爱免费视频 | 国产极品视觉盛宴 | 日日橹狠狠爱欧美视频 | 久久zyz资源站无码中文动漫 | 精品欧洲av无码一区二区三区 | 亚洲一区二区三区四区 | 国产精品欧美成人 | 熟妇人妻激情偷爽文 | 亚洲色www成人永久网址 | 久久精品国产日本波多野结衣 | 四虎影视成人永久免费观看视频 | 欧洲欧美人成视频在线 | 又黄又爽又色的视频 | 少妇邻居内射在线 | 成人精品视频一区二区三区尤物 | 纯爱无遮挡h肉动漫在线播放 | 日韩人妻无码中文字幕视频 | 国产精品久久久久久亚洲影视内衣 | 大屁股大乳丰满人妻 | 人人妻人人澡人人爽欧美一区九九 | 国内少妇偷人精品视频免费 | 性欧美牲交xxxxx视频 | 小sao货水好多真紧h无码视频 | 小鲜肉自慰网站xnxx | 国产免费观看黄av片 | 亚洲综合无码久久精品综合 | 狠狠噜狠狠狠狠丁香五月 | 小sao货水好多真紧h无码视频 | 无码一区二区三区在线观看 | 麻豆成人精品国产免费 | 免费视频欧美无人区码 | 人妻无码αv中文字幕久久琪琪布 | 亚洲精品www久久久 | 午夜肉伦伦影院 | 日韩在线不卡免费视频一区 | 久久久久99精品国产片 | 一个人看的视频www在线 | 国产香蕉尹人视频在线 | 成人性做爰aaa片免费看 | 荫蒂添的好舒服视频囗交 | 伊人久久大香线焦av综合影院 | 久久午夜无码鲁丝片 | 玩弄中年熟妇正在播放 | 欧洲美熟女乱又伦 | 久久精品国产大片免费观看 | 无遮无挡爽爽免费视频 | 日韩无码专区 | 欧美熟妇另类久久久久久多毛 | 在线天堂新版最新版在线8 | 亚洲阿v天堂在线 | 国产小呦泬泬99精品 | 成人综合网亚洲伊人 | 狠狠色噜噜狠狠狠7777奇米 | 国产日产欧产精品精品app | 欧美日韩亚洲国产精品 | 狠狠躁日日躁夜夜躁2020 | 亚洲国产精品成人久久蜜臀 | 理论片87福利理论电影 | 在线 国产 欧美 亚洲 天堂 | 中文字幕乱码人妻二区三区 | 国产亚洲精品久久久久久久 | 久久人妻内射无码一区三区 | 荡女精品导航 | 色综合久久88色综合天天 | 国产一区二区三区精品视频 | 鲁一鲁av2019在线 | 亚洲色偷偷偷综合网 | 99精品无人区乱码1区2区3区 | 亚洲人成人无码网www国产 | 中文精品无码中文字幕无码专区 | 亚洲gv猛男gv无码男同 | 亚洲精品久久久久久一区二区 | 18无码粉嫩小泬无套在线观看 | 纯爱无遮挡h肉动漫在线播放 | 99久久精品无码一区二区毛片 | 三级4级全黄60分钟 | 无码人妻黑人中文字幕 | 亚洲欧美日韩成人高清在线一区 | 亚洲国产精品成人久久蜜臀 | 女人和拘做爰正片视频 | 中文字幕 人妻熟女 | 国产电影无码午夜在线播放 | 呦交小u女精品视频 | 国产性生交xxxxx无码 | 国产亚洲欧美在线专区 | 九九综合va免费看 | 色婷婷久久一区二区三区麻豆 | 又紧又大又爽精品一区二区 | 特黄特色大片免费播放器图片 | 精品久久久久久人妻无码中文字幕 | 亚洲精品国偷拍自产在线麻豆 | 鲁大师影院在线观看 | 最近中文2019字幕第二页 | 久久久久久久人妻无码中文字幕爆 | 夜精品a片一区二区三区无码白浆 | 久久国语露脸国产精品电影 | 97资源共享在线视频 | 内射爽无广熟女亚洲 | 日韩无套无码精品 | 人人爽人人澡人人高潮 | 撕开奶罩揉吮奶头视频 | 成人无码视频在线观看网站 | 亚洲国产成人av在线观看 | 国产精品久久久久久亚洲毛片 | 久久天天躁夜夜躁狠狠 | 377p欧洲日本亚洲大胆 | 少女韩国电视剧在线观看完整 | 国产午夜福利亚洲第一 | 在线 国产 欧美 亚洲 天堂 | 日本熟妇人妻xxxxx人hd | 在线观看国产午夜福利片 | 亚洲国产成人a精品不卡在线 | 水蜜桃亚洲一二三四在线 | 国产成人精品无码播放 | 婷婷丁香五月天综合东京热 | 男女作爱免费网站 | 欧美 亚洲 国产 另类 | 小sao货水好多真紧h无码视频 | 亚洲欧美综合区丁香五月小说 | 人妻体内射精一区二区三四 | 国产国产精品人在线视 | 丰满少妇弄高潮了www | 国产卡一卡二卡三 | 久久久久久久女国产乱让韩 | 乌克兰少妇xxxx做受 | 性色欲情网站iwww九文堂 | 中文字幕无码日韩专区 | 性做久久久久久久久 | 天堂无码人妻精品一区二区三区 | 女人高潮内射99精品 | 国产特级毛片aaaaaaa高清 | 风流少妇按摩来高潮 | 成人免费视频在线观看 | 欧美真人作爱免费视频 | 初尝人妻少妇中文字幕 | av在线亚洲欧洲日产一区二区 | 少妇高潮一区二区三区99 | 少妇太爽了在线观看 | 午夜无码人妻av大片色欲 | 亚洲精品国产第一综合99久久 | 成人免费视频视频在线观看 免费 | 狂野欧美激情性xxxx | 无码福利日韩神码福利片 | 无码午夜成人1000部免费视频 | 1000部啪啪未满十八勿入下载 | 狠狠亚洲超碰狼人久久 | 亚洲爆乳无码专区 | 国产成人亚洲综合无码 | www国产亚洲精品久久网站 | 精品无码国产一区二区三区av | 大地资源中文第3页 | 波多野结衣av一区二区全免费观看 | 亚洲国产日韩a在线播放 | 色婷婷欧美在线播放内射 | 丰满人妻精品国产99aⅴ | 成人三级无码视频在线观看 | 中文字幕人妻无码一夲道 | 狠狠色丁香久久婷婷综合五月 | 欧美激情内射喷水高潮 | 久久国产精品精品国产色婷婷 | 国产香蕉尹人综合在线观看 | 麻豆国产人妻欲求不满谁演的 | 亚洲国产精品成人久久蜜臀 | 国产人妖乱国产精品人妖 | 国产成人精品一区二区在线小狼 | 女人被男人躁得好爽免费视频 | 国产偷自视频区视频 | 久久精品视频在线看15 | 欧美日本精品一区二区三区 | 午夜福利一区二区三区在线观看 | 成人精品一区二区三区中文字幕 | 人妻中文无码久热丝袜 | 毛片内射-百度 | 蜜桃视频插满18在线观看 | 国产内射爽爽大片视频社区在线 | 亚洲乱亚洲乱妇50p | 久久久精品456亚洲影院 | 捆绑白丝粉色jk震动捧喷白浆 | 美女极度色诱视频国产 | 国产乱人偷精品人妻a片 | 国产内射老熟女aaaa | 中文字幕无码免费久久9一区9 | 学生妹亚洲一区二区 | 少妇性荡欲午夜性开放视频剧场 | 欧美放荡的少妇 | 男女超爽视频免费播放 | 国内少妇偷人精品视频 | 国产精品美女久久久久av爽李琼 | 国产成人人人97超碰超爽8 | 女人被男人躁得好爽免费视频 | 狠狠色欧美亚洲狠狠色www | av无码电影一区二区三区 | 精品人妻av区 | 欧美乱妇无乱码大黄a片 | 中文字幕乱妇无码av在线 | 国产亚洲人成a在线v网站 | 18黄暴禁片在线观看 | 亚洲一区av无码专区在线观看 | 丰满护士巨好爽好大乳 | 人人妻人人澡人人爽欧美一区九九 | 中文字幕久久久久人妻 | 强奷人妻日本中文字幕 | 99精品视频在线观看免费 | 中文字幕人妻无码一区二区三区 | 中文字幕色婷婷在线视频 | 99久久久无码国产精品免费 | 亚洲精品无码国产 | 欧洲极品少妇 | 日韩少妇白浆无码系列 | 黑人巨大精品欧美一区二区 | 亚洲国产综合无码一区 | 麻豆成人精品国产免费 | 人人妻人人澡人人爽人人精品 | 亚洲综合伊人久久大杳蕉 | 高中生自慰www网站 | 国产在线一区二区三区四区五区 | 精品亚洲韩国一区二区三区 | 国产精品久久久久9999小说 | 最新国产麻豆aⅴ精品无码 | 中文字幕 亚洲精品 第1页 | 亚洲爆乳大丰满无码专区 | 精品国偷自产在线 | 男女性色大片免费网站 | 亚洲国产精品成人久久蜜臀 | 日本精品久久久久中文字幕 | 两性色午夜视频免费播放 | 中文精品久久久久人妻不卡 | 在线亚洲高清揄拍自拍一品区 | 欧洲极品少妇 | 国内丰满熟女出轨videos | 亚洲va欧美va天堂v国产综合 | 久久亚洲精品中文字幕无男同 | 东京热一精品无码av | 日本一区二区三区免费播放 | 亚洲国产精品毛片av不卡在线 | 日韩人妻无码一区二区三区久久99 | 亚洲娇小与黑人巨大交 | √8天堂资源地址中文在线 | 国产明星裸体无码xxxx视频 | 国产乱人无码伦av在线a | 色婷婷av一区二区三区之红樱桃 | 日韩av无码中文无码电影 | 天堂无码人妻精品一区二区三区 | 桃花色综合影院 | 欧美亚洲日韩国产人成在线播放 | 久青草影院在线观看国产 | 亚洲区欧美区综合区自拍区 | 日日天干夜夜狠狠爱 | 久久久久久九九精品久 | 国产艳妇av在线观看果冻传媒 | 国产精品久久久久影院嫩草 | 日日天干夜夜狠狠爱 | 性色av无码免费一区二区三区 | 久久五月精品中文字幕 | 一区二区传媒有限公司 | 樱花草在线社区www | 婷婷综合久久中文字幕蜜桃三电影 | 国产福利视频一区二区 | 亚洲国产午夜精品理论片 | aⅴ在线视频男人的天堂 | 国产国语老龄妇女a片 | 蜜桃臀无码内射一区二区三区 | 精品国偷自产在线视频 | 熟妇激情内射com | 中文精品久久久久人妻不卡 | 欧美三级不卡在线观看 | 欧洲熟妇色 欧美 | 人妻无码久久精品人妻 | 精品无码国产自产拍在线观看蜜 | 亚洲综合精品香蕉久久网 | 日本一区二区更新不卡 | 丝袜人妻一区二区三区 | 十八禁视频网站在线观看 | 久久综合给久久狠狠97色 | 国内精品人妻无码久久久影院蜜桃 | 九九热爱视频精品 | 又粗又大又硬又长又爽 | 亚洲熟妇色xxxxx亚洲 | 亚洲成av人片在线观看无码不卡 | 国产无遮挡又黄又爽免费视频 | 女人被爽到呻吟gif动态图视看 | 国产真人无遮挡作爱免费视频 | 青青草原综合久久大伊人精品 | 十八禁视频网站在线观看 | 欧洲熟妇色 欧美 | www一区二区www免费 | 亚洲精品国产精品乱码不卡 | 77777熟女视频在线观看 а天堂中文在线官网 | 亚洲精品国偷拍自产在线观看蜜桃 | 中文字幕+乱码+中文字幕一区 | 日本va欧美va欧美va精品 | 亚洲区欧美区综合区自拍区 | 东京无码熟妇人妻av在线网址 | 全黄性性激高免费视频 | ass日本丰满熟妇pics | 夜夜躁日日躁狠狠久久av | 国产成人一区二区三区在线观看 | 成人女人看片免费视频放人 | 国产精品毛多多水多 | 在线观看免费人成视频 | 日本欧美一区二区三区乱码 | 啦啦啦www在线观看免费视频 | 无码精品国产va在线观看dvd | 亚洲熟悉妇女xxx妇女av | 夜精品a片一区二区三区无码白浆 | 亚洲精品综合五月久久小说 | 无码播放一区二区三区 | 国产九九九九九九九a片 | 超碰97人人射妻 | 欧美性生交活xxxxxdddd | 色窝窝无码一区二区三区色欲 | 国产精品久久精品三级 | 日本护士毛茸茸高潮 | 狠狠亚洲超碰狼人久久 | 福利一区二区三区视频在线观看 | 中文字幕无码热在线视频 | 色综合久久久无码网中文 | 中文字幕无码日韩欧毛 | 欧美午夜特黄aaaaaa片 | 亚洲中文字幕无码中字 | 国产精品无套呻吟在线 | 少妇无套内谢久久久久 | 激情内射日本一区二区三区 | 国产亚洲精品精品国产亚洲综合 | 亚洲色www成人永久网址 | 亚洲日本在线电影 | yw尤物av无码国产在线观看 | 免费看男女做好爽好硬视频 | 久久亚洲精品成人无码 | 欧美人与牲动交xxxx | 国产高潮视频在线观看 | 精品久久综合1区2区3区激情 | 久久久久亚洲精品中文字幕 | 国产乡下妇女做爰 | 亚洲色无码一区二区三区 | 中文字幕亚洲情99在线 | 国产又爽又猛又粗的视频a片 | 国产电影无码午夜在线播放 | 亚洲国产精品成人久久蜜臀 | 强辱丰满人妻hd中文字幕 | 国产在线无码精品电影网 | 久激情内射婷内射蜜桃人妖 | 国产绳艺sm调教室论坛 | 欧美丰满少妇xxxx性 | 蜜桃av抽搐高潮一区二区 | 色综合久久久无码网中文 | 国产亚洲人成a在线v网站 | 成人三级无码视频在线观看 | 丰满人妻一区二区三区免费视频 | 国产精品毛片一区二区 | 久久99精品国产麻豆蜜芽 | 天天av天天av天天透 | 鲁一鲁av2019在线 | 国产又粗又硬又大爽黄老大爷视 | 欧洲极品少妇 | 午夜福利不卡在线视频 | 中文字幕乱码亚洲无线三区 | 国产精品香蕉在线观看 | 久久久婷婷五月亚洲97号色 | 成人免费视频一区二区 | 蜜桃臀无码内射一区二区三区 | 国产成人无码区免费内射一片色欲 | 国产精品亚洲一区二区三区喷水 | 久久人人爽人人爽人人片av高清 | 在线成人www免费观看视频 | 亚洲成色在线综合网站 | 国语精品一区二区三区 | 中文字幕乱码亚洲无线三区 | 成人动漫在线观看 | 自拍偷自拍亚洲精品10p | 日本www一道久久久免费榴莲 | 欧美日韩人成综合在线播放 | 婷婷色婷婷开心五月四房播播 | 天堂久久天堂av色综合 | 欧美日韩视频无码一区二区三 | 国产偷国产偷精品高清尤物 | 中文无码成人免费视频在线观看 | 欧美野外疯狂做受xxxx高潮 | a在线亚洲男人的天堂 | 亚洲爆乳精品无码一区二区三区 | 欧美老妇与禽交 | 福利一区二区三区视频在线观看 | 亚洲经典千人经典日产 | 欧洲欧美人成视频在线 | 日日摸天天摸爽爽狠狠97 | 麻豆md0077饥渴少妇 | 国产人妻精品一区二区三区不卡 | 久久婷婷五月综合色国产香蕉 | 亚洲爆乳无码专区 | 波多野结衣 黑人 | 亚洲国产午夜精品理论片 | av在线亚洲欧洲日产一区二区 | 日日摸日日碰夜夜爽av | 在线观看国产午夜福利片 | 久青草影院在线观看国产 | 两性色午夜视频免费播放 | 国产精品人人爽人人做我的可爱 | 粉嫩少妇内射浓精videos | 精品国产一区二区三区四区 | 国产国产精品人在线视 | 久久久久免费看成人影片 | 日日天干夜夜狠狠爱 | 无码国产色欲xxxxx视频 | 好男人社区资源 | 无码精品国产va在线观看dvd | 人妻体内射精一区二区三四 | 三上悠亚人妻中文字幕在线 | 国产精品久免费的黄网站 | 久久国产精品萌白酱免费 | 欧美国产日产一区二区 | 亚洲国产高清在线观看视频 | 图片小说视频一区二区 | 欧美乱妇无乱码大黄a片 | 亚洲成av人在线观看网址 | 国产午夜亚洲精品不卡 | 水蜜桃亚洲一二三四在线 | 中文字幕+乱码+中文字幕一区 | 曰韩无码二三区中文字幕 | 在线视频网站www色 | 国产真人无遮挡作爱免费视频 | 人妻天天爽夜夜爽一区二区 | 强奷人妻日本中文字幕 | 久久精品国产99精品亚洲 | 亚洲中文字幕在线无码一区二区 | 中文精品无码中文字幕无码专区 | 亚洲第一网站男人都懂 | 中文亚洲成a人片在线观看 | 无码精品人妻一区二区三区av | 性欧美牲交xxxxx视频 | 99久久人妻精品免费一区 | 人人妻人人澡人人爽欧美一区 | 亚洲色欲色欲欲www在线 | 无码午夜成人1000部免费视频 | 88国产精品欧美一区二区三区 | 99精品久久毛片a片 | 国产精品无套呻吟在线 | 伊人久久大香线蕉午夜 | 国产精品久久久午夜夜伦鲁鲁 | 青春草在线视频免费观看 | 久热国产vs视频在线观看 | 成年美女黄网站色大免费全看 | 两性色午夜视频免费播放 | 亚洲色大成网站www国产 | 精品国偷自产在线视频 | 国产精品免费大片 | 人妻无码αv中文字幕久久琪琪布 | 亚洲中文字幕久久无码 | 精品一二三区久久aaa片 | 蜜臀aⅴ国产精品久久久国产老师 | 久久久久亚洲精品中文字幕 | 一个人看的视频www在线 | 久久综合久久自在自线精品自 | 美女扒开屁股让男人桶 | 人妻中文无码久热丝袜 | 中文无码精品a∨在线观看不卡 | 亚洲精品www久久久 | 免费中文字幕日韩欧美 | 久久99热只有频精品8 | 亚洲欧洲无卡二区视頻 | 日韩亚洲欧美中文高清在线 | 我要看www免费看插插视频 | 狠狠亚洲超碰狼人久久 | 在线精品国产一区二区三区 | 无码毛片视频一区二区本码 | 少妇激情av一区二区 | 色综合久久88色综合天天 | 熟女俱乐部五十路六十路av | 成人免费视频一区二区 | 国产精品成人av在线观看 | 中文久久乱码一区二区 | 久久精品无码一区二区三区 | 国产亚洲视频中文字幕97精品 | 男人和女人高潮免费网站 | 久久综合狠狠综合久久综合88 | 老子影院午夜精品无码 | 色五月五月丁香亚洲综合网 | 又大又紧又粉嫩18p少妇 | 欧美老熟妇乱xxxxx | 欧美精品免费观看二区 | 国产成人无码专区 | 亚洲一区二区三区香蕉 | 国产精品亚洲综合色区韩国 | 亚洲国产精品一区二区美利坚 | 内射白嫩少妇超碰 | 风流少妇按摩来高潮 | 野狼第一精品社区 | 女人和拘做爰正片视频 | 波多野42部无码喷潮在线 | 俺去俺来也在线www色官网 | 中文无码成人免费视频在线观看 | 国精品人妻无码一区二区三区蜜柚 | 学生妹亚洲一区二区 | 亚洲爆乳精品无码一区二区三区 | 国产在线精品一区二区三区直播 | 国产乱子伦视频在线播放 | 亚洲理论电影在线观看 | 成人精品视频一区二区 | 国产精品无码久久av | 偷窥日本少妇撒尿chinese | 乱人伦中文视频在线观看 | 激情国产av做激情国产爱 | 99精品视频在线观看免费 | 精品 日韩 国产 欧美 视频 | 日本护士毛茸茸高潮 | 青春草在线视频免费观看 | 亚洲国产综合无码一区 | 少妇人妻大乳在线视频 | 成 人 免费观看网站 | 亚洲精品www久久久 | 色综合天天综合狠狠爱 | 欧美成人家庭影院 | √天堂中文官网8在线 | 四虎国产精品免费久久 | a在线亚洲男人的天堂 | 人人妻人人澡人人爽欧美一区九九 | 亚洲区欧美区综合区自拍区 | 亚洲の无码国产の无码影院 | 亚洲中文字幕va福利 | 久久婷婷五月综合色国产香蕉 | 亚洲中文无码av永久不收费 | 又湿又紧又大又爽a视频国产 | 国产suv精品一区二区五 | 久久久久人妻一区精品色欧美 | 无码人妻少妇伦在线电影 | 18无码粉嫩小泬无套在线观看 | 18无码粉嫩小泬无套在线观看 | 亚洲日韩精品欧美一区二区 | 色婷婷综合激情综在线播放 | 特大黑人娇小亚洲女 | 无码精品人妻一区二区三区av | 国产熟女一区二区三区四区五区 | 内射爽无广熟女亚洲 | 黑人巨大精品欧美一区二区 | 亚洲 激情 小说 另类 欧美 | 精品国产av色一区二区深夜久久 | 久久zyz资源站无码中文动漫 | 国产香蕉97碰碰久久人人 | 女人被男人爽到呻吟的视频 | 国产两女互慰高潮视频在线观看 | 亚洲综合另类小说色区 | 中文字幕无码av波多野吉衣 | 亚洲天堂2017无码 | 2020最新国产自产精品 | 人人妻人人澡人人爽精品欧美 | v一区无码内射国产 | 色欲av亚洲一区无码少妇 | 亚洲自偷自拍另类第1页 | 少妇一晚三次一区二区三区 | 亚洲精品中文字幕乱码 | 乌克兰少妇xxxx做受 | 国产偷抇久久精品a片69 | 偷窥日本少妇撒尿chinese | 国产麻豆精品一区二区三区v视界 | 亚洲a无码综合a国产av中文 | 欧美日韩在线亚洲综合国产人 | 欧美老妇与禽交 | 中文字幕av无码一区二区三区电影 | 久久久亚洲欧洲日产国码αv | 天堂在线观看www | 全黄性性激高免费视频 | 丰满人妻精品国产99aⅴ | 色综合视频一区二区三区 | 激情亚洲一区国产精品 | 国产婷婷色一区二区三区在线 | 性欧美牲交xxxxx视频 | 国产无遮挡又黄又爽免费视频 | 97夜夜澡人人双人人人喊 | 国产精品久久久久久无码 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产绳艺sm调教室论坛 | 久久精品国产精品国产精品污 | 欧美日本免费一区二区三区 | 妺妺窝人体色www在线小说 | 中文字幕人成乱码熟女app | 亚洲啪av永久无码精品放毛片 | 激情亚洲一区国产精品 | 狠狠综合久久久久综合网 | 老熟妇仑乱视频一区二区 | 人人澡人人妻人人爽人人蜜桃 | 久久国产自偷自偷免费一区调 | 一本久久a久久精品亚洲 | 乱中年女人伦av三区 | 女人被男人爽到呻吟的视频 | 亚洲人成无码网www | 中文字幕 亚洲精品 第1页 | 免费无码肉片在线观看 | 四虎国产精品一区二区 | 99久久精品无码一区二区毛片 | 99久久人妻精品免费二区 | 97久久超碰中文字幕 | 国产精品久久久久久无码 | 国产精品香蕉在线观看 | 中国女人内谢69xxxx | 国产精品久久久久久久影院 | 国产成人综合美国十次 | 国产成人精品视频ⅴa片软件竹菊 | 欧美乱妇无乱码大黄a片 | 久久精品国产日本波多野结衣 | 久久久久国色av免费观看性色 | 日韩欧美群交p片內射中文 | 久久综合九色综合欧美狠狠 | 性史性农村dvd毛片 | 亚洲精品久久久久avwww潮水 | 岛国片人妻三上悠亚 | 2019午夜福利不卡片在线 | 亚洲中文字幕无码中文字在线 | 无人区乱码一区二区三区 | 97久久精品无码一区二区 | 国模大胆一区二区三区 | 男女性色大片免费网站 | 中文字幕精品av一区二区五区 | 在线成人www免费观看视频 | 无码国产激情在线观看 | 免费人成在线视频无码 | 国产亚洲精品久久久久久大师 | 久久精品99久久香蕉国产色戒 | 国产精品无码mv在线观看 | 99精品视频在线观看免费 | 夫妻免费无码v看片 | 人妻体内射精一区二区三四 | 学生妹亚洲一区二区 | 丰满诱人的人妻3 | 成人免费视频视频在线观看 免费 | 亚洲日韩一区二区三区 | 无套内谢的新婚少妇国语播放 | 中文字幕乱码人妻二区三区 | 精品国产av色一区二区深夜久久 | 国产偷抇久久精品a片69 | 久久综合九色综合欧美狠狠 | aa片在线观看视频在线播放 | 午夜精品一区二区三区的区别 | 亚洲国产高清在线观看视频 | 久久99热只有频精品8 | 国产香蕉尹人视频在线 | 久久99精品久久久久久 | 麻豆成人精品国产免费 | 麻豆精产国品 | 性欧美牲交在线视频 | 老子影院午夜伦不卡 | 精品国产一区二区三区av 性色 | 久久久久久av无码免费看大片 | 久久综合给合久久狠狠狠97色 | 亚洲伊人久久精品影院 | 日韩成人一区二区三区在线观看 | 熟妇女人妻丰满少妇中文字幕 | 激情内射日本一区二区三区 | 黑人粗大猛烈进出高潮视频 | 日韩成人一区二区三区在线观看 | 亚洲男女内射在线播放 | 欧美人与善在线com | av无码不卡在线观看免费 | 国产又爽又黄又刺激的视频 | 狠狠色噜噜狠狠狠7777奇米 | 亚洲aⅴ无码成人网站国产app | 性欧美大战久久久久久久 | 99久久婷婷国产综合精品青草免费 | 一区二区三区乱码在线 | 欧洲 | 久久精品国产亚洲精品 | 兔费看少妇性l交大片免费 | 99久久精品午夜一区二区 | 成年女人永久免费看片 | 成熟人妻av无码专区 | 色综合天天综合狠狠爱 | 男人的天堂av网站 | 少妇性l交大片欧洲热妇乱xxx | 小鲜肉自慰网站xnxx | 欧洲极品少妇 | 99国产精品白浆在线观看免费 | 国产真实伦对白全集 | 牲欲强的熟妇农村老妇女视频 | 国产偷自视频区视频 | 无码人妻丰满熟妇区五十路百度 | 男女作爱免费网站 | 亚洲成a人片在线观看日本 | 国产精品福利视频导航 | 日本又色又爽又黄的a片18禁 | 中文字幕中文有码在线 | 中文字幕 亚洲精品 第1页 | 国产精品多人p群无码 | 少妇无码av无码专区在线观看 | 天天摸天天透天天添 | 久久天天躁狠狠躁夜夜免费观看 | 国产精品久久久久久亚洲毛片 | 爱做久久久久久 | 又粗又大又硬毛片免费看 | 又大又硬又爽免费视频 | yw尤物av无码国产在线观看 | 强开小婷嫩苞又嫩又紧视频 | 久久综合给久久狠狠97色 | 乱人伦中文视频在线观看 | 理论片87福利理论电影 | 久久久精品人妻久久影视 | 精品人妻人人做人人爽夜夜爽 | 欧美日韩人成综合在线播放 | 免费无码的av片在线观看 | 九一九色国产 | 中国女人内谢69xxxxxa片 | 亚洲欧美日韩成人高清在线一区 | 国产偷国产偷精品高清尤物 | 国产熟女一区二区三区四区五区 | 中文无码成人免费视频在线观看 | 久久久精品国产sm最大网站 | 99久久人妻精品免费一区 | 中文字幕 人妻熟女 | 亚洲综合精品香蕉久久网 | 国产莉萝无码av在线播放 | 精品 日韩 国产 欧美 视频 | 国产深夜福利视频在线 | 免费视频欧美无人区码 | 国产97在线 | 亚洲 | 久久 国产 尿 小便 嘘嘘 | 久久97精品久久久久久久不卡 | 国产肉丝袜在线观看 | 国産精品久久久久久久 | 狠狠躁日日躁夜夜躁2020 | 丰满少妇人妻久久久久久 | 精品无码一区二区三区的天堂 | 图片区 小说区 区 亚洲五月 | 久久久久久久久蜜桃 | 精品aⅴ一区二区三区 | 亚洲国产精品一区二区美利坚 | 人人澡人人妻人人爽人人蜜桃 | 成人无码精品一区二区三区 | 亚洲国产欧美日韩精品一区二区三区 | 中文字幕无码乱人伦 | 色综合久久久久综合一本到桃花网 | 亚洲欧美日韩成人高清在线一区 | 人人妻人人澡人人爽人人精品 | 亚洲综合在线一区二区三区 | 国内精品九九久久久精品 | 中文字幕无码热在线视频 | 蜜桃视频韩日免费播放 | 日韩亚洲欧美中文高清在线 | 亚洲熟妇色xxxxx欧美老妇 | 亚洲中文字幕成人无码 | 欧美国产亚洲日韩在线二区 | 欧美色就是色 | a在线观看免费网站大全 | 人人妻人人澡人人爽人人精品 | 亚洲第一无码av无码专区 | 呦交小u女精品视频 | 亚洲aⅴ无码成人网站国产app | 国产美女极度色诱视频www | 乱人伦中文视频在线观看 | 人人超人人超碰超国产 | 中文毛片无遮挡高清免费 | 六月丁香婷婷色狠狠久久 | 久久精品国产大片免费观看 | 日本肉体xxxx裸交 | 伦伦影院午夜理论片 | 欧美国产日产一区二区 | 亚洲中文无码av永久不收费 | 欧美日本免费一区二区三区 | 国产亚洲精品久久久久久 | 亚洲精品久久久久久一区二区 | 少妇一晚三次一区二区三区 | 九九久久精品国产免费看小说 | 一本大道伊人av久久综合 | 无码人妻精品一区二区三区不卡 | 男女作爱免费网站 | 国产午夜无码精品免费看 | 久久综合给合久久狠狠狠97色 | 久久精品国产一区二区三区 | 白嫩日本少妇做爰 | 欧美性猛交内射兽交老熟妇 | 无码人妻丰满熟妇区五十路百度 | 国产精品99久久精品爆乳 | 99久久精品日本一区二区免费 | 精品国产福利一区二区 | 国产人成高清在线视频99最全资源 | 国产亚洲日韩欧美另类第八页 | 久久精品国产精品国产精品污 | 亚洲国产av美女网站 | 最新国产麻豆aⅴ精品无码 | 国产9 9在线 | 中文 | 无码免费一区二区三区 | 久久午夜夜伦鲁鲁片无码免费 | 人人爽人人澡人人人妻 | 免费观看又污又黄的网站 | 亚洲人成影院在线无码按摩店 | 精品国产aⅴ无码一区二区 | √8天堂资源地址中文在线 | 六月丁香婷婷色狠狠久久 | 成人动漫在线观看 | 国产成人无码午夜视频在线观看 | 377p欧洲日本亚洲大胆 | 日韩无套无码精品 | 狠狠色欧美亚洲狠狠色www | 亚洲日本va午夜在线电影 | 国产精品无码mv在线观看 | 377p欧洲日本亚洲大胆 | 亚洲小说图区综合在线 | 久久亚洲中文字幕无码 | 欧洲熟妇色 欧美 | 亚洲午夜无码久久 | 国产性生大片免费观看性 | 人妻天天爽夜夜爽一区二区 | 国产精品无码一区二区三区不卡 | 国产精品多人p群无码 | 欧美高清在线精品一区 | av香港经典三级级 在线 | 亚洲人成影院在线观看 | 无人区乱码一区二区三区 | 亚洲一区av无码专区在线观看 | 天天做天天爱天天爽综合网 | 国产成人无码av一区二区 | 特黄特色大片免费播放器图片 | 激情内射日本一区二区三区 | 欧美黑人性暴力猛交喷水 | 国产av人人夜夜澡人人爽麻豆 | 国产午夜手机精彩视频 | 国产成人一区二区三区在线观看 | 国语精品一区二区三区 | 日本肉体xxxx裸交 | 国产性生大片免费观看性 | 丰满诱人的人妻3 | 日本一卡二卡不卡视频查询 | 欧美日韩亚洲国产精品 | 一个人免费观看的www视频 | 久久久国产精品无码免费专区 | 国内少妇偷人精品视频 | 国产精品久久精品三级 | 少妇激情av一区二区 | 国产成人精品久久亚洲高清不卡 | 国产精品va在线观看无码 | 欧美人妻一区二区三区 | 精品久久久久久亚洲精品 | 亚洲人成人无码网www国产 | 人妻少妇被猛烈进入中文字幕 | 国产成人av免费观看 | 日韩精品乱码av一区二区 | 国产特级毛片aaaaaa高潮流水 | 国产精品高潮呻吟av久久4虎 | 麻花豆传媒剧国产免费mv在线 | 亚洲区小说区激情区图片区 | 久热国产vs视频在线观看 | 国产艳妇av在线观看果冻传媒 | 亚洲gv猛男gv无码男同 | 久久久久久久久888 | 国产办公室秘书无码精品99 | 精品久久久中文字幕人妻 | 97资源共享在线视频 | 波多野结衣高清一区二区三区 | 国产欧美亚洲精品a | 熟妇人妻无乱码中文字幕 | 亚洲国产精品一区二区第一页 | 亚洲欧美综合区丁香五月小说 | 久久久久久九九精品久 | 久久综合久久自在自线精品自 | 国产精品国产自线拍免费软件 | 国产精品成人av在线观看 | 日本肉体xxxx裸交 | 无码人妻黑人中文字幕 | 亚洲国产精品无码久久久久高潮 | 131美女爱做视频 | 欧美丰满熟妇xxxx性ppx人交 | 性色av无码免费一区二区三区 | 18黄暴禁片在线观看 | 高清无码午夜福利视频 | 亚洲精品国产第一综合99久久 | 日韩人妻无码一区二区三区久久99 | 中文精品久久久久人妻不卡 | 成人三级无码视频在线观看 | 东京热无码av男人的天堂 | 精品水蜜桃久久久久久久 | 久久97精品久久久久久久不卡 | 99riav国产精品视频 | 精品熟女少妇av免费观看 | 亚洲人成影院在线无码按摩店 | 2020久久香蕉国产线看观看 | 亚洲精品美女久久久久久久 | 日本护士xxxxhd少妇 | 人人妻人人澡人人爽人人精品浪潮 | 无套内射视频囯产 | 日日麻批免费40分钟无码 | 日韩欧美中文字幕公布 | 亚洲成在人网站无码天堂 | 亚洲第一无码av无码专区 | 国产人妖乱国产精品人妖 | 久久人人爽人人爽人人片ⅴ | 51国偷自产一区二区三区 | 国产电影无码午夜在线播放 | 国产精品99爱免费视频 | 中文字幕无码日韩欧毛 | 少妇人妻偷人精品无码视频 | 亚洲综合在线一区二区三区 | 免费观看黄网站 | 国产一区二区三区四区五区加勒比 | 无码人中文字幕 | 国产精品久久久av久久久 | 日韩欧美中文字幕在线三区 | 久9re热视频这里只有精品 | 精品国产乱码久久久久乱码 | 国产艳妇av在线观看果冻传媒 | 中文字幕中文有码在线 | 亚洲无人区午夜福利码高清完整版 | 成人无码视频在线观看网站 | 国产又爽又猛又粗的视频a片 | 国产肉丝袜在线观看 | 国产精品成人av在线观看 | 人妻aⅴ无码一区二区三区 | 精品一区二区三区无码免费视频 | 久久久久久久人妻无码中文字幕爆 | 蜜臀aⅴ国产精品久久久国产老师 | 四虎永久在线精品免费网址 | 中文字幕亚洲情99在线 | 人人澡人人透人人爽 | 免费观看的无遮挡av | 免费网站看v片在线18禁无码 | av香港经典三级级 在线 | 99视频精品全部免费免费观看 | 日本乱偷人妻中文字幕 | 久久国产精品萌白酱免费 | 无遮挡啪啪摇乳动态图 | 黑森林福利视频导航 | 国产成人一区二区三区别 | 成人欧美一区二区三区 | 97夜夜澡人人双人人人喊 | 国产精品美女久久久久av爽李琼 | 又大又黄又粗又爽的免费视频 | 久久国产精品精品国产色婷婷 | 午夜性刺激在线视频免费 | 国产av剧情md精品麻豆 | 亚洲午夜久久久影院 | 免费男性肉肉影院 | 国产精品亚洲一区二区三区喷水 | 青草青草久热国产精品 | 亚洲自偷自偷在线制服 | 婷婷丁香五月天综合东京热 | 一二三四在线观看免费视频 | 欧洲精品码一区二区三区免费看 | 亚洲码国产精品高潮在线 | 双乳奶水饱满少妇呻吟 | 麻豆精产国品 | 国产香蕉尹人视频在线 | 激情人妻另类人妻伦 | 激情五月综合色婷婷一区二区 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 人妻体内射精一区二区三四 | 又大又硬又黄的免费视频 | 丰满肥臀大屁股熟妇激情视频 | 中文字幕 人妻熟女 | 日韩精品无码一本二本三本色 | 亚洲人亚洲人成电影网站色 | 乌克兰少妇性做爰 | 亚洲午夜福利在线观看 | 亚洲精品一区二区三区在线观看 | 无码精品人妻一区二区三区av | 未满小14洗澡无码视频网站 | 国产莉萝无码av在线播放 | 成人精品视频一区二区 | 亚洲一区二区三区四区 | 97无码免费人妻超级碰碰夜夜 | 国产精品办公室沙发 | 7777奇米四色成人眼影 | 日本一本二本三区免费 | 大肉大捧一进一出好爽视频 | 久久国产精品二国产精品 | 少妇无码av无码专区在线观看 | 亚洲狠狠色丁香婷婷综合 | 亚洲人成人无码网www国产 | 国产人成高清在线视频99最全资源 | 男女猛烈xx00免费视频试看 | 性欧美牲交xxxxx视频 | 免费人成在线观看网站 | 东京无码熟妇人妻av在线网址 | 内射老妇bbwx0c0ck | 中文字幕无码人妻少妇免费 | 波多野结衣av在线观看 | 久久国语露脸国产精品电影 | 欧美日韩综合一区二区三区 | 国产午夜精品一区二区三区嫩草 | 国产艳妇av在线观看果冻传媒 | 国产精品亚洲专区无码不卡 | 性欧美videos高清精品 | 人妻中文无码久热丝袜 | 亚洲自偷自拍另类第1页 | 精品夜夜澡人妻无码av蜜桃 | 久久99精品久久久久久动态图 | 日韩精品a片一区二区三区妖精 | 国产香蕉尹人视频在线 | 久久国产自偷自偷免费一区调 | 亚洲色在线无码国产精品不卡 | 中文精品无码中文字幕无码专区 | 免费无码的av片在线观看 | 俺去俺来也在线www色官网 | 丰满人妻精品国产99aⅴ | 99视频精品全部免费免费观看 | 国产无遮挡吃胸膜奶免费看 | 亚洲色偷偷男人的天堂 | 成人免费无码大片a毛片 | 色欲久久久天天天综合网精品 | 久久久www成人免费毛片 | 国产成人午夜福利在线播放 | 红桃av一区二区三区在线无码av | 亚洲一区av无码专区在线观看 | 东京一本一道一二三区 | 亚洲熟女一区二区三区 | 国产精品免费大片 | 国产精品高潮呻吟av久久 | 欧美国产日韩久久mv | 久久99精品国产.久久久久 | 老太婆性杂交欧美肥老太 | 免费无码一区二区三区蜜桃大 | 亚洲精品中文字幕久久久久 | 国产性生大片免费观看性 | 成人无码影片精品久久久 | 人人妻人人澡人人爽人人精品 | 久久综合九色综合欧美狠狠 | 理论片87福利理论电影 | 国产激情精品一区二区三区 | 天海翼激烈高潮到腰振不止 | 国产亚洲精品久久久久久 | 狠狠色噜噜狠狠狠狠7777米奇 | 东京热无码av男人的天堂 | 久久久久久a亚洲欧洲av冫 | 久久综合色之久久综合 | av无码不卡在线观看免费 | 国产精品无码永久免费888 | 人妻夜夜爽天天爽三区 | 小泽玛莉亚一区二区视频在线 | 色综合久久久无码中文字幕 | 精品久久久久久亚洲精品 | 国产色xx群视频射精 | 欧美肥老太牲交大战 | 亚洲一区二区三区在线观看网站 | 少妇人妻大乳在线视频 | 丰满少妇人妻久久久久久 | 国产乱人偷精品人妻a片 | 丰满少妇弄高潮了www | 无码人妻av免费一区二区三区 | 性生交大片免费看女人按摩摩 | 熟女少妇人妻中文字幕 | 女高中生第一次破苞av | 黑人大群体交免费视频 | 人人爽人人爽人人片av亚洲 | www一区二区www免费 | 亚洲国产日韩a在线播放 | 无码人妻少妇伦在线电影 | 成年美女黄网站色大免费视频 | 日本熟妇乱子伦xxxx | 无码乱肉视频免费大全合集 | 高潮毛片无遮挡高清免费 | 牛和人交xxxx欧美 | 无码人妻精品一区二区三区下载 | 中文字幕无码热在线视频 | 扒开双腿吃奶呻吟做受视频 | 亚洲爆乳无码专区 | 欧美激情一区二区三区成人 | 亚洲一区二区观看播放 | 扒开双腿疯狂进出爽爽爽视频 | 欧美日韩综合一区二区三区 | 无码毛片视频一区二区本码 | 夜先锋av资源网站 | 成人免费无码大片a毛片 | 成在人线av无码免观看麻豆 | 亚洲成a人一区二区三区 | 欧美日本日韩 | 久久久中文久久久无码 | 久激情内射婷内射蜜桃人妖 | 亚洲国产av精品一区二区蜜芽 | 色情久久久av熟女人妻网站 | 亚洲一区二区观看播放 | 亚洲а∨天堂久久精品2021 | 精品国产青草久久久久福利 | 精品成在人线av无码免费看 | 亚洲综合无码一区二区三区 | 亚洲国产精品无码一区二区三区 | 国产亚洲精品久久久久久 | 国产欧美精品一区二区三区 | 欧美老妇与禽交 | 欧美精品免费观看二区 | 日本一区二区更新不卡 | 国产精品久免费的黄网站 | a片在线免费观看 | 国产亚洲欧美在线专区 | 老子影院午夜伦不卡 | 亚欧洲精品在线视频免费观看 | 欧美熟妇另类久久久久久多毛 | 国产精品二区一区二区aⅴ污介绍 | 99精品视频在线观看免费 | 最近的中文字幕在线看视频 | 国产激情无码一区二区app | 天天综合网天天综合色 | 99久久精品午夜一区二区 | 日韩视频 中文字幕 视频一区 | 亚洲 另类 在线 欧美 制服 | 国产成人无码av片在线观看不卡 | 国产一区二区不卡老阿姨 | 国产无套内射久久久国产 | 国产麻豆精品精东影业av网站 | 天堂无码人妻精品一区二区三区 | 国产97在线 | 亚洲 | 奇米影视888欧美在线观看 | 亚洲日韩精品欧美一区二区 | 亚洲成色在线综合网站 | www成人国产高清内射 | 无码成人精品区在线观看 | 国产明星裸体无码xxxx视频 | 一本大道伊人av久久综合 | 无码乱肉视频免费大全合集 | 亚洲精品无码人妻无码 | 色综合久久网 | 色 综合 欧美 亚洲 国产 | 老熟女重囗味hdxx69 | 国产精品国产自线拍免费软件 | 午夜男女很黄的视频 | 爽爽影院免费观看 | 奇米影视888欧美在线观看 | 无码人妻丰满熟妇区五十路百度 | 一二三四社区在线中文视频 | 亚洲自偷自偷在线制服 | 一个人看的视频www在线 | 色婷婷综合中文久久一本 | 国产在线精品一区二区三区直播 | 18禁黄网站男男禁片免费观看 | 在教室伦流澡到高潮hnp视频 | 色综合久久88色综合天天 | 中文字幕乱码人妻二区三区 | 国产在线aaa片一区二区99 | 亚洲国产成人a精品不卡在线 | 欧美精品一区二区精品久久 | a片免费视频在线观看 | 亚洲中文字幕无码一久久区 | 西西人体www44rt大胆高清 | 夜夜影院未满十八勿进 | 亚洲呦女专区 | 日本xxxx色视频在线观看免费 | 丝袜 中出 制服 人妻 美腿 | 亚洲毛片av日韩av无码 | 成人aaa片一区国产精品 | 欧美日韩在线亚洲综合国产人 | 一本久道高清无码视频 | 欧美一区二区三区 | 最新国产乱人伦偷精品免费网站 | 午夜成人1000部免费视频 | 国产精品香蕉在线观看 | 国产在线精品一区二区高清不卡 | 永久免费观看美女裸体的网站 | 亚洲人成人无码网www国产 | 国产午夜亚洲精品不卡下载 | 国产亚洲精品久久久久久久 | 97色伦图片97综合影院 | 国产97人人超碰caoprom | 亚洲va欧美va天堂v国产综合 | 久久精品国产一区二区三区 | 水蜜桃av无码 | 精品厕所偷拍各类美女tp嘘嘘 | 久青草影院在线观看国产 | 骚片av蜜桃精品一区 | 麻豆人妻少妇精品无码专区 | 黑人玩弄人妻中文在线 | 色婷婷av一区二区三区之红樱桃 | 国产97色在线 | 免 | 少妇人妻偷人精品无码视频 | 中文字幕中文有码在线 | 久久99精品国产麻豆 | 久久久精品456亚洲影院 | 国产精品二区一区二区aⅴ污介绍 | 无码精品人妻一区二区三区av | 精品国产福利一区二区 | 熟女少妇在线视频播放 | 亚洲日本va中文字幕 | 久久精品国产一区二区三区肥胖 | 国产超级va在线观看视频 | 久久久久成人精品免费播放动漫 | 人妻无码久久精品人妻 | 国产亚洲精品久久久久久大师 | 熟妇女人妻丰满少妇中文字幕 | 台湾无码一区二区 | 久久久久亚洲精品男人的天堂 | 国产熟女一区二区三区四区五区 | 我要看www免费看插插视频 | 国产激情综合五月久久 | 午夜精品一区二区三区的区别 | 久久午夜夜伦鲁鲁片无码免费 | 又粗又大又硬又长又爽 | 免费播放一区二区三区 | 精品久久久久香蕉网 | 亚洲国产高清在线观看视频 | 77777熟女视频在线观看 а天堂中文在线官网 | 久久综合给合久久狠狠狠97色 | 国产精品va在线观看无码 | 国产精品毛片一区二区 | 丝袜美腿亚洲一区二区 | 四虎影视成人永久免费观看视频 | 人妻体内射精一区二区三四 | 国产精品亚洲专区无码不卡 | 国产明星裸体无码xxxx视频 | 女人高潮内射99精品 | 一本色道久久综合狠狠躁 | 麻豆国产人妻欲求不满 | 蜜桃臀无码内射一区二区三区 | 国产艳妇av在线观看果冻传媒 | 综合人妻久久一区二区精品 | 国产精品久久久久影院嫩草 | 高清不卡一区二区三区 | 欧美老熟妇乱xxxxx | 高清国产亚洲精品自在久久 | 日韩欧美中文字幕公布 | 日韩亚洲欧美中文高清在线 | 夫妻免费无码v看片 | 玩弄中年熟妇正在播放 | 欧美黑人性暴力猛交喷水 | 欧美猛少妇色xxxxx | 亚洲娇小与黑人巨大交 | 国产无遮挡又黄又爽免费视频 | 老子影院午夜伦不卡 | 久久视频在线观看精品 | 欧美丰满老熟妇xxxxx性 | 亚洲区欧美区综合区自拍区 | 欧美阿v高清资源不卡在线播放 | 97无码免费人妻超级碰碰夜夜 | 日日碰狠狠丁香久燥 | 无码人妻精品一区二区三区不卡 | 又紧又大又爽精品一区二区 | 欧美日韩综合一区二区三区 | 丰满少妇人妻久久久久久 | 亚洲中文字幕乱码av波多ji | 日韩欧美中文字幕在线三区 | 午夜精品一区二区三区的区别 | 一区二区三区乱码在线 | 欧洲 | 蜜桃无码一区二区三区 | 任你躁国产自任一区二区三区 | 久久精品一区二区三区四区 | 麻豆精品国产精华精华液好用吗 | 玩弄人妻少妇500系列视频 | 午夜精品久久久久久久 | 日本一区二区更新不卡 | 成人女人看片免费视频放人 | 国产激情无码一区二区app | 人妻无码αv中文字幕久久琪琪布 | 亚洲男女内射在线播放 | 日韩少妇内射免费播放 | 十八禁视频网站在线观看 | 精品厕所偷拍各类美女tp嘘嘘 | 国产亚洲欧美日韩亚洲中文色 | 男女作爱免费网站 | 中文字幕无码乱人伦 | 亚洲天堂2017无码 | 亚洲国产成人a精品不卡在线 | 亚洲区小说区激情区图片区 | 一本久久a久久精品亚洲 | 亚洲一区二区三区含羞草 | 久久精品人人做人人综合试看 | 少女韩国电视剧在线观看完整 | 999久久久国产精品消防器材 | 亚洲欧美中文字幕5发布 | 无码国产激情在线观看 | 亚洲人亚洲人成电影网站色 | 成在人线av无码免观看麻豆 | 性史性农村dvd毛片 | 成人免费视频在线观看 | 国产亚洲tv在线观看 | 狂野欧美激情性xxxx | 色婷婷综合激情综在线播放 | 女人被爽到呻吟gif动态图视看 | 欧美自拍另类欧美综合图片区 | 午夜免费福利小电影 | 亚洲国产精品久久人人爱 | 亚洲精品久久久久久久久久久 | 亚洲の无码国产の无码影院 | 夜精品a片一区二区三区无码白浆 | 欧美怡红院免费全部视频 | 伊在人天堂亚洲香蕉精品区 | 国产成人无码区免费内射一片色欲 | 国产婷婷色一区二区三区在线 | 国产高潮视频在线观看 | 在线天堂新版最新版在线8 | 中文字幕无码日韩专区 | 欧美乱妇无乱码大黄a片 | 久久精品成人欧美大片 | 国产精品第一区揄拍无码 | 国产真实乱对白精彩久久 | 欧美日韩人成综合在线播放 | 乌克兰少妇性做爰 | 久久zyz资源站无码中文动漫 | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产精品多人p群无码 | 婷婷五月综合激情中文字幕 | 双乳奶水饱满少妇呻吟 | 国产在线aaa片一区二区99 | 永久免费精品精品永久-夜色 | 久久久久久国产精品无码下载 | 无码一区二区三区在线观看 | 亚洲欧美综合区丁香五月小说 | 精品久久久久久人妻无码中文字幕 | 国产亚洲日韩欧美另类第八页 | 久久久久久国产精品无码下载 | 久久99精品久久久久久动态图 | 男人的天堂av网站 | 中国女人内谢69xxxx | 中文字幕乱码人妻无码久久 | 红桃av一区二区三区在线无码av | 少女韩国电视剧在线观看完整 | 免费无码一区二区三区蜜桃大 | 日韩av无码中文无码电影 | 天天摸天天碰天天添 | 青青草原综合久久大伊人精品 | 久久国产精品偷任你爽任你 | 国产免费久久精品国产传媒 | 久久视频在线观看精品 | 久久这里只有精品视频9 | 永久免费观看国产裸体美女 | 国内揄拍国内精品少妇国语 | 久久综合给合久久狠狠狠97色 | 久久综合九色综合97网 | а√资源新版在线天堂 | 夜先锋av资源网站 | 久久国产精品精品国产色婷婷 | 色五月丁香五月综合五月 | 少妇愉情理伦片bd | 综合网日日天干夜夜久久 | 亚洲性无码av中文字幕 | 亚洲成在人网站无码天堂 | 国内精品久久毛片一区二区 | 国产亚洲精品精品国产亚洲综合 | 亚洲成a人片在线观看无码 | 亚洲一区二区三区香蕉 | 日韩精品成人一区二区三区 | 久久人人爽人人爽人人片ⅴ | 伊人久久大香线蕉午夜 | 亚洲精品鲁一鲁一区二区三区 | 99精品国产综合久久久久五月天 | 国产精品va在线播放 | 少妇激情av一区二区 | 一个人看的视频www在线 | 99国产欧美久久久精品 | 亚洲国产欧美在线成人 | 亚洲国产精华液网站w | 亚洲 a v无 码免 费 成 人 a v | 亚洲gv猛男gv无码男同 | 久久精品女人的天堂av | 男女作爱免费网站 | 亚洲国产精品毛片av不卡在线 | 国产无遮挡吃胸膜奶免费看 | 欧美 日韩 人妻 高清 中文 | 欧美 丝袜 自拍 制服 另类 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 天天躁日日躁狠狠躁免费麻豆 | 精品人人妻人人澡人人爽人人 | 日日天日日夜日日摸 | 欧美熟妇另类久久久久久多毛 | 亚洲色欲色欲天天天www | 午夜男女很黄的视频 | 国产在线无码精品电影网 | 亚洲一区av无码专区在线观看 | 久久久精品国产sm最大网站 | 双乳奶水饱满少妇呻吟 | 欧美国产亚洲日韩在线二区 | 88国产精品欧美一区二区三区 | 欧美精品无码一区二区三区 | 性欧美videos高清精品 | 国产成人无码av片在线观看不卡 | 亚洲爆乳精品无码一区二区三区 | 男女下面进入的视频免费午夜 | 亚洲精品久久久久久一区二区 | 亚洲国产精品成人久久蜜臀 | 日日夜夜撸啊撸 | 久久99精品久久久久婷婷 | 国产精品久久国产三级国 | 国产精品视频免费播放 | 亚洲区欧美区综合区自拍区 | 欧美人与物videos另类 | 久久精品国产一区二区三区 | 老熟女重囗味hdxx69 | 欧美亚洲国产一区二区三区 | 99国产欧美久久久精品 | 超碰97人人射妻 | 狂野欧美激情性xxxx | 久久国产精品偷任你爽任你 | 欧美freesex黑人又粗又大 | 男人的天堂2018无码 | 久久综合色之久久综合 | 亚洲区小说区激情区图片区 | 99久久99久久免费精品蜜桃 | 熟妇人妻无码xxx视频 | 免费观看的无遮挡av | 国产av无码专区亚洲awww | 日本一卡二卡不卡视频查询 | 熟妇激情内射com | 日韩无码专区 | 人妻少妇被猛烈进入中文字幕 | 精品夜夜澡人妻无码av蜜桃 | 性史性农村dvd毛片 | 国产欧美亚洲精品a | 午夜无码人妻av大片色欲 | 亚洲日韩一区二区三区 | 国产精品久久久久久亚洲毛片 | 人妻人人添人妻人人爱 | 国产成人人人97超碰超爽8 | 伊人久久大香线蕉亚洲 | 日本又色又爽又黄的a片18禁 | 色一情一乱一伦一区二区三欧美 | 久久亚洲a片com人成 | 女人高潮内射99精品 | 国产精品二区一区二区aⅴ污介绍 | 国产精品亚洲一区二区三区喷水 | 精品午夜福利在线观看 | 少妇人妻偷人精品无码视频 | 亚洲一区二区三区在线观看网站 | 日本一本二本三区免费 | 亚洲精品欧美二区三区中文字幕 | 俺去俺来也www色官网 | 搡女人真爽免费视频大全 | 亚洲国产精华液网站w | 亚洲精品一区二区三区在线观看 | 激情综合激情五月俺也去 | 99久久精品无码一区二区毛片 | 99麻豆久久久国产精品免费 | www一区二区www免费 | 亚洲啪av永久无码精品放毛片 | 日韩少妇内射免费播放 | 亚洲人成影院在线观看 | 少妇性荡欲午夜性开放视频剧场 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产在线精品一区二区三区直播 | 欧美三级不卡在线观看 | 无码毛片视频一区二区本码 | 日韩欧美中文字幕在线三区 | 无套内谢的新婚少妇国语播放 | 中文字幕无线码免费人妻 | 国内综合精品午夜久久资源 | 欧美老熟妇乱xxxxx | 激情爆乳一区二区三区 | 亚洲の无码国产の无码步美 | 久久久精品成人免费观看 | 玩弄少妇高潮ⅹxxxyw | 国产av剧情md精品麻豆 | 亚洲国产精品久久久天堂 | 18精品久久久无码午夜福利 | 亚洲日韩av一区二区三区四区 | 国内精品久久毛片一区二区 | 人妻中文无码久热丝袜 | 亚洲高清偷拍一区二区三区 | 国产精品资源一区二区 | 又大又硬又爽免费视频 | 最近中文2019字幕第二页 | 东京热无码av男人的天堂 | 精品无码一区二区三区的天堂 | 亚洲熟熟妇xxxx | 亚洲日韩精品欧美一区二区 | 一二三四在线观看免费视频 | 四虎4hu永久免费 | 免费人成在线视频无码 | 中文字幕乱码人妻二区三区 | 久久亚洲日韩精品一区二区三区 | 成人影院yy111111在线观看 | 18禁黄网站男男禁片免费观看 | 欧美色就是色 | 国产精品亚洲а∨无码播放麻豆 | 久久精品国产一区二区三区肥胖 | 伊人久久大香线焦av综合影院 | 色综合视频一区二区三区 | 日本熟妇人妻xxxxx人hd | 日本又色又爽又黄的a片18禁 | 理论片87福利理论电影 | 99精品国产综合久久久久五月天 | 免费男性肉肉影院 | 性欧美牲交xxxxx视频 | 性做久久久久久久免费看 | 色综合久久久无码中文字幕 | 久激情内射婷内射蜜桃人妖 | 精品国产精品久久一区免费式 | 国产亚av手机在线观看 | 成人毛片一区二区 | 99精品视频在线观看免费 | 亚洲精品无码国产 | 亚洲大尺度无码无码专区 | 国产av剧情md精品麻豆 | 99国产精品白浆在线观看免费 | 国产精品高潮呻吟av久久4虎 | 欧美一区二区三区视频在线观看 | 国产亚洲欧美日韩亚洲中文色 | 天干天干啦夜天干天2017 | 亚洲精品一区二区三区在线 | 亚欧洲精品在线视频免费观看 | 欧美激情综合亚洲一二区 | 乌克兰少妇性做爰 | 女人被爽到呻吟gif动态图视看 | 伊人久久婷婷五月综合97色 | 国产麻豆精品一区二区三区v视界 | 婷婷综合久久中文字幕蜜桃三电影 | 色偷偷人人澡人人爽人人模 | 亚洲精品一区二区三区在线观看 | 日韩av无码中文无码电影 | 日韩少妇内射免费播放 | 99久久久无码国产精品免费 | 亚洲精品国产a久久久久久 | 欧美日韩久久久精品a片 | 99久久人妻精品免费二区 | 日本又色又爽又黄的a片18禁 | 精品国产青草久久久久福利 | 午夜福利试看120秒体验区 | 国产精品久久久久影院嫩草 | 激情爆乳一区二区三区 | 亚洲精品成a人在线观看 | 67194成是人免费无码 | 亚洲а∨天堂久久精品2021 | 性生交片免费无码看人 | 亚洲精品午夜无码电影网 | 少妇无套内谢久久久久 | 国产人妻精品一区二区三区不卡 | 国产另类ts人妖一区二区 | 日日干夜夜干 | 亚洲精品国产第一综合99久久 | 少妇无套内谢久久久久 | 桃花色综合影院 | 国产精品永久免费视频 | 国产亚洲精品久久久久久久 | 欧美亚洲国产一区二区三区 | 东北女人啪啪对白 | 亚洲综合精品香蕉久久网 | 在线а√天堂中文官网 | 国产内射爽爽大片视频社区在线 | 亚洲日韩精品欧美一区二区 | 东京热无码av男人的天堂 | 天堂亚洲2017在线观看 | 伊人久久大香线焦av综合影院 | 狂野欧美激情性xxxx | 无码人妻av免费一区二区三区 | 国产精品va在线观看无码 | 妺妺窝人体色www在线小说 | 97精品国产97久久久久久免费 | 最新国产麻豆aⅴ精品无码 | 99视频精品全部免费免费观看 | 人妻无码αv中文字幕久久琪琪布 | 无码纯肉视频在线观看 | 国产无遮挡吃胸膜奶免费看 | 51国偷自产一区二区三区 | 欧美国产日产一区二区 | 中文字幕 人妻熟女 | 亚洲爆乳精品无码一区二区三区 | 精品aⅴ一区二区三区 | 国产精品久久久av久久久 | 久久精品国产日本波多野结衣 | 97夜夜澡人人双人人人喊 | 少妇愉情理伦片bd | 久久久久免费看成人影片 | 亚洲成熟女人毛毛耸耸多 | 2020久久超碰国产精品最新 | 人人妻人人澡人人爽欧美精品 | 色综合久久久无码中文字幕 | 午夜成人1000部免费视频 | 精品无码av一区二区三区 | 国内精品人妻无码久久久影院 | 亲嘴扒胸摸屁股激烈网站 | 亚洲日韩一区二区 | 国产性生交xxxxx无码 | 超碰97人人射妻 | 亚洲精品综合一区二区三区在线 | 亚无码乱人伦一区二区 | 天堂亚洲免费视频 | 午夜福利试看120秒体验区 | 黑人巨大精品欧美一区二区 | av香港经典三级级 在线 | 亚洲综合无码久久精品综合 | 装睡被陌生人摸出水好爽 | 午夜肉伦伦影院 | 又湿又紧又大又爽a视频国产 | 无码av最新清无码专区吞精 | 中文字幕+乱码+中文字幕一区 | 国产成人精品无码播放 | 国産精品久久久久久久 | 色综合久久中文娱乐网 | 成人欧美一区二区三区黑人 | 欧洲精品码一区二区三区免费看 |