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

文件系統:隱匿在 Linux 背后的機制

系統 Linux
在 Linux 中,最直觀、最可見的部分就是 文件系統(file system)。下面我們就來一起探討一下關于 Linux 中國的文件系統,系統調用以及文件系統實現背后的原理和思想。

[[339597]]

 本文轉載自微信公眾號「 Java建設者」,可以通過以下二維碼關注。轉載本文請聯系 Java建設者公眾號。

在 Linux 中,最直觀、最可見的部分就是 文件系統(file system)。下面我們就來一起探討一下關于 Linux 中國的文件系統,系統調用以及文件系統實現背后的原理和思想。這些思想中有一些來源于 MULTICS,現在已經被 Windows 等其他操作系統使用。Linux 的設計理念就是 小的就是好的(Small is Beautiful) 。雖然 Linux 只是使用了最簡單的機制和少量的系統調用,但是 Linux 卻提供了強大而優雅的文件系統。

Linux 文件系統基本概念

Linux 在最初的設計是 MINIX1 文件系統,它只支持 14 字節的文件名,它的最大文件只支持到 64 MB。在 MINIX 1 之后的文件系統是 ext 文件系統。ext 系統相較于 MINIX 1 來說,在支持字節大小和文件大小上均有很大提升,但是 ext 的速度仍沒有 MINIX 1 快,于是,ext 2 被開發出來,它能夠支持長文件名和大文件,而且具有比 MINIX 1 更好的性能。這使他成為 Linux 的主要文件系統。只不過 Linux 會使用 VFS 曾支持多種文件系統。在 Linux 鏈接時,用戶可以動態的將不同的文件系統掛載倒 VFS 上。

Linux 中的文件是一個任意長度的字節序列,Linux 中的文件可以包含任意信息,比如 ASCII 碼、二進制文件和其他類型的文件是不加區分的。

為了方便起見,文件可以被組織在一個目錄中,目錄存儲成文件的形式在很大程度上可以作為文件處理。目錄可以有子目錄,這樣形成有層次的文件系統,Linux 系統下面的根目錄是 /,它通常包含了多個子目錄。字符 / 還用于對目錄名進行區分,例如 /usr/cxuan 表示的就是根目錄下面的 usr 目錄,其中有一個叫做 cxuan 的子目錄。

下面我們介紹一下 Linux 系統根目錄下面的目錄名

  • /bin,它是重要的二進制應用程序,包含二進制文件,系統的所有用戶使用的命令都在這里
  • /boot,啟動包含引導加載程序的相關文件
  • /dev,包含設備文件,終端文件,USB 或者連接到系統的任何設備
  • /etc,配置文件,啟動腳本等,包含所有程序所需要的配置文件,也包含了啟動/停止單個應用程序的啟動和關閉 shell 腳本
  • /home,本地主要路徑,所有用戶用 home 目錄存儲個人信息
  • /lib,系統庫文件,包含支持位于 /bin 和 /sbin 下的二進制庫文件
  • /lost+found,在根目錄下提供一個遺失+查找系統,必須在 root 用戶下才能查看當前目錄下的內容
  • /media,掛載可移動介質
  • /mnt,掛載文件系統
  • /opt,提供一個可選的應用程序安裝目錄
  • /proc,特殊的動態目錄,用于維護系統信息和狀態,包括當前運行中進程信息
  • /root,root 用戶的主要目錄文件夾
  • /sbin,重要的二進制系統文件
  • /tmp, 系統和用戶創建的臨時文件,系統重啟時,這個目錄下的文件都會被刪除
  • /usr,包含絕大多數用戶都能訪問的應用程序和文件
  • /var,經常變化的文件,諸如日志文件或數據庫等

在 Linux 中,有兩種路徑,一種是 絕對路徑(absolute path) ,絕對路徑告訴你從根目錄下查找文件,絕對路徑的缺點是太長而且不太方便。還有一種是 相對路徑(relative path) ,相對路徑所在的目錄也叫做工作目錄(working directory)。

如果 /usr/local/books 是工作目錄,那么 shell 命令

  1. cp books books-replica  

就表示的是相對路徑,而

  1. cp /usr/local/books/books /usr/local/books/books-replica 

則表示的是絕對路徑。

在 Linux 中經常出現一個用戶使用另一個用戶的文件或者使用文件樹結構中的文件。兩個用戶共享同一個文件,這個文件位于某個用戶的目錄結構中,另一個用戶需要使用這個文件時,必須通過絕對路徑才能引用到他。如果絕對路徑很長,那么每次輸入起來會變的非常麻煩,所以 Linux 提供了一種 鏈接(link) 機制。

舉個例子,下面是一個使用鏈接之前的圖

 

以上所示,比如有兩個工作賬戶 jianshe 和 cxuan,jianshe 想要使用 cxuan 賬戶下的 A 目錄,那么它可能會輸入 /usr/cxuan/A ,這是一種未使用鏈接之后的圖。

使用鏈接后的示意如下

 

現在,jianshe 可以創建一個鏈接來使用 cxuan 下面的目錄了。‘

當一個目錄被創建出來后,有兩個目錄項也同時被創建出來,它們就是 . 和 .. ,前者代表工作目錄自身,后者代表該目錄的父目錄,也就是該目錄所在的目錄。這樣一來,在 /usr/jianshe 中訪問 cxuan 中的目錄就是 ../cxuan/xxx

Linux 文件系統不區分磁盤的,這是什么意思呢?一般來說,一個磁盤中的文件系統相互之間保持獨立,如果一個文件系統目錄想要訪問另一個磁盤中的文件系統,在 Windows 中你可以像下面這樣。

 

兩個文件系統分別在不同的磁盤中,彼此保持獨立。

而在 Linux 中,是支持掛載的,它允許一個磁盤掛在到另外一個磁盤上,那么上面的關系會變成下面這樣

 

掛在之后,兩個文件系統就不再需要關心文件系統在哪個磁盤上了,兩個文件系統彼此可見。

Linux 文件系統的另外一個特性是支持 加鎖(locking)。在一些應用中會出現兩個或者更多的進程同時使用同一個文件的情況,這樣很可能會導致競爭條件(race condition)。一種解決方法是對其進行加不同粒度的鎖,就是為了防止某一個進程只修改某一行記錄從而導致整個文件都不能使用的情況。

POSIX 提供了一種靈活的、不同粒度級別的鎖機制,允許一個進程使用一個不可分割的操作對一個字節或者整個文件進行加鎖。加鎖機制要求嘗試加鎖的進程指定其 要加鎖的文件,開始位置以及要加鎖的字節Linux 系統提供了兩種鎖:共享鎖和互斥鎖。如果文件的一部分已經加上了共享鎖,那么再加排他鎖是不會成功的;如果文件系統的一部分已經被加了互斥鎖,那么在互斥鎖解除之前的任何加鎖都不會成功。為了成功加鎖、請求加鎖的部分的所有字節都必須是可用的。

在加鎖階段,進程需要設計好加鎖失敗后的情況,也就是判斷加鎖失敗后是否選擇阻塞,如果選擇阻塞式,那么當已經加鎖的進程中的鎖被刪除時,這個進程會解除阻塞并替換鎖。如果進程選擇非阻塞式的,那么就不會替換這個鎖,會立刻從系統調用中返回,標記狀態碼表示是否加鎖成功,然后進程會選擇下一個時間再次嘗試。

加鎖區域是可以重疊的。下面我們演示了三種不同條件的加鎖區域。

 

如上圖所示,A 的共享鎖在第四字節到第八字節進行加鎖

 

如上圖所示,進程在 A 和 B 上同時加了共享鎖,其中 6 - 8 字節是重疊鎖

 

如上圖所示,進程 A 和 B 和 C 同時加了共享鎖,那么第六字節和第七字節是共享鎖。

如果此時一個進程嘗試在第 6 個字節處加鎖,此時會設置失敗并阻塞,由于該區域被 A B C 同時加鎖,那么只有等到 A B C 都釋放鎖后,進程才能加鎖成功。

Linux 文件系統調用

許多系統調用都會和文件與文件系統有關。我們首先先看一下對單個文件的系統調用,然后再來看一下對整個目錄和文件的系統調用。

為了創建一個新的文件,會使用到 creat 方法,注意沒有 e。

這里說一個小插曲,曾經有人問 UNIX 創始人 Ken Thompson,如果有機會重新寫 UNIX ,你會怎么辦,他回答自己要把 creat 改成 create ,哈哈哈哈。

這個系統調用的兩個參數是文件名和保護模式

  1. fd = creat("aaa",mode); 

這段命令會創建一個名為 aaa 的文件,并根據 mode 設置文件的保護位。這些位決定了哪個用戶可能訪問文件、如何訪問。

creat 系統調用不僅僅創建了一個名為 aaa 的文件,還會打開這個文件。為了允許后續的系統調用訪問這個文件,這個 creat 系統調用會返回一個 非負整數, 這個就叫做 文件描述符(file descriptor),也就是上面的 fd。

如果在已經存在的文件上調用了 creat 系統調用,那么該文件中的內容會被清除,從 0 開始。通過設置合適的參數,open 系統調用也能夠創建文件。

下面讓我們看一看主要的系統調用,如下表所示

系統調用 描述
fd = creat(name,mode) 一種創建一個新文件的方式
fd = open(file, ...) 打開文件讀、寫或者讀寫
s = close(fd) 關閉一個打開的文件
n = read(fd, buffer, nbytes) 從文件中向緩存中讀入數據
n = write(fd, buffer, nbytes) 從緩存中向文件中寫入數據
position = lseek(fd, offset, whence) 移動文件指針
s = stat(name, &buf) 獲取文件信息
s = fstat(fd, &buf) 獲取文件信息
s = pipe(&fd[0]) 創建一個管道
s = fcntl(fd,...) 文件加鎖等其他操作

為了對一個文件進行讀寫的前提是先需要打開文件,必須使用 creat 或者 open 打開,參數是打開文件的方式,是只讀、可讀寫還是只寫。open 系統調用也會返回文件描述符。打開文件后,需要使用 close 系統調用進行關閉。close 和 open 返回的 fd 總是未被使用的最小數量。

什么是文件描述符?文件描述符就是一個數字,這個數字標示了計算機操作系統中打開的文件。它描述了數據資源,以及訪問資源的方式。

當程序要求打開一個文件時,內核會進行如下操作

  • 授予訪問權限
  • 在全局文件表(global file table)中創建一個條目(entry)
  • 向軟件提供條目的位置

文件描述符由唯一的非負整數組成,系統上每個打開的文件至少存在一個文件描述符。文件描述符最初在 Unix 中使用,并且被包括 Linux,macOS 和 BSD 在內的現代操作系統所使用。

當一個進程成功訪問一個打開的文件時,內核會返回一個文件描述符,這個文件描述符指向全局文件表的 entry 項。這個文件表項包含文件的 inode 信息,字節位移,訪問限制等。例如下圖所示

 

默認情況下,前三個文件描述符為 STDIN(標準輸入)、STDOUT(標準輸出)、STDERR(標準錯誤)。

標準輸入的文件描述符是 0 ,在終端中,默認為用戶的鍵盤輸入

標準輸出的文件描述符是 1 ,在終端中,默認為用戶的屏幕

與錯誤有關的默認數據流是 2,在終端中,默認為用戶的屏幕。

在簡單聊了一下文件描述符后,我們繼續回到文件系統調用的探討。

在文件系統調用中,開銷最大的就是 read 和 write 了。read 和 write 都有三個參數

  • 文件描述符:告訴需要對哪一個打開文件進行讀取和寫入
  • 緩沖區地址:告訴數據需要從哪里讀取和寫入哪里
  • 統計:告訴需要傳輸多少字節

這就是所有的參數了,這個設計非常簡單輕巧。

雖然幾乎所有程序都按順序讀取和寫入文件,但是某些程序需要能夠隨機訪問文件的任何部分。與每個文件相關聯的是一個指針,該指針指示文件中的當前位置。順序讀取(或寫入)時,它通常指向要讀取(寫入)的下一個字節。如果指針在讀取 1024 個字節之前位于 4096 的位置,則它將在成功讀取系統調用后自動移至 5120 的位置。

Lseek 系統調用會更改指針位置的值,以便后續對 read 或 write 的調用可以在文件中的任何位置開始,甚至可以超出文件末尾。

lseek = Lseek ,段首大寫。

lseek 避免叫做 seek 的原因就是 seek 已經在之前 16 位的計算機上用于搜素功能了。

Lseek 有三個參數:第一個是文件的文件描述符,第二個是文件的位置;第三個告訴文件位置是相對于文件的開頭,當前位置還是文件的結尾

  1. lseek(int fildes, off_t offset, int whence); 

lseek 的返回值是更改文件指針后文件中的絕對位置。lseek 是唯一從來不會造成真正磁盤查找的系統調用,它只是更新當前的文件位置,這個文件位置就是內存中的數字。

對于每個文件,Linux 都會跟蹤文件模式(常規,目錄,特殊文件),大小,最后修改時間以及其他信息。程序能夠通過 stat 系統調用看到這些信息。第一個參數就是文件名,第二個是指向要放置請求信息結構的指針。這些結構的屬性如下圖所示。

fstat 調用和 stat 相同,只有一點區別,fstat 可以對打開文件進行操作,而 stat 只能對路徑進行操作。

pipe 文件系統調用被用來創建 shell 管道。它會創建一系列的偽文件,來緩沖和管道組件之間的數據,并且返回讀取或者寫入緩沖區的文件描述符。在管道中,像是如下操作

  1. sort <in | head –40 

sort 進程將會輸出到文件描述符1,也就是標準輸出,寫入管道中,而 head 進程將從管道中讀入。在這種方式中,sort 只是從文件描述符 0 中讀取并寫入到文件描述符 1 (管道)中,甚至不知道它們已經被重定向了。如果沒有重定向的話,sort 會自動的從鍵盤讀入并輸出到屏幕中。

最后一個系統調用是 fcntl,它用來鎖定和解鎖文件,應用共享鎖和互斥鎖,或者是執行一些文件相關的其他操作。

現在我們來關心一下和整體目錄和文件系統相關的系統調用,而不是把精力放在單個的文件上,下面列出了這些系統調用,我們一起來看一下。

系統調用 描述
s = mkdir(path,mode) 創建一個新的目錄
s = rmdir(path) 移除一個目錄
s = link(oldpath,newpath) 創建指向已有文件的鏈接
s = unlink(path) 取消文件的鏈接
s = chdir(path) 改變工作目錄
dir = opendir(path) 打開一個目錄讀取
s = closedir(dir) 關閉一個目錄
dirent = readdir(dir) 讀取一個目錄項
rewinddir(dir) 回轉目錄使其在此使用

可以使用 mkdir 和 rmdir 創建和刪除目錄。但是需要注意,只有目錄為空時才可以刪除。

創建一個指向已有文件的鏈接時會創建一個目錄項(directory entry)。系統調用 link 來創建鏈接,oldpath 代表已有的路徑,newpath 代表需要鏈接的路徑,使用 unlink 可以刪除目錄項。當文件的最后一個鏈接被刪除時,這個文件會被自動刪除。

使用 chdir 系統調用可以改變工作目錄。

最后四個系統調用是用于讀取目錄的。和普通文件類似,他們可以被打開、關閉和讀取。每次調用 readdir 都會以固定的格式返回一個目錄項。用戶不能對目錄執行寫操作,但是可以使用 creat 或者 link 在文件夾中創建一個目錄,或使用 unlink 刪除一個目錄。用戶不能在目錄中查找某個特定文件,但是可以使用 rewindir 作用于一個打開的目錄,使他能在此從頭開始讀取。

責任編輯:武曉燕 來源: Java建設者
相關推薦

2021-01-12 08:06:11

ARP數據計網

2020-05-22 13:40:09

Linux文件系統

2020-05-25 09:09:01

Linux件系統導航

2009-12-14 13:33:31

linuxramdisk文件系統

2011-01-13 14:10:30

Linux文件系統

2012-07-05 09:52:06

EFS文件加密

2020-07-22 14:53:06

Linux系統虛擬文件

2009-11-06 10:05:18

Linux系統環境GFS

2009-04-20 21:20:32

Linux文件系統存儲機制

2021-04-12 05:44:44

Linux文件系統

2021-06-06 16:55:22

Linux文件系統

2014-06-23 17:04:25

2024-01-12 08:26:16

Linux磁盤文件系統

2020-09-25 07:48:12

Linux系統文件

2012-05-10 13:49:44

Linux文件系統

2011-01-11 10:29:35

Linux文件

2012-12-24 11:32:08

2017-04-20 14:55:36

LinuxPyinotifyPython

2010-11-15 15:44:11

Oracle文件系統

2009-12-10 09:42:07

點贊
收藏

51CTO技術棧公眾號

中文字幕日韩欧美| 在线观看成人小视频| 国产精品区二区三区日本| 国产无遮挡又黄又爽又色| 欧美一区 二区| 欧美亚洲愉拍一区二区| 日本丰满大乳奶| 天天干视频在线观看| 丝瓜av网站精品一区二区| 中文字幕欧美专区| 一区二区免费在线观看视频| 成人免费网站www网站高清| 樱桃视频在线观看一区| 欧洲精品久久| 国产91免费在线观看| 日日摸夜夜添夜夜添国产精品| 欧美理论片在线观看| 亚洲黄色小说视频| 66精品视频在线观看| 欧美在线观看你懂的| 成人免费性视频| 在线激情免费视频| 99国内精品久久| 91在线精品视频| 亚洲精品无码久久久久| 亚洲久久视频| 久久99精品久久久久久琪琪| 亚洲不卡的av| 奇米色欧美一区二区三区| 精品国产一区二区三区四区四| 免费看国产黄色片| 亚洲美女久久精品| 洋洋成人永久网站入口| 亚洲一区精彩视频| 岛国在线大片| 久久亚洲捆绑美女| 国产欧美韩日| 性中国xxx极品hd| 国产在线精品一区二区三区不卡| 国产精品18久久久久久首页狼| www.天天色| 色狮一区二区三区四区视频| 欧美mv日韩mv| 爱情岛论坛亚洲自拍| 日本亚洲欧洲无免费码在线| 欧洲一区二区三区在线| 欧美在线观看视频网站| 一区二区电影免费观看| 天天综合天天综合色| 福利视频免费在线观看| 免费男女羞羞的视频网站在线观看| 国产精品久久久久久久久动漫 | 欧美一二区在线观看| 日韩精品中文字幕视频在线| 国产精品入口麻豆| 精品欧美午夜寂寞影院| 亚洲国产精品电影| 亚洲国产精品无码久久久久高潮| 国产精品极品| 亚洲精品久久久久国产| 亚洲图片综合网| 嫩草国产精品入口| 亚洲国产毛片完整版| 性欧美丰满熟妇xxxx性久久久| 老司机成人在线| 亚洲欧美999| www..com.cn蕾丝视频在线观看免费版| 国产精品一区高清| 最近2019年手机中文字幕| www.99re6| 欧美黄色一区| 久久全国免费视频| 成年人视频在线免费看| 日本不卡的三区四区五区| 国产精品香蕉在线观看| 国产又粗又大又爽| 国产高清成人在线| 精品无人区一区二区三区竹菊| 视频午夜在线| 国产欧美一区二区在线观看| 中文字幕中文字幕在线中心一区| 在线中文字幕视频观看| 精品国产999| 国产一线二线三线在线观看| 国产精品美女久久久久| 亚洲国产精品福利| 美女100%露胸无遮挡| 91成人超碰| 91高清在线免费观看| а中文在线天堂| 黄色精品一二区| 精品在线视频一区二区| 三区四区在线视频| 亚洲男女一区二区三区| 无码人妻丰满熟妇区96| 69堂免费精品视频在线播放| 日韩精品一区二区三区四区| 成年人网站免费看| 亚洲精品国产偷自在线观看| 欧美一级大胆视频| 97精品人妻一区二区三区香蕉| 成人av动漫在线| 一区二区三区电影| 交100部在线观看| 6080yy午夜一二三区久久| xxxxxx黄色| 999精品视频| 2025国产精品视频| 精品久久久免费视频| 久久蜜桃一区二区| 国产激情片在线观看| 全球最大av网站久久| 亚洲第一精品福利| 熟女av一区二区| 免费亚洲网站| 国产精品青青草| av在线免费网站| 欧美视频一区二| 欧美图片一区二区| 国产精品v亚洲精品v日韩精品| 国产精品都在这里| 亚洲人视频在线观看| 亚洲精选视频在线| 伊人影院综合在线| 国产成人三级| 国产91精品久久久| 男人天堂综合网| 亚洲女人的天堂| 手机免费av片| 日韩欧美午夜| 国产精品视频xxx| 国产乱理伦片a级在线观看| 午夜久久久久久| 色婷婷狠狠18禁久久| 午夜久久免费观看| 成人xxxxx| 免费网站免费进入在线| 欧美视频一二三区| 大胸美女被爆操| 日本美女一区二区三区视频| 久久艳妇乳肉豪妇荡乳av| 国产第一页在线视频| 日韩一区二区三区高清免费看看| 男女全黄做爰文章| 秋霞影院一区二区| 天天综合色天天综合色hd| 日本成人三级电影| 亚洲欧美一区二区三区情侣bbw| 五月天婷婷综合网| 91色porny在线视频| 国产中文字幕免费观看| 欧美三级午夜理伦三级小说| 欧美一级大片视频| 国产日韩精品在线看| 色噜噜狠狠色综合欧洲selulu| 成人h动漫精品一区| 一本综合久久| 你懂的视频在线一区二区| 国产精品迅雷| 国产一区二区三区欧美| 中文字幕91爱爱| 日韩美女视频一区二区 | 成人免费不卡视频| 免费看欧美一级片| 日韩av午夜| 国产福利精品视频| 午夜国产福利在线| 日韩女优av电影在线观看| 国产亚洲欧美精品久久久久久 | 欧美男男青年gay1069videost | 欧美午夜在线视频| 国产伦视频一区二区三区| 欧美a级在线观看| 亚洲天堂第二页| 国产精品欧美激情在线| 亚洲综合在线第一页| 波多野结衣一二三区| 母乳一区在线观看| 中文精品视频一区二区在线观看| 日韩高清一区| 97久久精品视频| 在线观看精品一区二区三区| 日韩亚洲欧美在线| 六月丁香激情综合| 亚洲天堂av老司机| 中文字幕人妻一区二区三区| 久久亚洲不卡| 最新av网址在线观看| 秋霞蜜臀av久久电影网免费| 国产精品嫩草影院久久久| 性xxxxfjsxxxxx欧美| 亚洲精品在线看| 国产人妖一区二区| 欧美性jizz18性欧美| 日本激情视频一区二区三区| 成人免费高清视频| 国产精品久久a| 在线日韩视频| 少妇熟女一区二区| 亚洲69av| 99三级在线| 成人a在线观看高清电影| 久久久久久18| 欧美极品视频| 国产视频丨精品|在线观看| 国产精品国产av| 日韩欧美在线观看视频| 欧美日韩成人免费观看| 亚洲国产精品av| av黄色一级片| 国产精品一区二区在线看| av观看免费在线| 悠悠资源网久久精品| 国产精品99久久久久久大便| 奇米色欧美一区二区三区| 国产福利久久精品| 欧美美女被草| 国产精品第1页| 日本在线影院| 欧美激情精品久久久久久免费印度| 成人性生交大片免费看午夜| 亚洲国产婷婷香蕉久久久久久| 国产乱淫片视频| 欧美三级日韩三级| 国产又黄又猛又粗又爽| 亚洲成人tv网| 久久精品www人人爽人人| 中文字幕在线不卡| 日韩一级av毛片| 26uuu欧美| 精品人妻一区二区三区日产乱码卜| 国产精品 日产精品 欧美精品| av污在线观看| 美女国产一区二区| 91香蕉视频导航| 手机精品视频在线观看| 久久美女福利视频| 亚洲尤物在线| 免费在线观看的av网站| 一本久道久久久| 欧美日本视频在线观看| 亚洲三级毛片| 秋霞无码一区二区| 亚洲茄子视频| 国产成人a亚洲精v品无码| 国产精品久久久久毛片大屁完整版 | 国产精品成人国产乱一区| 吞精囗交69激情欧美| 日本欧美一级片| 欧美福利在线播放| 国产成人中文字幕| 日本在线精品| 国产精品美乳在线观看| 国产成人福利夜色影视| 成人午夜小视频| 日本精品在线观看| 成人3d动漫一区二区三区91| 国产精品久久久久久久久久白浆| 国产精品亚洲不卡a| 神马久久av| 欧美一级日本a级v片| 日韩激情图片| 精品一区二区三区毛片| 欧美视频导航| 鲁一鲁一鲁一鲁一澡| 久久中文字幕一区二区三区| 国产一区二区在线免费播放| 蜜桃视频在线一区| 亚洲一级片av| 成人免费视频一区二区| 3d动漫精品啪啪一区二区下载| 久久精品日韩一区二区三区| 黄色国产在线播放| 亚洲欧洲中文日韩久久av乱码| 国产精品第108页| 一本大道久久a久久综合| 中文精品久久久久人妻不卡| 91精品国产黑色紧身裤美女| 国产 欧美 自拍| 一区二区成人av| 日本高清成人vr专区| 91大神福利视频在线| 国产亚洲人成a在线v网站| 99www免费人成精品| 你懂的一区二区三区| 中文字幕中文字幕在线中心一区| 伊人影院久久| 色诱视频在线观看| 国产精品原创巨作av| 中文字幕在线免费看线人| 国产精品嫩草影院av蜜臀| 久久久久97国产| 色老汉av一区二区三区| a天堂在线视频| 亚洲片国产一区一级在线观看| 国产在线观看av| 欧洲精品在线视频| 精品国产乱码一区二区三区| 欧美日韩精品一区| 中文无码久久精品| 毛片av免费在线观看| 国产精品一区二区不卡| 51妺嘿嘿午夜福利| 亚洲国产另类av| 亚洲无码久久久久久久| 日韩国产欧美精品一区二区三区| 毛片av在线| 国产第一区电影| 欧美一级二级三级视频| 久久久天堂国产精品| 免费久久99精品国产| 野外性满足hd| 婷婷久久综合九色综合绿巨人| 国产影视一区二区| 有码中文亚洲精品| 在线观看网站免费入口在线观看国内 | 99久久这里有精品| 日本成人三级电影网站| 亚洲夜间福利| 91丨porny丨九色| 国产精品国产三级国产aⅴ入口| 日韩黄色在线播放| 亚洲国产成人一区| 日韩成人伦理| 91黄色精品| 亚洲91精品| jizz欧美性11| 欧美国产成人在线| 免费无码国产精品| 亚洲国内精品视频| 丁香花在线高清完整版视频| 5566中文字幕一区二区| 国产精品国内免费一区二区三区| 毛葺葺老太做受视频| 久久香蕉国产线看观看99| www.国产色| 亚洲精品综合久久中文字幕| 国模精品视频| 国模一区二区三区私拍视频| 国内精品美女在线观看| 亚洲一区二区三区三州| 亚洲女人的天堂| 精品人妻一区二区三区蜜桃| 欧美成人精品xxx| 欧美视频三区| 久久久国内精品| 成人激情小说网站| 国产性xxxx高清| 日韩精品999| 欧美三级精品| 亚洲精品欧美精品| 理论电影国产精品| 日本精品在线免费观看| 欧美电影一区二区三区| gogo在线观看| 豆国产97在线| 亚洲精品系列| 丝袜美腿中文字幕| 在线观看日韩精品| 一广人看www在线观看免费视频| 91精品免费久久久久久久久| 欧美二区不卡| 99re久久精品国产| 日本久久一区二区| 永久免费av在线| 成人羞羞视频免费| 亚洲日本免费| 国产99在线 | 亚洲| 欧美日本亚洲韩国国产| 美脚丝袜一区二区三区在线观看| 久热精品在线| 小泽玛利亚一区| 欧美成人伊人久久综合网| √天堂8资源中文在线| 欧美人与性禽动交精品| 麻豆精品在线看| 精品97人妻无码中文永久在线| 亚洲第一网中文字幕| 吞精囗交69激情欧美| 成年人三级视频| www.成人网.com| 在线观看毛片视频| 久久久久久久久电影| 亚洲ab电影| 国产xxxxhd| 色综合久久综合网欧美综合网| 求av网址在线观看| 国产精品青青草| 蓝色福利精品导航| 久久精品女人毛片国产| 一区二区三欧美| 超碰97久久| jizz18女人| 日韩欧美亚洲国产一区| 在线观看中文| 性欧美大战久久久久久久免费观看| 国产精品亚洲а∨天堂免在线| 国产成人无码av| 欧美精品情趣视频| 日本道不卡免费一区|