青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Prayer

在一般中尋求卓越
posts - 1256, comments - 190, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

Linux 文件系統(tǒng)剖析

Posted on 2009-07-28 13:45 Prayer 閱讀(216) 評(píng)論(0)  編輯 收藏 引用 所屬分類: LINUX/UNIX/AIX
在文件系統(tǒng)方面,Linux® 可以算得上操作系統(tǒng)中的 “瑞士軍刀”。Linux 支持許多種文件系統(tǒng),從日志型文件系統(tǒng)到集群文件系統(tǒng)和加密文件系統(tǒng)。對(duì)于使用標(biāo)準(zhǔn)的和比較奇特的文件系統(tǒng)以及開發(fā)文件系統(tǒng)來說,Linux 是極好的平臺(tái)。本文討論 Linux 內(nèi)核中的虛擬文件系統(tǒng)(VFS,有時(shí)候稱為虛擬文件系統(tǒng)交換器),然后介紹將文件系統(tǒng)連接在一起的主要結(jié)構(gòu)。

基本的文件系統(tǒng)體系結(jié)構(gòu)

Linux 文件系統(tǒng)體系結(jié)構(gòu)是一個(gè)對(duì)復(fù)雜系統(tǒng)進(jìn)行抽象化的有趣例子。通過使用一組通用的 API 函數(shù),Linux 可以在許多種存儲(chǔ)設(shè)備上支持許多種文件系統(tǒng)。例如,read 函數(shù)調(diào)用可以從指定的文件描述符讀取一定數(shù)量的字節(jié)。read 函數(shù)不了解文件系統(tǒng)的類型,比如 ext3 或 NFS。它也不了解文件系統(tǒng)所在的存儲(chǔ)媒體,比如 AT Attachment Packet Interface(ATAPI)磁盤、Serial-Attached SCSI(SAS)磁盤或 Serial Advanced Technology Attachment(SATA)磁盤。但是,當(dāng)通過調(diào)用 read 函數(shù)讀取一個(gè)文件時(shí),數(shù)據(jù)會(huì)正常返回。本文講解這個(gè)機(jī)制的實(shí)現(xiàn)方法并介紹 Linux 文件系統(tǒng)層的主要結(jié)構(gòu)。





回頁首


什么是文件系統(tǒng)?

首先回答最常見的問題,“什么是文件系統(tǒng)”。文件系統(tǒng)是對(duì)一個(gè)存儲(chǔ)設(shè)備上的數(shù)據(jù)和元數(shù)據(jù)進(jìn)行組織的機(jī)制。由于定義如此寬泛,支持它的代碼會(huì)很有意思。正如前面提到的,有許多種文件系統(tǒng)和媒體。由于存在這么多類型,可以預(yù)料到 Linux 文件系統(tǒng)接口實(shí)現(xiàn)為分層的體系結(jié)構(gòu),從而將用戶接口層、文件系統(tǒng)實(shí)現(xiàn)和操作存儲(chǔ)設(shè)備的驅(qū)動(dòng)程序分隔開。

文件系統(tǒng)作為協(xié)議
另一種看待文件系統(tǒng)的方式是把它看作一個(gè)協(xié)議。網(wǎng)絡(luò)協(xié)議(比如 IP)規(guī)定了互聯(lián)網(wǎng)上傳輸?shù)臄?shù)據(jù)流的意義,同樣,文件系統(tǒng)會(huì)給出特定存儲(chǔ)媒體上數(shù)據(jù)的意義。

掛裝

在 Linux 中將一個(gè)文件系統(tǒng)與一個(gè)存儲(chǔ)設(shè)備關(guān)聯(lián)起來的過程稱為掛裝(mount)。使用 mount 命令將一個(gè)文件系統(tǒng)附著到當(dāng)前文件系統(tǒng)層次結(jié)構(gòu)中(根)。在執(zhí)行掛裝時(shí),要提供文件系統(tǒng)類型、文件系統(tǒng)和一個(gè)掛裝點(diǎn)。

為了說明 Linux 文件系統(tǒng)層的功能(以及掛裝的方法),我們?cè)诋?dāng)前文件系統(tǒng)的一個(gè)文件中創(chuàng)建一個(gè)文件系統(tǒng)。實(shí)現(xiàn)的方法是,首先用 dd 命令創(chuàng)建一個(gè)指定大小的文件(使用 /dev/zero 作為源進(jìn)行文件復(fù)制)—— 換句話說,一個(gè)用零進(jìn)行初始化的文件,見清單 1。


清單 1. 創(chuàng)建一個(gè)經(jīng)過初始化的文件
            $ dd if=/dev/zero of=file.img bs=1k count=10000
            10000+0 records in
            10000+0 records out
            $
            

現(xiàn)在有了一個(gè) 10MB 的 file.img 文件。使用 losetup 命令將一個(gè)循環(huán)設(shè)備與這個(gè)文件關(guān)聯(lián)起來,讓它看起來像一個(gè)塊設(shè)備,而不是文件系統(tǒng)中的常規(guī)文件:

$ losetup /dev/loop0 file.img
            $
            

這個(gè)文件現(xiàn)在作為一個(gè)塊設(shè)備出現(xiàn)(由 /dev/loop0 表示)。然后用 mke2fs 在這個(gè)設(shè)備上創(chuàng)建一個(gè)文件系統(tǒng)。這個(gè)命令創(chuàng)建一個(gè)指定大小的新的 ext2 文件系統(tǒng),見清單 2。


清單 2. 用循環(huán)設(shè)備創(chuàng)建 ext2 文件系統(tǒng)
            $ mke2fs -c /dev/loop0 10000
            mke2fs 1.35 (28-Feb-2004)
            max_blocks 1024000, rsv_groups = 1250, rsv_gdb = 39
            Filesystem label=
            OS type: Linux
            Block size=1024 (log=0)
            Fragment size=1024 (log=0)
            2512 inodes, 10000 blocks
            500 blocks (5.00%) reserved for the super user
            ...
            $
            

使用 mount 命令將循環(huán)設(shè)備(/dev/loop0)所表示的 file.img 文件掛裝到掛裝點(diǎn) /mnt/point1。注意,文件系統(tǒng)類型指定為 ext2。掛裝之后,就可以將這個(gè)掛裝點(diǎn)當(dāng)作一個(gè)新的文件系統(tǒng),比如使用 ls 命令,見清單 3。


清單 3. 創(chuàng)建掛裝點(diǎn)并通過循環(huán)設(shè)備掛裝文件系統(tǒng)
            $ mkdir /mnt/point1
            $ mount -t ext2 /dev/loop0 /mnt/point1
            $ ls /mnt/point1
            lost+found
            $
            

如清單 4 所示,還可以繼續(xù)這個(gè)過程:在剛才掛裝的文件系統(tǒng)中創(chuàng)建一個(gè)新文件,將它與一個(gè)循環(huán)設(shè)備關(guān)聯(lián)起來,再在上面創(chuàng)建另一個(gè)文件系統(tǒng)。


清單 4. 在循環(huán)文件系統(tǒng)中創(chuàng)建一個(gè)新的循環(huán)文件系統(tǒng)
            $ dd if=/dev/zero of=/mnt/point1/file.img bs=1k count=1000
            1000+0 records in
            1000+0 records out
            $ losetup /dev/loop1 /mnt/point1/file.img
            $ mke2fs -c /dev/loop1 1000
            mke2fs 1.35 (28-Feb-2004)
            max_blocks 1024000, rsv_groups = 125, rsv_gdb = 3
            Filesystem label=
            ...
            $ mkdir /mnt/point2
            $ mount -t ext2 /dev/loop1 /mnt/point2
            $ ls /mnt/point2
            lost+found
            $ ls /mnt/point1
            file.img lost+found
            $
            

通過這個(gè)簡單的演示很容易體會(huì)到 Linux 文件系統(tǒng)(和循環(huán)設(shè)備)是多么強(qiáng)大。可以按照相同的方法在文件上用循環(huán)設(shè)備創(chuàng)建加密的文件系統(tǒng)。可以在需要時(shí)使用循環(huán)設(shè)備臨時(shí)掛裝文件,這有助于保護(hù)數(shù)據(jù)。





回頁首


文件系統(tǒng)體系結(jié)構(gòu)

既然已經(jīng)看到了文件系統(tǒng)的構(gòu)造方法,現(xiàn)在就看看 Linux 文件系統(tǒng)層的體系結(jié)構(gòu)。本文從兩個(gè)角度考察 Linux 文件系統(tǒng)。首先采用高層體系結(jié)構(gòu)的角度。然后進(jìn)行深層次討論,介紹實(shí)現(xiàn)文件系統(tǒng)層的主要結(jié)構(gòu)。





回頁首


高層體系結(jié)構(gòu)

盡管大多數(shù)文件系統(tǒng)代碼在內(nèi)核中(后面討論的用戶空間文件系統(tǒng)除外),但是圖 1 所示的體系結(jié)構(gòu)顯示了用戶空間和內(nèi)核中與文件系統(tǒng)相關(guān)的主要組件之間的關(guān)系。


圖 1. Linux 文件系統(tǒng)組件的體系結(jié)構(gòu)
圖 1. Linux 文件系統(tǒng)組件的體系結(jié)構(gòu)

用戶空間包含一些應(yīng)用程序(例如,文件系統(tǒng)的使用者)和 GNU C 庫(glibc),它們?yōu)槲募到y(tǒng)調(diào)用(打開、讀取、寫和關(guān)閉)提供用戶接口。系統(tǒng)調(diào)用接口的作用就像是交換器,它將系統(tǒng)調(diào)用從用戶空間發(fā)送到內(nèi)核空間中的適當(dāng)端點(diǎn)。

VFS 是底層文件系統(tǒng)的主要接口。這個(gè)組件導(dǎo)出一組接口,然后將它們抽象到各個(gè)文件系統(tǒng),各個(gè)文件系統(tǒng)的行為可能差異很大。有兩個(gè)針對(duì)文件系統(tǒng)對(duì)象的緩存(inode 和 dentry)。它們緩存最近使用過的文件系統(tǒng)對(duì)象。

每個(gè)文件系統(tǒng)實(shí)現(xiàn)(比如 ext2、JFS 等等)導(dǎo)出一組通用接口,供 VFS 使用。緩沖區(qū)緩存會(huì)緩存文件系統(tǒng)和相關(guān)塊設(shè)備之間的請(qǐng)求。例如,對(duì)底層設(shè)備驅(qū)動(dòng)程序的讀寫請(qǐng)求會(huì)通過緩沖區(qū)緩存來傳遞。這就允許在其中緩存請(qǐng)求,減少訪問物理設(shè)備的次數(shù),加快訪問速度。以最近使用(LRU)列表的形式管理緩沖區(qū)緩存。注意,可以使用 sync 命令將緩沖區(qū)緩存中的請(qǐng)求發(fā)送到存儲(chǔ)媒體(迫使所有未寫的數(shù)據(jù)發(fā)送到設(shè)備驅(qū)動(dòng)程序,進(jìn)而發(fā)送到存儲(chǔ)設(shè)備)。

什么是塊設(shè)備?
塊設(shè)備就是以塊(比如磁盤扇區(qū))為單位收發(fā)數(shù)據(jù)的設(shè)備,它們支持緩沖和隨機(jī)訪問(不必順序讀取塊,而是可以在任何時(shí)候訪問任何塊)等特性。塊設(shè)備包括硬盤、CD-ROM 和 RAM 盤。與塊設(shè)備相對(duì)的是字符設(shè)備,字符設(shè)備沒有可以進(jìn)行物理尋址的媒體。字符設(shè)備包括串行端口和磁帶設(shè)備,只能逐字符地讀取這些設(shè)備中的數(shù)據(jù)。

這就是 VFS 和文件系統(tǒng)組件的高層情況。現(xiàn)在,討論實(shí)現(xiàn)這個(gè)子系統(tǒng)的主要結(jié)構(gòu)。

主要結(jié)構(gòu)

Linux 以一組通用對(duì)象的角度看待所有文件系統(tǒng)。這些對(duì)象是超級(jí)塊(superblock)、inode、dentry 和文件。超級(jí)塊在每個(gè)文件系統(tǒng)的根上,超級(jí)塊描述和維護(hù)文件系統(tǒng)的狀態(tài)。文件系統(tǒng)中管理的每個(gè)對(duì)象(文件或目錄)在 Linux 中表示為一個(gè) inode。inode 包含管理文件系統(tǒng)中的對(duì)象所需的所有元數(shù)據(jù)(包括可以在對(duì)象上執(zhí)行的操作)。另一組結(jié)構(gòu)稱為 dentry,它們用來實(shí)現(xiàn)名稱和 inode 之間的映射,有一個(gè)目錄緩存用來保存最近使用的 dentry。dentry 還維護(hù)目錄和文件之間的關(guān)系,從而支持在文件系統(tǒng)中移動(dòng)。最后,VFS 文件表示一個(gè)打開的文件(保存打開的文件的狀態(tài),比如寫偏移量等等)。

虛擬文件系統(tǒng)層

VFS 作為文件系統(tǒng)接口的根層。VFS 記錄當(dāng)前支持的文件系統(tǒng)以及當(dāng)前掛裝的文件系統(tǒng)。

可以使用一組注冊(cè)函數(shù)在 Linux 中動(dòng)態(tài)地添加或刪除文件系統(tǒng)。內(nèi)核保存當(dāng)前支持的文件系統(tǒng)的列表,可以通過 /proc 文件系統(tǒng)在用戶空間中查看這個(gè)列表。這個(gè)虛擬文件還顯示當(dāng)前與這些文件系統(tǒng)相關(guān)聯(lián)的設(shè)備。在 Linux 中添加新文件系統(tǒng)的方法是調(diào)用 register_filesystem。這個(gè)函數(shù)的參數(shù)定義一個(gè)文件系統(tǒng)結(jié)構(gòu)(file_system_type)的引用,這個(gè)結(jié)構(gòu)定義文件系統(tǒng)的名稱、一組屬性和兩個(gè)超級(jí)塊函數(shù)。也可以注銷文件系統(tǒng)。

在注冊(cè)新的文件系統(tǒng)時(shí),會(huì)把這個(gè)文件系統(tǒng)和它的相關(guān)信息添加到 file_systems 列表中(見圖 2 和 linux/include/linux/mount.h)。這個(gè)列表定義可以支持的文件系統(tǒng)。在命令行上輸入 cat /proc/filesystems,就可以查看這個(gè)列表。


圖 2. 向內(nèi)核注冊(cè)的文件系統(tǒng)
 圖 2. 向內(nèi)核注冊(cè)的文件系統(tǒng)

VFS 中維護(hù)的另一個(gè)結(jié)構(gòu)是掛裝的文件系統(tǒng)(見圖 3)。這個(gè)結(jié)構(gòu)提供當(dāng)前掛裝的文件系統(tǒng)(見 linux/include/linux/fs.h)。它鏈接下面討論的超級(jí)塊結(jié)構(gòu)。


圖 3. 掛裝的文件系統(tǒng)列表
 圖 3. 掛裝的文件系統(tǒng)列表

超級(jí)塊

超級(jí)塊結(jié)構(gòu)表示一個(gè)文件系統(tǒng)。它包含管理文件系統(tǒng)所需的信息,包括文件系統(tǒng)名稱(比如 ext2)、文件系統(tǒng)的大小和狀態(tài)、塊設(shè)備的引用和元數(shù)據(jù)信息(比如空閑列表等等)。超級(jí)塊通常存儲(chǔ)在存儲(chǔ)媒體上,但是如果超級(jí)塊不存在,也可以實(shí)時(shí)創(chuàng)建它。可以在 ./linux/include/linux/fs.h 中找到超級(jí)塊結(jié)構(gòu)(見圖 4)。


圖 4. 超級(jí)塊結(jié)構(gòu)和 inode 操作
 圖 4. 超級(jí)塊結(jié)構(gòu)和 inode 操作

超級(jí)塊中的一個(gè)重要元素是超級(jí)塊操作的定義。這個(gè)結(jié)構(gòu)定義一組用來管理這個(gè)文件系統(tǒng)中的 inode 的函數(shù)。例如,可以用 alloc_inode 分配 inode,用 destroy_inode 刪除 inode。可以用 read_inodewrite_inode 讀寫 inode,用 sync_fs 執(zhí)行文件系統(tǒng)同步。可以在 ./linux/include/linux/fs.h 中找到 super_operations 結(jié)構(gòu)。每個(gè)文件系統(tǒng)提供自己的 inode 方法,這些方法實(shí)現(xiàn)操作并向 VFS 層提供通用的抽象。

inode 和 dentry

inode 表示文件系統(tǒng)中的一個(gè)對(duì)象,它具有惟一標(biāo)識(shí)符。各個(gè)文件系統(tǒng)提供將文件名映射為惟一 inode 標(biāo)識(shí)符和 inode 引用的方法。圖 5 顯示 inode 結(jié)構(gòu)的一部分以及兩個(gè)相關(guān)結(jié)構(gòu)。請(qǐng)?zhí)貏e注意 inode_operationsfile_operations。這些結(jié)構(gòu)表示可以在這個(gè) inode 上執(zhí)行的操作。inode_operations 定義直接在 inode 上執(zhí)行的操作,而 file_operations 定義與文件和目錄相關(guān)的方法(標(biāo)準(zhǔn)系統(tǒng)調(diào)用)。


圖 5. inode 結(jié)構(gòu)和相關(guān)聯(lián)的操作
 圖 5. inode 結(jié)構(gòu)和相關(guān)聯(lián)的操作

inode 和目錄緩存分別保存最近使用的 inode 和 dentry。注意,對(duì)于 inode 緩存中的每個(gè) inode,在目錄緩存中都有一個(gè)對(duì)應(yīng)的 dentry。可以在 ./linux/include/linux/fs.h 中找到 inodedentry 結(jié)構(gòu)。

緩沖區(qū)緩存

除了各個(gè)文件系統(tǒng)實(shí)現(xiàn)(可以在 ./linux/fs 中找到)之外,文件系統(tǒng)層的底部是緩沖區(qū)緩存。這個(gè)組件跟蹤來自文件系統(tǒng)實(shí)現(xiàn)和物理設(shè)備(通過設(shè)備驅(qū)動(dòng)程序)的讀寫請(qǐng)求。為了提高效率,Linux 對(duì)請(qǐng)求進(jìn)行緩存,避免將所有請(qǐng)求發(fā)送到物理設(shè)備。緩存中緩存最近使用的緩沖區(qū)(頁面),這些緩沖區(qū)可以快速提供給各個(gè)文件系統(tǒng)。





回頁首


有趣的文件系統(tǒng)

本文沒有討論 Linux 中可用的具體文件系統(tǒng),但是值得在這里稍微提一下。Linux 支持許多種文件系統(tǒng),包括 MINIX、MS-DOS 和 ext2 等老式文件系統(tǒng)。Linux 還支持 ext3、JFS 和 ReiserFS 等新的日志型文件系統(tǒng)。另外,Linux 支持加密文件系統(tǒng)(比如 CFS)和虛擬文件系統(tǒng)(比如 /proc)。

最后一種值得注意的文件系統(tǒng)是 Filesystem in Userspace(FUSE)。這種文件系統(tǒng)可以將文件系統(tǒng)請(qǐng)求通過 VFS 發(fā)送回用戶空間。所以,如果您有興趣創(chuàng)建自己的文件系統(tǒng),那么通過使用 FUSE 進(jìn)行開發(fā)是一種不錯(cuò)的方法。





回頁首


結(jié)束語

分享這篇文章……

digg 將本文提交到 Digg
del.icio.us 發(fā)布到 del.icio.us
Slashdot 提交到 Slashdot!

盡管文件系統(tǒng)的實(shí)現(xiàn)并不復(fù)雜,但它是可伸縮和可擴(kuò)展的體系結(jié)構(gòu)的好例子。文件系統(tǒng)體系結(jié)構(gòu)已經(jīng)發(fā)展了許多年,并成功地支持了許多不同類型的文件系統(tǒng)和許多目標(biāo)存儲(chǔ)設(shè)備類型。由于使用了基于插件的體系結(jié)構(gòu)和多層的函數(shù)間接性,Linux 文件系統(tǒng)在近期的發(fā)展很值得關(guān)注

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产综合色产在线精品| 欧美aⅴ一区二区三区视频| 亚洲国语精品自产拍在线观看| 久久久欧美精品sm网站| 99精品免费| 欧美一区二区三区喷汁尤物| 亚洲国产日韩精品| 亚洲一区二区免费| 亚洲国产美女| 亚洲在线一区二区三区| 亚洲国产91| 亚洲欧美一区二区原创| 99精品欧美一区二区三区| 欧美制服丝袜| 亚洲免费人成在线视频观看| 久久久久国产精品厨房| 亚洲一区三区电影在线观看| 久久综合九色欧美综合狠狠| 欧美伊久线香蕉线新在线| 欧美欧美全黄| 欧美xx视频| 国产午夜精品福利| 一区二区三区导航| 亚洲久久成人| 久久婷婷国产综合精品青草| 性色一区二区三区| 欧美日韩一区二区在线视频| 亚洲高清不卡在线| 在线播放中文字幕一区| 香蕉久久a毛片| 亚洲综合电影| 欧美日韩亚洲视频| 最新国产精品拍自在线播放| 亚洲国产日韩美| 久久综合伊人77777蜜臀| 性欧美video另类hd性玩具| 欧美日韩精选| 亚洲三级影院| 亚洲美女视频在线免费观看| 麻豆av一区二区三区久久| 久久久人成影片一区二区三区| 国产精品午夜电影| 亚洲永久免费| 午夜伦理片一区| 国产精品乱人伦一区二区| 亚洲无线视频| 久久av老司机精品网站导航| 国产精品三区www17con| 亚洲一区二区欧美| 午夜精品一区二区在线观看| 国产精品久久福利| 亚洲香蕉视频| 午夜精品一区二区三区在线播放| 国产精品video| 亚洲一区综合| 久久久激情视频| 狠狠色综合网站久久久久久久| 欧美一区二区三区在线看 | 午夜精品www| 午夜精品理论片| 国产午夜精品视频| 久久爱www久久做| 蜜桃av一区二区| 亚洲国产精品视频| 欧美三级韩国三级日本三斤| 亚洲午夜电影| 国产精品久久国产精品99gif| 一区二区免费在线播放| 亚洲欧美日韩视频一区| 国产日韩欧美高清| 久久婷婷国产综合国色天香| 亚洲人www| 午夜精品一区二区三区电影天堂 | 欧美激情亚洲| 日韩午夜一区| 国产精品区二区三区日本| 午夜视频在线观看一区| 蜜臀91精品一区二区三区| 亚洲精品偷拍| 国产精品人人做人人爽人人添| 久久福利影视| 亚洲精品免费电影| 欧美在线视频一区| 亚洲人成毛片在线播放| 欧美午夜久久久| 久久国产精品久久国产精品| 亚洲成人在线网| 午夜精品久久99蜜桃的功能介绍| 国内久久精品视频| 欧美日韩国产大片| 欧美一区二区三区久久精品| 亚洲国产婷婷| 久久久久久国产精品mv| 一个色综合导航| 国产自产v一区二区三区c| 欧美日本韩国| 老司机精品视频一区二区三区| av成人免费在线观看| 美女网站在线免费欧美精品| 亚洲综合国产精品| 亚洲精选久久| 曰韩精品一区二区| 国产精品久在线观看| 欧美福利网址| 久久久精品国产免大香伊| 亚洲一区二区三区乱码aⅴ| 欧美国产日韩亚洲一区| 久久aⅴ国产紧身牛仔裤| 制服丝袜激情欧洲亚洲| 国产综合久久| 国产精品免费看久久久香蕉| 欧美精品粉嫩高潮一区二区| 久久久av水蜜桃| 性色av香蕉一区二区| 中文国产一区| 亚洲免费精品| 亚洲精品久久久久久久久久久久久| 久久综合99re88久久爱| 久久国产手机看片| 午夜精品www| 亚洲欧美日韩精品在线| 一区二区激情视频| 日韩一级视频免费观看在线| 亚洲区免费影片| 亚洲电影毛片| 在线看片成人| 在线观看91精品国产麻豆| 国产日本欧美视频| 国产精品视频xxxx| 国产精品国内视频| 欧美视频一区二区三区…| 欧美久久影院| 欧美激情一区二区三区全黄| 免费不卡在线观看| 美女福利精品视频| 麻豆久久婷婷| 男女视频一区二区| 美国十次成人| 欧美粗暴jizz性欧美20| 久久精品网址| 欧美激情欧美狂野欧美精品| 在线中文字幕日韩| 亚洲视频在线视频| 亚洲第一综合天堂另类专| 亚洲午夜精品久久久久久浪潮 | 91久久精品美女高潮| 欧美精品一区二区三区一线天视频| 校园激情久久| 亚洲精品国产系列| 亚洲盗摄视频| 亚洲第一二三四五区| 亚洲欧洲日本在线| 亚洲精品中文字幕在线观看| 99国产麻豆精品| 亚洲视频www| 午夜在线一区| 久久久久国产精品厨房| 欧美1区2区3区| 欧美视频在线观看一区二区| 国产精品视频内| 永久域名在线精品| 亚洲毛片一区| 亚洲欧美日韩国产成人精品影院| 欧美在线免费视频| 欧美aaa级| 夜夜嗨av色一区二区不卡| 亚洲欧美影院| 猛干欧美女孩| 国产精品大片免费观看| 国内精品久久久久影院色 | 夜夜嗨网站十八久久| 亚洲一区二区视频在线| 欧美一区二区三区免费视频| 老**午夜毛片一区二区三区| 欧美日本一区| 国产在线成人| 亚洲图片激情小说| 久久亚洲国产精品一区二区| 亚洲片在线资源| 欧美伊人久久| 欧美日韩国产bt| 一区二区在线视频| 午夜精品视频在线观看| 欧美福利在线观看| 亚洲欧美日韩一区二区在线| 欧美成年人网| 国产午夜久久| 中文在线资源观看网站视频免费不卡 | 亚洲性视频h| 美日韩精品免费观看视频| 国产精品日韩精品欧美在线| 亚洲黑丝在线| 久久精品亚洲国产奇米99| 亚洲精品中文字| 久久久蜜桃一区二区人| 欧美性片在线观看| 亚洲精品久久视频| 嫩草国产精品入口| 欧美亚洲视频在线观看| 久久久999|