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

一文揭秘單線程的Redis為什么這么快?

數據庫 其他數據庫 Redis
Redis 作為一種 KV 緩存服務器,有著極高的性能,相對于 Memcache,Redis 支持更多種數據類型,因此在業界應用廣泛。

 Redis 作為一種 KV 緩存服務器,有著極高的性能,相對于 Memcache,Redis 支持更多種數據類型,因此在業界應用廣泛。

記得剛畢業那會參加面試,面試官會問我 Redis 為什么快,由于當時技術水平有限,我只能回答出如下兩點:

  • 數據是存儲在內存中的。
  • Redis 是單線程的。

當然,將數據存儲在內存中,讀取的時候不需要進行磁盤的 IO,單線程也保證了系統沒有線程的上下文切換。

但這兩點只是 Redis 高性能原因的很小一部分,下面從數據存儲層面上為大家分析 Redis 性能為何如此高。

Redis性能如此高的原因,我總結了如下幾點:

  • 純內存操作
  • 單線程
  • 高效的數據結構
  • 合理的數據編碼
  • 其他方面的優化

在 Redis 中,常用的 5 種數據結構和應用場景如下:

  • String:緩存、計數器、分布式鎖等。
  • List:鏈表、隊列、微博關注人時間軸列表等。
  • Hash:用戶信息、Hash 表等。
  • Set:去重、贊、踩、共同好友等。
  • Zset:訪問量排行榜、點擊量排行榜等。

SDS

Redis 是用 C 語言開發完成的,但在 Redis 字符串中,并沒有使用  C 語言中的字符串,而是用一種稱為 SDS(Simple Dynamic String)的結構體來保存字符串。



struct sdshdr { 
       int len; 
     int free; 
     char buf[]; 
 }

SDS 的結構如上圖:

  • len:用于記錄 buf 中已使用空間的長度。
  • free:buf 中空閑空間的長度。
  • buf[]:存儲實際內容。

例如:執行命令 set key value,key 和 value 都是一個 SDS 類型的結構存儲在內存中。

SDS 與 C 字符串的區別

①常數時間內獲得字符串長度

C 字符串本身不記錄長度信息,每次獲取長度信息都需要遍歷整個字符串,復雜度為 O(n);C 字符串遍歷時遇到 '\0' 時結束。

SDS 中 len 字段保存著字符串的長度,所以總能在常數時間內獲取字符串長度,復雜度是 O(1)。

②避免緩沖區溢出

假設在內存中有兩個緊挨著的兩個字符串,s1=“xxxxx”和 s2=“yyyyy”。

由于在內存上緊緊相連,當我們對 s1 進行擴充的時候,將 s1=“xxxxxzzzzz”后,由于沒有進行相應的內存重新分配,導致 s1 把 s2 覆蓋掉,導致 s2 被莫名其妙的修改。

但 SDS 的 API 對 zfc 修改時首先會檢查空間是否足夠,若不充足則會分配新空間,避免了緩沖區溢出問題。

③減少字符串修改時帶來的內存重新分配的次數

在 C 中,當我們頻繁的對一個字符串進行修改(append 或 trim)操作的時候,需要頻繁的進行內存重新分配的操作,十分影響性能。

如果不小心忘記,有可能會導致內存溢出或內存泄漏,對于 Redis 來說,本身就會很頻繁的修改字符串,所以使用 C 字符串并不合適。而 SDS 實現了空間預分配和惰性空間釋放兩種優化策略:

空間預分配:當 SDS 的 API 對一個 SDS 修改后,并且對 SDS 空間擴充時,程序不僅會為 SDS 分配所需要的必須空間,還會分配額外的未使用空間。

分配規則如下:如果對 SDS 修改后,len 的長度小于 1M,那么程序將分配和 len 相同長度的未使用空間。

舉個例子,如果 len=10,重新分配后,buf 的實際長度會變為 10(已使用空間)+10(額外空間)+1(空字符)=21。

如果對 SDS 修改后 len 長度大于 1M,那么程序將分配 1M 的未使用空間。

惰性空間釋放:當對 SDS 進行縮短操作時,程序并不會回收多余的內存空間,而是使用 free 字段將這些字節數量記錄下來不釋放,后面如果需要 append 操作,則直接使用 free 中未使用的空間,減少了內存的分配。

④二進制安全

在 Redis 中不僅可以存儲 String 類型的數據,也可能存儲一些二進制數據。

二進制數據并不是規則的字符串格式,其中會包含一些特殊的字符如 '\0',在 C 中遇到 '\0' 則表示字符串的結束,但在 SDS 中,標志字符串結束的是 len 屬性。

字典

與 Java 中的 HashMap 類似,Redis 中的 Hash 比 Java 中的更高級一些。

Redis 本身就是 KV 服務器,除了 Redis 本身數據庫之外,字典也是哈希鍵的底層實現。

字典的數據結構如下所示:

typedef struct dict{ 
       dictType *type; 
     void *privdata; 
     dictht ht[2]; 
     int trehashidx; 
 }
typedef struct dictht{ 
     //哈希表數組 
     dectEntrt **table; 
     //哈希表大小 
     unsigned long size; 
     // 
     unsigned long sizemask; 
     //哈希表已有節點數量 
     unsigned long used; 
 }

重要的兩個字段是 dictht 和 trehashidx,這兩個字段與 rehash 有關,下面重點介紹 rehash。

Rehash

學過 Java 的朋友都應該知道 HashMap 是如何 rehash 的,在此處我就不過多贅述,下面介紹 Redis 中 Rehash 的過程。

由上段代碼,我們可知 dict 中存儲了一個 dictht 的數組,長度為 2,表明這個數據結構中實際存儲著兩個哈希表 ht[0] 和 ht[1],為什么要存儲兩張 hash 表呢?

當然是為了 Rehash,Rehash 的過程如下:

  • 為 ht[1] 分配空間。如果是擴容操作,ht[1] 的大小為***個大于等于 ht[0].used*2 的 2^n;如果是縮容操作,ht[1] 的大小為***個大于等于 ht[0].used 的 2^n。
  • 將 ht[0] 中的鍵值 Rehash 到 ht[1] 中。
  • 當 ht[0] 全部遷移到 ht[1] 中后,釋放 ht[0],將 ht[1] 置為 ht[0],并為 ht[1] 創建一張新表,為下次 Rehash 做準備。

漸進式 Rehash

由于 Redis 的 Rehash 操作是將 ht[0] 中的鍵值全部遷移到 ht[1],如果數據量小,則遷移過程很快。

但如果數據量很大,一個 Hash 表中存儲了幾萬甚至幾百萬幾千萬的鍵值時,遷移過程很慢并會影響到其他用戶的使用。

為了避免 Rehash 對服務器性能造成影響,Redis 采用了一種漸進式 Rehash 的策略,分多次、漸進的將 ht[0] 中的數據遷移到 ht[1] 中。

前一過程如下:

  • 為 ht[1] 分配空間,讓字典同時擁有 ht[0] 和 ht[1] 兩個哈希表。
  • 字典中維護一個 rehashidx,并將它置為 0,表示 Rehash 開始。
  • 在 Rehash 期間,每次對字典操作時,程序還順便將 ht[0] 在 rehashidx 索引上的所有鍵值對 rehash 到 ht[1] 中,當 Rehash 完成后,將 rehashidx 屬性+1。當全部 rehash 完成后,將 rehashidx 置為 -1,表示 rehash 完成。

注意,由于維護了兩張 Hash 表,所以在 Rehash 的過程中內存會增長。另外,在 Rehash 過程中,字典會同時使用 ht[0] 和 ht[1]。

所以在刪除、查找、更新時會在兩張表中操作,在查詢時會現在***張表中查詢,如果***張表中沒有,則會在第二張表中查詢。但新增時一律會在 ht[1] 中進行,確保 ht[0] 中的數據只會減少不會增加。

跳躍表

Zset 是一個有序的鏈表結構,其底層的數據結構是跳躍表 skiplist,其結構如下:

typedef struct zskiplistNode { 
     //成員對象 
    robj *obj; 
     //分值 
    double score; 
     //后退指針 
    struct zskiplistNode *backward; 
     //層 
    struct zskiplistLevel { 
         struct zskiplistNode *forward;//前進指針 
         unsigned int span;//跨度 
    } level[]; 
  } zskiplistNode;
typedef struct zskiplist { 
     //表頭節點和表尾節點 
    struct zskiplistNode *header, *tail; 
     //表中節點的的數量 
    unsigned long length; 
     //表中層數***的節點層數 
    int level; 
  } zskiplist;



前進指針:用于從表頭向表尾方向遍歷。

后退指針:用于從表尾向表頭方向回退一個節點,和前進指針不同的是,前進指針可以一次性跳躍多個節點,后退指針每次只能后退到上一個節點。

跨度:表示當前節點和下一個節點的距離,跨度越大,兩個節點中間相隔的元素越多。

在查詢過程中跳躍著前進。由于存在后退指針,如果查詢時超出了范圍,通過后退指針回退到上一個節點后仍可以繼續向前遍歷。

壓縮列表

壓縮列表 ziplist 是為 Redis 節約內存而開發的,是列表鍵和字典鍵的底層實現之一。

當元素個數較少時,Redis 用 ziplist 來存儲數據,當元素個數超過某個值時,鏈表鍵中會把 ziplist 轉化為 linkedlist,字典鍵中會把 ziplist 轉化為 hashtable。 

ziplist 是由一系列特殊編碼的連續內存塊組成的順序型的數據結構,ziplist 中可以包含多個 entry 節點,每個節點可以存放整數或者字符串。



由于內存是連續分配的,所以遍歷速度很快。

編碼轉化

Redis 使用對象(redisObject)來表示數據庫中的鍵值,當我們在 Redis 中創建一個鍵值對時,至少創建兩個對象,一個對象是用做鍵值對的鍵對象,另一個是鍵值對的值對象。

例如我們執行 SET MSG XXX 時,鍵值對的鍵是一個包含了字符串“MSG“的對象,鍵值對的值對象是包含字符串"XXX"的對象。

redisObject 的結構如下:

typedef struct redisObject{ 
     //類型 
    unsigned type:4; 
    //編碼 
    unsigned encoding:4; 
    //指向底層數據結構的指針 
    void *ptr; 
     //... 
  }robj;

其中 type 字段記錄了對象的類型,包含字符串對象、列表對象、哈希對象、集合對象、有序集合對象。

當我們執行 type key 命令時返回的結果如下:



ptr 指針字段指向對象底層實現的數據結構,而這些數據結構是由 encoding 字段決定的,每種對象至少有兩種數據編碼:



可以通過 object encoding key 來查看對象所使用的編碼:



細心的讀者可能注意到,list、hash、zset 三個鍵使用的是 ziplist 壓縮列表編碼,這就涉及到了 Redis 底層的編碼轉換。

上面介紹到,ziplist 是一種結構緊湊的數據結構,當某一鍵值中所包含的元素較少時,會優先存儲在 ziplist 中,當元素個數超過某一值后,才將 ziplist 轉化為標準存儲結構,而這一值是可配置的。

String 對象的編碼轉化

String 對象的編碼可以是 int 或 raw,對于 String 類型的鍵值,如果我們存儲的是純數字,Redis 底層采用的是 int 類型的編碼,如果其中包括非數字,則會立即轉為 raw 編碼:

127.0.0.1:6379> set str 1 
 OK 
 127.0.0.1:6379> object encoding str 
 "int" 
 127.0.0.1:6379> set str 1a 
 OK 
 127.0.0.1:6379> object encoding str 
 "raw" 
 127.0.0.1:6379>

List 對象的編碼轉化

List 對象的編碼可以是 ziplist 或 linkedlist,對于 List 類型的鍵值,當列表對象同時滿足以下兩個條件時,采用 ziplist 編碼:

  • 列表對象保存的所有字符串元素的長度都小于 64 字節。
  • 列表對象保存的元素個數小于 512 個。

如果不滿足這兩個條件的任意一個,就會轉化為 linkedlist 編碼。注意:這兩個條件是可以修改的,在 redis.conf 中:

list-max-ziplist-entries 512 
 list-max-ziplist-value 64

Set 類型的編碼轉化

Set 對象的編碼可以是 intset 或 hashtable,intset 編碼的結婚對象使用整數集合作為底層實現,把所有元素都保存在一個整數集合里面。

127.0.0.1:6379> sadd set 1 2 3 
 (integer) 3 
 127.0.0.1:6379> object encoding set 
 "intset" 
 127.0.0.1:6379>

如果 set 集合中保存了非整數類型的數據時,Redis 會將 intset 轉化為 hashtable:

127.0.0.1:6379> sadd set 1 2 3 
 (integer) 3 
 127.0.0.1:6379> object encoding set 
 "intset" 
 127.0.0.1:6379> sadd set a 
 (integer) 1 
 127.0.0.1:6379> object encoding set 
 "hashtable" 
  127.0.0.1:6379>

當 Set 對象同時滿足以下兩個條件時,對象采用 intset 編碼:

  • 保存的所有元素都是整數值(小數不行)。
  • Set 對象保存的所有元素個數小于 512 個。

不能滿足這兩個條件的任意一個,Set 都會采用 hashtable 存儲。注意:第兩個條件是可以修改的,在 redis.conf 中:

set-max-intset-entries 512

Hash 對象的編碼轉化

Hash 對象的編碼可以是 ziplist 或 hashtable,當 Hash 以 ziplist 編碼存儲的時候,保存同一鍵值對的兩個節點總是緊挨在一起,鍵節點在前,值節點在后:



當 Hash 對象同時滿足以下兩個條件時,Hash 對象采用 ziplist 編碼:

  • Hash 對象保存的所有鍵值對的鍵和值的字符串長度均小于 64 字節。
  • Hash 對象保存的鍵值對數量小于 512 個。

如果不滿足以上條件的任意一個,ziplist 就會轉化為 hashtable 編碼。注意:這兩個條件是可以修改的,在 redis.conf 中:

hash-max-ziplist-entries 512 
 hash-max-ziplist-value 64

Zset 對象的編碼轉化

Zset 對象的編碼可以是 ziplist 或 zkiplist,當采用 ziplist 編碼存儲時,每個集合元素使用兩個緊挨在一起的壓縮列表來存儲。

***個節點存儲元素的成員,第二個節點存儲元素的分值,并且按分值大小從小到大有序排列。



當 Zset 對象同時滿足一下兩個條件時,采用 ziplist 編碼:

  • Zset 保存的元素個數小于 128。
  • Zset 元素的成員長度都小于 64 字節。

如果不滿足以上條件的任意一個,ziplist 就會轉化為 zkiplist 編碼。注意:這兩個條件是可以修改的,在 redis.conf 中:

zset-max-ziplist-entries 128 
 zset-max-ziplist-value 64

思考:Zset 如何做到 O(1) 復雜度內元素并且快速進行范圍操作?Zset 采用 skiplist 編碼時使用 zset 結構作為底層實現,該數據結構同時包含了一個跳躍表和一個字典。

其結構如下:

typedef struct zset{ 
     zskiplist *zsl; 
    dict *dict; 
 }

Zset 中的 dict 字典為集合創建了一個從成員到分值之間的映射,字典中的鍵保存了成員,字典中的值保存了成員的分值,這樣定位元素時時間復雜度是 O(1)。

Zset 中的 zsl 跳躍表適合范圍操作,比如 ZRANK、ZRANGE 等,程序使用 zkiplist。

另外,雖然 Zset 中使用了 dict 和 skiplist 存儲數據,但這兩種數據結構都會通過指針來共享相同的內存,所以沒有必要擔心內存的浪費。

過期數據的刪除對 Redis 性能影響

當我們對某些 key 設置了 expire 時,數據到了時間會自動刪除。如果一個鍵過期了,它會在什么時候刪除呢?

下面介紹三種刪除策略:

  • 定時刪除:在這是鍵的過期時間的同時,創建一個定時器 Timer,讓定時器在鍵過期時間來臨時立即執行對過期鍵的刪除。
  • 惰性刪除:鍵過期后不管,每次讀取該鍵時,判斷該鍵是否過期,如果過期刪除該鍵返回空。
  • 定期刪除:每隔一段時間對數據庫中的過期鍵進行一次檢查。

定時刪除:對內存友好,對 CPU 不友好。如果過期刪除的鍵比較多的時候,刪除鍵這一行為會占用相當一部分 CPU 性能,會對 Redis 的吞吐量造成一定影響。

惰性刪除:對 CPU 友好,內存不友好。如果很多鍵過期了,但在將來很長一段時間內沒有很多客戶端訪問該鍵導致過期鍵不會被刪除,占用大量內存空間。

定期刪除:是定時刪除和惰性刪除的一種折中。每隔一段時間執行一次刪除過期鍵的操作,并且限制刪除操作執行的時長和頻率。

具體的操作如下:

  • Redis 會將每一個設置了 expire 的鍵存儲在一個獨立的字典中,以后會定時遍歷這個字典來刪除過期的 key。除了定時遍歷外,它還會使用惰性刪除策略來刪除過期的 key。
  • Redis 默認每秒進行十次過期掃描,過期掃描不會掃描所有過期字典中的 key,而是采用了一種簡單的貪心策略。

從過期字典中隨機選擇 20 個 key;刪除這 20 個 key 中已過期的 key;如果過期 key 比例超過 1/4,那就重復步驟 1。

  • 同時,為了保證在過期掃描期間不會出現過度循環,導致線程卡死,算法還增加了掃描時間上限,默認不會超過 25ms。

總結

總而言之,Redis 為了高性能,從各方各面都進行了優化,下次小伙伴們面試的時候,面試官問 Redis 性能為什么如此高,可不能傻傻的只說單線程和內存存儲了。



 

責任編輯:武曉燕 來源: 向代碼致敬
相關推薦

2023-03-21 08:02:36

Redis6.0IO多線程

2019-06-17 14:20:51

Redis數據庫Java

2022-01-04 08:54:32

Redis數據庫數據類型

2023-10-15 12:23:10

單線程Redis

2018-04-25 10:13:30

Redis內存模型

2019-05-07 09:44:45

Redis高并發模型

2020-06-11 09:35:39

Redis單線程Java

2020-10-30 16:20:38

Redis單線程高并發

2023-08-17 14:12:17

2020-11-09 09:33:37

多線程

2019-05-06 11:12:18

Redis高并發單線程

2019-04-02 11:20:48

Redis高并發單線程

2021-03-03 08:01:58

Redis多線程程序

2020-11-17 10:20:53

Redis多線程單線程

2025-06-17 00:22:00

2025-01-17 08:23:33

2023-08-29 07:46:08

Redis數據ReHash

2023-02-07 08:18:34

單線程Redis內存

2025-09-18 08:16:28

JavaScrip單線程Linux

2020-10-16 16:00:50

Redis單線程數據庫
點贊
收藏

51CTO技術棧公眾號

在线观看国产成人av片| 亚洲精品18在线观看| 福利片在线观看| 久久视频免费| 免费在线欧美黄色| 6080yy午夜一二三区久久| 国产免费一区二区| 国产午夜精品久久久久久久久| 色婷婷在线播放| 热久久一区二区| 亚洲成人精品在线| 中国人体摄影一区二区三区| 国产三级av片| 97青娱国产盛宴精品视频| 亚洲国产精品v| 日本精品免费观看| 日本不卡视频一区| h片在线播放| 免费精品99久久国产综合精品| 精品国产一区二区三区久久久蜜月 | 国产无套粉嫩白浆内谢| av日韩一区| 国产日韩欧美在线一区| 欧美中文字幕精品| 熟妇高潮精品一区二区三区| 高清电影在线免费观看| 国产一区二区免费视频| 中文字幕av一区中文字幕天堂| 欧美亚洲精品一区二区| 免费a视频在线观看| 欧美色图麻豆| 欧美一区二区三区视频| 日韩中文字幕亚洲精品欧美| 国产毛片在线视频| 久久中文视频| 欧美日韩成人高清| 影音先锋欧美资源| 日韩电影免费| 美女精品网站| 在线观看日韩视频| 亚洲av无码一区二区三区网址| 国产蜜臀在线| 亚洲品质自拍视频| 91久久精品www人人做人人爽 | 天天干天天曰天天操| 国产黄色在线观看| 国产农村妇女毛片精品久久麻豆| 国产精品久久久久久av下载红粉| a资源在线观看| 国产成人免费| 亚洲精品成人悠悠色影视| 91免费看国产| 国产在线观看成人| 在线中文一区| 日韩精品电影网| 国产97色在线 | 日韩| 午夜免费视频在线国产| 国产在线精品一区二区| 成人www视频在线观看| 国产极品美女高潮无套嗷嗷叫酒店| 91久久久精品国产| 欧美精品一区二区在线播放| 男人午夜视频在线观看| 丁香影院在线| 香蕉加勒比综合久久| 日本一区美女| 国产三级视频在线播放| 国内一区二区视频| 17婷婷久久www| 国产视频不卡在线| 日韩在线看片| 日韩精品视频在线播放| free性中国hd国语露脸| 国产欧美日韩一区二区三区四区| 日韩一区二区在线看片| 任你操这里只有精品| 九色porny在线| 久久综合久久鬼色中文字| 91精品久久久久久久久久久| 麻豆久久久久久久久久| 性欧美videos另类喷潮| 国产成人精品优优av| 久久伊人成人网| 欧美丝袜激情| 日韩成人免费视频| japanese中文字幕| 久久在线观看| 亚洲风情亚aⅴ在线发布| 欧美一区二区三区成人精品| 国产色99精品9i| 欧美午夜电影一区| 青青草国产精品视频| 国产婷婷视频在线| 亚洲第一主播视频| 久久久无码中文字幕久...| 在线网址91| 亚洲欧美影音先锋| 色999日韩自偷自拍美女| 色哟哟在线观看| 中文字幕国产一区二区| 久久久久久久香蕉| 在线国产情侣| 国产欧美日韩亚州综合| 妞干网这里只有精品| 五月天婷婷在线视频| 亚洲综合视频在线| 青青草综合视频| 原纱央莉成人av片| 亚洲午夜久久久久久久久久久| 综合久久国产| 波多野一区二区| 亚洲亚洲精品在线观看| 9久久婷婷国产综合精品性色| 亚洲性受xxx喷奶水| 91精品国产麻豆| www.色多多| 欧美1区2区3区| 久久中文字幕国产| 情侣偷拍对白清晰饥渴难耐| 久久99青青| 亚洲欧美视频在线| 欧美色图亚洲激情| 综合激情一区| 国产日韩av在线| 日韩av地址| 亚洲大片免费看| 免费不卡av网站| 久久神马影院| 国产精品久久久久久久久久免费 | 视频一区免费观看| 韩国精品一区| 精品国产乱码久久| 99热精品免费| 欧美精选一区| 91精品久久久久久久久久久久久| 看电影就来5566av视频在线播放| 久久久久高清精品| 亚洲国产精品一区二区第一页 | 制服丝袜日韩| 国产亚洲欧美aaaa| 亚洲欧洲综合网| 中文字幕日韩欧美精品高清在线| 国产精品美女免费视频| www.久久精品.com| www.66久久| 久久久久国产精品视频| 国产女人在线观看| 欧美日韩加勒比精品一区| 国产天堂在线播放| 网红女主播少妇精品视频| 一区二区在线视频| 波多野结衣大片| 国产一区二区h| 最新中文字幕久久| 欧美男男tv网站在线播放| 欧美色精品在线视频| 在线观看视频在线观看| 91精品国产自产在线观看永久∴| 久久久噜噜噜久久久| 99热国产在线观看| 日韩国产精品久久| 97碰碰视频| 国产丝袜精品丝袜| 亚洲国产欧美日韩精品| 激情高潮到大叫狂喷水| 久久精品国内一区二区三区| 国产精品国产三级欧美二区| 爱久久·www| 性欧美大战久久久久久久久| 亚洲视频在线播放免费| 亚洲理论电影网| av在线不卡观看| √新版天堂资源在线资源| 欧美日韩一区二区欧美激情| 国产97免费视频| 日韩电影在线一区二区三区| 亚洲春色在线视频| 伊人久久精品| 久久久欧美一区二区| 欧美日韩在线精品一区二区三区激情综| 在线视频亚洲一区| 日本黄色动态图| 日韩经典一区二区| 在线国产99| 红杏视频成人| 欧美日韩国产二区| 中文字幕在线播放av| 成人av电影在线| 少妇久久久久久被弄到高潮| 国产精品任我爽爆在线播放| 久久久精品电影| 亚洲天堂五月天| 99re在线视频这里只有精品| 日本大片免费看| 国产高清亚洲| 亚洲**2019国产| 国产福利资源在线| ...中文天堂在线一区| 极品白嫩少妇无套内谢| 亚洲天堂一区二区三区四区| 国产亚洲一区在线播放| 写真福利精品福利在线观看| 日韩高清中文字幕| 一二三四区在线| 国产精品亲子乱子伦xxxx裸| 色一情一乱一伦一区二区三区日本| 91一区二区三区四区| 国产亚洲情侣一区二区无 | 亚洲xxxx3d| 黄色网址在线免费观看| 精品视频偷偷看在线观看 | 在线一区二区视频| 久久久久久久中文字幕| 中文字幕高清不卡| 国产熟女高潮一区二区三区 | 欧美日韩亚洲精品内裤| 裸体武打性艳史| 国产精品拍天天在线| 国产呦小j女精品视频| 国产1区2区3区精品美女| 伊人婷婷久久| 国产探花一区二区| 国语精品中文字幕| 国产伦精品一区二区三区视频金莲| 久热国产精品视频| 91精彩在线视频| 亚洲精品视频免费在线观看| 蜜桃av鲁一鲁一鲁一鲁俄罗斯的| 91.com在线观看| 又色又爽又黄无遮挡的免费视频| 色综合欧美在线| 精品亚洲aⅴ无码一区二区三区| 高清不卡一二三区| 成人免费播放视频| 精品一区二区三区在线视频| 国产 国语对白 露脸| 精品欧美激情在线观看| 成人精品视频99在线观看免费| 黑人巨大亚洲一区二区久| 性欧美暴力猛交69hd| 日本中文字幕中出在线| 欧美裸体xxxx极品少妇| 羞羞网站在线看| 久热在线中文字幕色999舞| 麻豆网站在线看| 精品国产123| 亚洲国产成人一区二区| 欧美不卡一区二区三区四区| 中日韩黄色大片| 亚洲3atv精品一区二区三区| 国产第一页第二页| 亚洲福利电影网| 人人干人人干人人干| 精品色蜜蜜精品视频在线观看| 日韩免费黄色片| 狠狠躁夜夜躁人人爽天天天天97 | 美女网站在线免费欧美精品| 另类小说色综合| 激情91久久| 日本在线视频不卡| 97se亚洲国产一区二区三区| 官网99热精品| 成人精品动漫| 国产精品私拍pans大尺度在线| 91麻豆免费在线视频| 欧美大胆在线视频| 国产视频精选在线| 在线不卡国产精品| 麻豆电影在线播放| 色综合视频一区中文字幕| 国产精品四虎| xvideos亚洲人网站| 日本韩国精品一区二区| 亚洲色在线视频| 成人爽a毛片一区二区| 欧美性猛交xxxx黑人交| 91高潮大合集爽到抽搐| 婷婷综合另类小说色区| 黄色一级片中国| 午夜精品在线视频一区| 天天干天天操天天爱| 一区二区三区在线视频播放| 国产一级淫片a| 亚洲乱码日产精品bd| 国产女主播喷水高潮网红在线| 国产99久久久精品| 中文字幕在线播放视频| 欧美国产乱子伦| 劲爆欧美第一页| 中文字幕一区在线观看| 男人天堂av电影| 国产精品美女视频| 精品一区二区三区四| 91国偷自产一区二区三区成为亚洲经典| 国产精品suv一区二区| 一本大道综合伊人精品热热| 97人人爽人人爽人人爽| 91国内精品野花午夜精品| 国产免费一区二区三区最新不卡| 亚洲成人精品视频| 日本三级视频在线观看| 97精品免费视频| 成人在线啊v| 欧美日韩另类综合| 欧美欧美黄在线二区| 国产精品美女在线播放| 性欧美精品高清| 亚洲天堂一区二区在线观看| 久久久无码精品亚洲日韩按摩| 欧美三级在线免费观看| 欧美中文字幕一区二区三区亚洲| 超碰在线人人干| 中文字幕亚洲二区| 伊人成综合网站| 欧美一区二三区| 日韩电影免费看| 亚洲综合av影视| 色88久久久久高潮综合影院| 欧美日韩中文在线视频| 久久最新视频| 国产成人黄色网址| av不卡在线播放| 国产亚洲第一页| 欧美一区二区三区免费大片| av中文在线| 国产精品999| 亚洲警察之高压线| 免费看国产一级片| 成人三级在线视频| 久久国产精品影院| 午夜亚洲福利老司机| 午夜精品久久久久久久99| 久久韩国免费视频| 欧美高清xxx| 成人在线观看网址| 综合一区二区三区| 日本一二三四区视频| 国产精品久久久久久久第一福利| 日韩xxx视频| 91精品国产黑色紧身裤美女| 黄网站在线免费| 国产色视频一区| 天堂美国久久| 手机av在线网站| 一区二区三区小说| 性一交一乱一精一晶| 蜜臀久久99精品久久久无需会员 | 成人黄色国产精品网站大全在线免费观看 | 亚洲精品国产成人久久av盗摄 | 91性感美女视频| 成年人在线免费看片| 亚洲欧美国产77777| 国产精品久久欧美久久一区| 久久久成人av| 久久久久久久久久久久电影| 国产黄色激情视频| 国产91精品一区二区麻豆网站| 久久久.www| 亚洲福利视频二区| 综合日韩av| 翔田千里亚洲一二三区| 精品一区二区三区在线播放 | 日韩欧美在线观看| 国产又黄又猛又爽| 久久国产精品亚洲| 国产精品久久久久av蜜臀| 欧美成人高潮一二区在线看| 久久综合久久鬼色| 一区二区三区www污污污网站| 超在线视频97| 欧美有码在线| 一区在线电影| 国产91精品精华液一区二区三区 | 久久精品国产精品亚洲红杏| 暗呦丨小u女国产精品| 一本到不卡免费一区二区| 在线免费观看黄色网址| 成人av免费电影| 久久天堂成人| 成人免费视频网站入口::| 亚洲国产成人精品久久| 黄色精品视频| 六月婷婷久久| 亚洲毛片一区| 亚洲国产日韩在线一区| 午夜成人在线视频| av天在线观看| 国产乱码精品一区二区三区中文| 日韩综合一区二区| 精品爆乳一区二区三区无码av| 日韩精品极品毛片系列视频| 四虎精品永久免费| 日韩在线国产| 成人在线综合网| 欧美日韩 一区二区三区| 欧美老女人xx| 精品理论电影在线| 超碰caoprom| 777奇米四色成人影色区| 国产美女精品写真福利视频|