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

Redis是如何高效管理有限內存的?

數據庫 Redis
Redis并不支持按照TTI機制來做數據過期處理。但是作為補償,Redis提供了一個重新設定某個key值過期時間的方法,可以通過expire方法來實現指定key的續期操作,以一種曲線救國的方式滿足訴求。

過期刪除策略的深度剖析

Redis 可以對 key 設置過期時間的,為了防止過期的key長期占用內存,需要相應的過期刪除策略將過期的key刪除

基礎操作

Redis設置過期時間

  • setex key1 5 value1:創建記錄的時候指定過期時間,設置key1在5秒后過期

其實Redis這是一種基于創建時間來判定是否過期的機制,也即常規上說的TTL策略,當設定了過期時間之后不管有沒有被使用都會到期被強制清理掉。但有很多場景下也會期望數據能夠按照TTI(指定時間未使用再過期)的方式來過期清理,如用戶鑒權場景:

假設用戶登錄系統后生成token并存儲到Redis中,指定token有效期30分鐘,那么如果用戶一直在使用系統的時候突然時間到了然后退出要求重新登錄,這個體驗感就會很差。正確的預期應該是用戶連續操作的時候就不要退出登錄,只有連續30分鐘沒有操作的時候才過期處理。

略有遺憾的是,Redis并不支持按照TTI機制來做數據過期處理。但是作為補償,Redis提供了一個重新設定某個key值過期時間的方法,可以通過expire方法來實現指定key的續期操作,以一種曲線救國的方式滿足訴求。

實現緩存續期

  • expire <key> <n>:設置 key 在 n 秒后過期,比如 expire key 100 表示設置 key 在 100 秒后過期;
  • pexpire <key> <n>:設置 key 在 n 毫秒后過期,比如 pexpire key2 100000 表示設置 key2 在 100000 毫秒(100 秒)后過期。
  • expireat <key> <n>:設置 key 在某個時間戳(精確到秒)之后過期,比如 expireat key3 1683187646 表示 key3 在時間戳 1683187646 后過期(精確到秒);
  • pexpireat <key> <n>:設置 key 在某個時間戳(精確到毫秒)之后過期,比如 pexpireat key4 1683187660972 表示 key4 在時間戳 1683187660972 后過期(精確到毫秒)

對于上面說的用戶token續期的訴求,可以這樣來操作:

用戶首次登錄成功后,會生成一個token令牌,然后將令牌與用戶信息存儲到redis中,設定30分鐘有效期。 每次請求接口中攜帶token來鑒權,每次get請求的時候,就重新通過expire操作將token的過期時間重新設定為30分鐘。 持續30分鐘無請求后,此條token緩存信息過期失效。同樣實現了TTI的效果。

ttl查看過期時間

# 查看 key1 過期時間還剩多少
> ttl key
(integer) 56

# 取消 key 的過期時間
> persist key
(integer) 1

//永不過期返回-1
> ttl key
(integer) -1

如何判斷過期時間

typedef struct redisDb {
    dict *dict;                 /* The keyspace for this DB */
    dict *expires;              /* 鍵值對的過期時間 */
 //……
} redisDb;

dict是hash表

  • *dict是鍵值對,指向的是數據庫中保存的具體的key value對象,key是String類型,value是具體的數據類型
  • *expires是過期字典,key與*dict中的key一致,value則是一個 long long 類型的整數,這個整數保存了 key 的過期時間;

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

圖片圖片

簡單地總結來說就是,設置了失效時間的key和具體的失效時間全部都維護在 expires 這個字典表中。未設置失效時間的key不會出現在expires字典表中。

所以當查詢一個 key 時,Redis 首先檢查該 key 是否存在于expires過期字典中:

  1. 如果不在,則正常讀取鍵值;
  2. 如果存在,則會獲取該 key 的過期時間,然后與當前系統時間進行比對,如果比系統時間大,那就沒有過期,否則判定該 key 已過期。

過期刪除策略

定時刪除

在設置key的過期時間的同時,為該key創建一個定時器,讓定時器在key的過期時間來臨時,對key進行刪除。

優點:保證內存被盡快釋放,對內存友好

缺點:若過期key很多,刪除這些key會占用很多的CPU時間,在CPU時間緊張的情況下,CPU不能把所有的時間用來做要緊的事兒,還需要去花時間刪除這些key,定時器的創建耗時,若為每一個設置過期時間的key創建一個定時器(將會有大量的定時器產生),性能影響嚴重。對CPU不友好

結論:此方法基本上沒人用

惰性刪除

過期的key并不一定會馬上刪除,還會占用著內存。 當你真正查詢這個key時,redis會檢查一下,這個設置了過期時間的key是否過期了? 如果過期了就會刪除,返回空。這就是惰性刪除。

優點:刪除操作只發生在從數據庫取出key的時候發生,而且只刪除當前key,所以對CPU時間的占用是比較少的,對 CPU友好

缺點:若大量的key在超出超時時間后,很久一段時間內,都沒有被獲取過,那么可能發生內存泄露。對內存不友好

定期刪除

每隔一段時間,程序就對數據庫進行一次檢查,刪除里面的過期鍵,至于要刪除多少過期鍵,以及要檢查多少個數據庫,由算法決定

優點:通過限制刪除操作執行的時長和頻率,來減少刪除操作對 CPU 的影響,同時也能刪除一部分過期的數據減少了過期鍵對空間的無效占用。

缺點:

  • 內存清理方面沒有定時刪除效果好,同時沒有惰性刪除使用的系統資源少。
  • 難以確定刪除操作執行的時長和頻率。如果執行的太頻繁,定期刪除策略變得和定時刪除策略一樣,對CPU不友好;如果執行的太少,那又和惰性刪除一樣了,過期 key 占用的內存不能及時得到釋放

Redis的過期刪除策略

redis實際使用的過期鍵刪除策略是定期刪除策略惰性刪除策略

  • 定期刪除策略:redis 會將每個設置了過期時間的 key 放入到一個獨立的字典中,以后會定時遍歷這個字典來刪除到期的 key。
  • 惰性刪除策略:只有當訪問某個key時,才判斷這個key是否已過期,如果已經過期,則從實例中刪除

定時刪除是集中處理,惰性刪除是零散處理。

定期刪除策略

Redis內部維護一個定時任務,默認每秒進行10次(也就是每隔100毫秒一次)過期掃描,過期掃描不會遍歷過期字典中所有的 key,而是采用了一種簡單的貪心策略。

  1. 從過期字典中隨機取出20個key
  2. 刪除這 20 個 key 中已經過期的 key;
  3. 如果這20個key中過期key的比例超過了25%,則重復步驟1

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

為什么key集中過期時,其它key的讀寫效率會降低?

Redis的定期刪除策略是在Redis主線程中執行的,也就是說如果在執行定期刪除的過程中,出現了需要大量刪除過期key的情況,那么在業務訪問時,必須等這個定期刪除任務執行結束,才可以處理業務請求。此時就會出現,業務訪問延時增大的問題,最大延遲為25毫秒。

為了盡量避免這個問題,在設置過期時間時,可以給過期時間設置一個隨機范圍,避免同一時刻過期。

惰性刪除策略

int expireIfNeeded(redisDb *db, robj *key, int flags) {
 //檢查是否開啟惰性刪除策略
    if (server.lazy_expire_disabled) return 0;
    if (!keyIsExpired(db,key)) return 0;//檢查key是否過期,沒過期不用刪除
 
 //……
 
    //刪除失效key
    deleteExpiredKeyAndPropagate(db,key);
    return 1;
}

int keyIsExpired(redisDb *db, robj *key) {
    //假如Redis服務器正在從RDB文件中加載數據,暫時不進行失效主鍵的刪除,直接返回0
    if (server.loading) return 0;
 
 //獲取主鍵的失效時間 get當前時間-創建時間>ttl
    mstime_t when = getExpire(db,key);
    mstime_t now;
 
 //假如失效時間為負數,說明該主鍵未設置失效時間(失效時間默認為-1),直接返回0 
    if (when < 0) return 0; /* No expire for this key */

    now = commandTimeSnapshot();

    //如果以上條件都不滿足,就將主鍵的失效時間與當前時間進行對比,如果發現指定的key還未失效就返回0
    return now > when;
}

過期key對持久化的影響

RDB:

  • 生成rdb文件:生成時,程序會對key進行檢查,過期key不放入rdb文件。
  • 載入rdb文件:載入時,如果以主服務器模式運行,程序會對文件中保存的key進行檢查,未過期的key會被載入到數據庫中,而過期key則會忽略;如果以從服務器模式運行,無論鍵過期與否,均會載入數據庫中,過期key會通過與主服務器同步而刪除。

AOF:

  • 當服務器以AOF持久化模式運行時,如果數據庫中的某個key已經過期,但它還沒有被惰性刪除或者定期刪除,那么AOF文件不會因為這個過期key而產生任何影響
  • 當過期key被惰性刪除或者定期刪除之后,程序會向AOF文件追加一條DEL命令,來顯示的記錄被該key已經發被刪除
  • 在執行AOF重寫的過程中,程序會對數據庫中的key進行檢查,已過期的key不會被保存到重寫后的AOF文件中

主從復制:當服務器運行在復制模式下時,從服務器的過期刪除動作由主服務器控制:

  • 主服務器在刪除一個過期key后,會顯式地向所有從服務器發送一個del命令,告知從服務器刪除這個過期key;
  • 從服務器在執行客戶端發送的讀命令時,即使碰到過期key也不會將過期key刪除,而是繼續像處理未過期的key一樣來處理過期key;
  • 從服務器只有在接到主服務器發來的del命令后,才會刪除過期key。

內存淘汰策略

過期刪除策略,是刪除已過期的 key,而當 Redis 的運行內存已經超過 Redis 設置的最大內存之后,則會使用內存淘汰策略刪除符合條件的 key,以此來保障 Redis 高效的運行。這兩個機制雖然都是做刪除的操作,但是觸發的條件和使用的策略都是不同的。

  • 數據過期,是符合業務預期的一種數據刪除機制,為記錄設定過期時間,過期后從緩存中移除。
  • 數據淘汰,是一種“有損自保”的降級策略,是業務預期之外的一種數據刪除手段。指的是所存儲的數據沒達到過期時間,但緩存空間滿了,對于新的數據想要加入內存時,為了避免OOM而需要執行的一種應對策略。

基礎操作

設置 Redis 最大運行內存

在配置文件redis.conf 中,可以通過參數 maxmemory <bytes> 來設定最大內存,當數據內存達到 maxmemory 時,便會觸發redis的內存淘汰策略

不進行數據淘汰

noeviction:不會淘汰任何數據。

當使用的內存空間超過 maxmemory 值時,也不會淘汰任何數據,但是再有寫請求時,則返回OOM錯誤。

進行數據淘汰

  • volatile-lru:針對設置了過期時間的key,使用lru算法進行淘汰。
  • allkeys-lru:針對所有key使用lru算法進行淘汰。
  • volatile-lfu:針對設置了過期時間的key,使用lfu算法進行淘汰。
  • allkeys-lfu:針對所有key使用lfu算法進行淘汰。
  • volatile-random:針對設置了過期時間的key中使用隨機淘汰的方式進行淘汰。
  • allkeys-random:針對所有key使用隨機淘汰機制進行淘汰。
  • volatile-ttl:針對設置了過期時間的key,越早過期的越先被淘汰。

Redis對隨機淘汰和LRU策略進行的更精細化的實現,支持將淘汰目標范圍細分為全部數據和設有過期時間的數據,這種策略相對更為合理一些。因為一般設置了過期時間的數據,本身就具備可刪除性,將其直接淘汰對業務不會有邏輯上的影響;而沒有設置過期時間的數據,通常是要求常駐內存的,往往是一些配置數據或者是一些需要當做白名單含義使用的數據(比如用戶信息,如果用戶信息不在緩存里,則說明用戶不存在),這種如果強行將其刪除,可能會造成業務層面的一些邏輯異常。

Redis的內存淘汰算法

操作系統本身有其內存淘汰算法,針對內存頁面淘汰,詳情請看 內存的頁面置換算法[1]

LRU 算法

LRU( Least Recently Used,最近最少使用)淘汰算法:是一種常用的頁面置換算法,也就是說最久沒有使用的緩存將會被淘汰。

傳統的LRU 是基于鏈表結構實現的,鏈表中的元素按照操作順序從前往后排列,最新操作的key會被移動到表頭,當需要進行內存淘汰時,只需要刪除鏈表尾部的元素即可,因為鏈表尾部的元素就代表最久未被使用的元素。

但是傳統的LRU算法存在兩個問題:

  • 需要用鏈表管理所有的緩存數據,這會帶來額外的空間開銷;
  • 當有數據被訪問時,需要在鏈表上把該數據移動到頭端,如果有大量數據被訪問,就會帶來很多鏈表元素的移動操作,會很耗時,進而會降低 Redis 緩存性能。

Redis 使用的是一種近似 LRU 算法,目的是為了更好的節約內存,它的實現方式是給現有的數據結構添加一個額外的字段,用于記錄此key的最后一次訪問時間。Redis 內存淘汰時,會使用隨機采樣的方式來淘汰數據,它是隨機取 5 個值 (此值可配置) ,然后淘汰一個最少訪問的key,之后把剩下的key暫存到一個池子中,繼續隨機取出一批key,并與之前池子中的key比較,再淘汰一個最少訪問的key。以此循環,直到內存降到maxmemory之下。

struct redisObject {
    unsigned type:4;
    unsigned encoding:4;
    unsigned lru:LRU_BITS; //記錄 Key 的最后被訪問時間
    int refcount;
    void *ptr;
};

在 LRU 算法中,Redis 對象頭的 24 bits 的 lru 字段是用來記錄 key 的訪問時間戳,因此在 LRU 模式下,Redis可以根據對象頭中的 lru 字段記錄的值,來比較最后一次 key 的訪問時間長,從而淘汰最久未被使用的 key。

但是 LRU 算法有一個問題,無法解決緩存污染問題,比如應用一次讀取了大量的數據,而這些數據只會被讀取這一次,那么這些數據會留存在 Redis 緩存中很長一段時間,造成緩存污染。Redis利用LFU解決這個問題

LFU 算法

最不常用的算法是根據總訪問次數來淘汰數據的,它的核心思想是“如果數據過去被訪問多次,那么將來被訪問的頻率也更高”。

Redis 的 LFU 算法也是通過 robj 對象的 lru 字段來保存 Key 的訪問頻率的,LFU 算法把  lru 字段分為兩部分,如下圖:

圖片圖片

  • 0 ~ 7 位:用于保存 Key 的訪問頻率計數器。
  • 8 ~ 23 位:用于保存當前時間(以分鐘計算)。

由于訪問頻率計數器只有8個位,所以取值范圍為 0 ~ 255,如果每訪問 Key 都增加 1,那么很快就用完,LFU 算法也就不起效果了。所以 Redis 使用了一種比較復雜的算法了計算訪問頻率,算法如下:

  1. 先按照上次訪問距離當前的時長,來對 logc 進行衰減;
  2. 然后,再按照一定概率增加 logc 的值

具體為:

  1. 在每次 key 被訪問時,會先對 訪問頻率 做一個衰減操作,衰減的值跟前后訪問時間的差距有關系,如果上一次訪問的時間與這一次訪問的時間差距很大,那么衰減的值就越大,這樣實現的 LFU 算法是根據訪問頻率來淘汰數據的,而不只是訪問次數。訪問頻率需要考慮 key 的訪問是多長時間段內發生的。key 的先前訪問距離當前時間越長,那么這個 key 的訪問頻率相應地也就會降低,這樣被淘汰的概率也會更大。
  2. 對 訪問頻率 做完衰減操作后,就開始對 訪問頻率 進行增加操作,增加操作并不是單純的 + 1,而是根據概率增加,如果 訪問頻率 越大的 key,它的 訪問頻率 就越難再增加。

訪問頻率衰減算法:原理就是,Key 越久沒被訪問,衰減的程度就越大。

unsigned long LFUDecrAndReturn(robj *o) {
    unsigned long ldt = o->lru >> 8;// 獲取 Key 最后訪問時間(單位為分鐘)
    unsigned long counter = o->lru & 255;// 獲取 Key 訪問頻率計數器的值
 // 下面是計算要衰減的數量
 // LFUTimeElapsed 函數用于獲取 Key 沒被訪問的時間(單位為分鐘)
  // lfu_decay_time 是衰減的力度,通過配置項 lfu-decay-time 設置,值越大,衰減力度越小
    unsigned long num_periods = server.lfu_decay_time ? LFUTimeElapsed(ldt) / server.lfu_decay_time : 0;
 // 對訪問頻率計數器進行衰減操作
    if (num_periods)
        counter = (num_periods > counter) ? 0 : counter - num_periods;
    return counter;
}

從 LFUDecrAndReturn 函數可知,lfu-decay-time 設置越大,衰減的力度就越小。如果 lfu-decay-time 設置為1,并且 Key 在 10 分鐘內沒被訪問的話,按算法可知,訪問頻率計數器就會被衰減10。

訪問頻率增加算法:

uint8_t LFULogIncr(uint8_t counter) {
    if (counter == 255) return 255;
    double r = (double)rand()/RAND_MAX;// 獲取隨機數r
    double baseval = counter - LFU_INIT_VAL;// 計數器舊值
    if (baseval < 0) baseval = 0;
    double p = 1.0/(baseval*server.lfu_log_factor+1);// 根據計數器舊值與影響因子來計算出p
    if (r < p) counter++;// 如果 p 大于 r, 那么對計數器進行加以操作
    return counter;
}

LFU 算法更新 lru 字段和LRU 算法更新lru字段都是在 lookupKey 函數中完成的

robj *lookupKey(redisDb *db, robj *key, int flags) {
    dictEntry *de = dictFind(db->dict,key->ptr);
    robj *val = NULL;
    if (de) {
        val = dictGetVal(de);
       //……
    }

    if (val) {
       //……
        if (!hasActiveChildProcess() && !(flags & LOOKUP_NOTOUCH)){
            if (server.maxmemory_policy & MAXMEMORY_FLAG_LFU) {// 如果配置的是LFU淘汰算法
                updateLFU(val);// 更新LFU算法的統計信息
            } else {// 如果配置的是LRU淘汰算法
                val->lru = LRU_CLOCK();// 更新 Key 最后被訪問時間
            }
        }

       //……
    } else {
        //……
    }

    return val;
}

參考資料

[1] 內存的頁面置換算法: https://www.seven97.top/cs-basics/operating-system/memorypagereplacementalgorithm.html

責任編輯:武曉燕 來源: SevenCoding
相關推薦

2020-07-28 08:10:33

Linux內存虛擬

2023-10-16 23:57:35

Redis內存

2019-08-19 08:01:50

Flink數據管理內存

2024-12-31 00:00:15

2025-05-30 01:55:00

go語言Redis

2020-09-17 11:19:39

Linux 系統 數據

2025-09-18 09:17:46

2025-03-26 00:00:05

2025-04-15 06:00:00

2023-11-19 22:31:00

內存程序

2024-12-11 08:18:11

2019-09-24 08:56:00

內存Redis使用

2019-07-10 05:08:05

CPU內存分頁管理

2018-12-06 12:58:50

CPU內存模塊

2019-06-24 19:00:09

JavaScript內存泄漏垃圾回收

2024-09-09 09:41:03

內存溢出golang開發者

2016-12-12 16:17:22

華為

2025-03-03 10:42:50

深度學習PyTorch大型語言模型

2012-07-31 09:55:50

時間管理管理

2024-12-26 10:45:08

點贊
收藏

51CTO技術棧公眾號

精品素人av| 水莓100国产免费av在线播放| 日韩成人免费| 日韩亚洲欧美一区| av免费观看大全| 国产大学生校花援交在线播放| 美女视频一区二区三区| 欧美成人免费va影院高清| 性欧美丰满熟妇xxxx性久久久| 女海盗2成人h版中文字幕| 中文字幕第一区| 国产精品美女诱惑| 中文字幕免费在线看| 国产精品hd| 综合av色偷偷网| 一边摸一边做爽的视频17国产| **欧美日韩在线观看| 一区二区三区欧美激情| 日韩免费三级| 日本激情视频网站| 韩国av一区二区三区| 欧洲永久精品大片ww免费漫画| 香蕉成人在线视频| 全球av集中精品导航福利| 91精品在线一区二区| 国产精品欧美激情在线观看| 青春草视频在线观看| 国产精品五月天| 久久久久资源| 亚洲精品久久久蜜桃动漫| 久久国产精品色婷婷| 热99精品里视频精品| 久久久久成人网站| 久久综合99| 亚洲人av在线影院| 小毛片在线观看| 日韩三级久久| 欧美福利视频导航| 欧美一级裸体视频| 丝袜诱惑一区二区| 亚洲二区在线视频| 黄色成人在线免费观看| 成人影院www在线观看| 国产精品女人毛片| 日韩av在线一区二区三区| 亚洲aⅴ乱码精品成人区| 丰满放荡岳乱妇91ww| **亚洲第一综合导航网站| 一区二区三区免费在线| 免费在线观看精品| 国产精品专区第二| 亚洲一区二区激情| 久久精品国产99久久6| 国产精品美女免费视频| 中文字幕永久在线| 免费成人在线视频观看| 国产日韩精品在线播放| 国产又粗又大又爽视频| 久久精品国产精品亚洲综合| 国产日本欧美一区二区三区在线| 在线观看国产精品视频| 久久成人精品无人区| 成人h视频在线| 国产剧情久久久| 国产精品99久久久久久宅男| 国产精品自产拍高潮在线观看| 中文文字幕一区二区三三| 青青草精品视频| 国产精品嫩草视频| 一二三四区在线| 国产精品资源在线看| av一区和二区| 天天操天天干天天操| 久久综合久色欧美综合狠狠| 日韩av一区二区三区美女毛片| 啊v视频在线| 综合亚洲深深色噜噜狠狠网站| 免费成人进口网站| 久久www人成免费看片中文| 亚洲国产欧美在线人成| www国产黄色| 国产a亚洲精品| 日韩一级二级三级精品视频| 中文字幕在线国产| 日韩在线黄色| 最近2019年中文视频免费在线观看 | 乱老熟女一区二区三区| 欧美激情五月| 国产成人91久久精品| 国产又大又黑又粗| av亚洲精华国产精华| 日韩欧美三级电影| 亚洲男同gay网站| 日韩人体视频一二区| 污污视频网站在线| 色爱av综合网| 超碰日本道色综合久久综合| 国产精品黄色大片| 黑人巨大精品欧美黑白配亚洲| 国产精品18毛片一区二区| 精品亚洲成a人片在线观看| 亚洲人精品一区| www.com毛片| 激情视频亚洲| 中文字幕av日韩| 中文在线观看免费网站| 精品一区二区三区在线观看 | 免费人成在线观看网站| 亚洲欧美电影一区二区| 久久免费精品国产久精品久久久久| 欧美久久精品一级c片| 中文字幕亚洲无线码a| 久久网一区二区| 理论片日本一区| 久久久久成人精品免费播放动漫| 日本在线免费播放| 欧美网站在线观看| 波多野结衣中文字幕在线播放| 网友自拍一区| 欧美国产日韩视频| 国产一区二区视频免费观看| 久久久国产精华| 熟女少妇在线视频播放| 九九九九九九精品任你躁| 亚洲天堂免费观看| 午夜精品三级久久久有码| 国产一区二区三区免费看| 日韩精品久久一区二区三区| 国产理论在线| 欧美精品一区二区不卡 | 国产精品17p| 欧美床上激情在线观看| 伊人精品一区二区三区| 久久精品欧美一区二区三区麻豆 | 日韩综合一区二区| 久久精品国产美女| www.综合网.com| 3d成人动漫网站| 久久爱一区二区| 免费成人av资源网| 欧美日韩免费高清| 中文字幕21页在线看| 亚洲第一区在线观看| 黄色一级片中国| 国产美女精品一区二区三区| 中文字幕一区二区三区四区五区| 精品久久在线| 日韩在线播放视频| 国产一区二区三区黄片| 亚洲男同性恋视频| 欧美成人手机在线视频| 亚洲成人tv| 114国产精品久久免费观看| 国产三级在线播放| 欧美一级爆毛片| 免费日韩在线视频| 激情综合网激情| 男同互操gay射视频在线看| 精品91福利视频| 欧美精品在线免费观看| 女人18毛片水真多18精品| 亚洲成av人片在线| 亚洲永久无码7777kkk| 羞羞答答国产精品www一本| 欧美一区二区三区四区五区六区| 免费日韩电影| 日韩亚洲综合在线| www.我爱av| 午夜精品一区二区三区三上悠亚| 亚洲欧美日本一区| 视频一区二区三区中文字幕| 亚洲精品欧美精品| 久久久久久爱| 7777免费精品视频| 韩国三级在线观看久| 欧美日韩免费一区二区三区| 99久久久免费精品| 成人免费观看视频| 久久综合久久色| 亚洲成av人片一区二区密柚| 国产乱码精品一区二区三区卡| 正在播放日韩精品| 色综合伊人色综合网站| 亚洲AV无码一区二区三区性| 欧美日韩激情小视频| 免费视频91蜜桃| 国产丶欧美丶日本不卡视频| 人妻精品无码一区二区三区 | 欧美日韩黄色一级片| 精品国产一区二区三区久久久樱花 | 久久成人这里只有精品| 五月天福利视频| 欧美日韩激情一区| 国产精品2020| 国产精品私人影院| 天天躁日日躁狠狠躁免费麻豆| 久久久国产精品一区二区中文| 日本成人性视频| 亚洲图区在线| 99re视频在线| 成人国产精品一区二区免费麻豆| 欧美激情网友自拍| 97在线观看免费观看高清 | 欧美午夜片在线观看| 妺妺窝人体色www婷婷| 久久一夜天堂av一区二区三区| 天堂av手机在线| 丝瓜av网站精品一区二区| 小泽玛利亚av在线| 欧美精选视频在线观看| 精品91免费| 亚洲大奶少妇| 国产主播精品在线| 欧美xx视频| 欧美性受xxxx白人性爽| 宅男网站在线免费观看| 一本一道久久a久久精品逆3p| 狠狠人妻久久久久久综合麻豆| 欧美色综合影院| 亚洲欧美一二三区| 精品久久久久久久大神国产| 男女性高潮免费网站| 欧美经典一区二区| 免费成人深夜夜行p站| 国产成人久久精品77777最新版本| 亚洲色图 在线视频| 久久一二三区| 你懂的av在线| 一区二区自拍| 日本黄色片一级片| 欧美 日韩 国产精品免费观看| 日韩精品欧美专区| 欧美欧美黄在线二区| 精品高清视频| 加勒比中文字幕精品| 成人羞羞视频免费| 欧美第一在线视频| 91久久国产精品| 亚洲综合资源| 成人亚洲欧美一区二区三区| 国产精品蜜月aⅴ在线| 国产精品高潮视频| 国产成人精品亚洲日本在线观看| 欧美壮男野外gaytube| 午夜激情在线播放| 青青草原成人在线视频| 一区一区三区| 国产精品mp4| 日本成人福利| 国产欧美日韩视频| 日日夜夜亚洲| 亚洲伊人久久大香线蕉av| 国产精品3区| 超碰97在线播放| 懂色av一区二区| 精品亚洲欧美日韩| 蜜臀91精品国产高清在线观看| 欧洲av一区| 成人在线免费观看视频| 亚洲一区二区四区| 久久久国产精品| 成人免费看片'免费看| 伊人久久大香线蕉综合热线| 久久视频这里有精品| 中文精品在线| 欧美精品成人网| 精品一区二区三区欧美| 久久黄色一级视频| 99riav久久精品riav| 免费看黄色的视频| 中文字幕在线不卡| 久久99久久久| 精品国产乱码久久久久久虫虫漫画| 国产一级片毛片| 欧美色图在线观看| h片在线免费看| 亚洲激情在线观看视频免费| 精品推荐蜜桃传媒| 久久精品国产亚洲| 激情av在线播放| 日本成人黄色片| 北岛玲精品视频在线观看| 国产精品亚洲一区| 精品久久精品| www国产无套内射com| 久久激情视频| 1314成人网| 久久午夜羞羞影院免费观看| 天天做夜夜爱爱爱| 精品久久久久久久久久久久久| 在线视频精品免费| 精品国产乱码久久久久久久| 国产小视频在线| 欧美大秀在线观看| 在线观看精品| 999日本视频| 国产探花一区在线观看| 一级性生活视频| 日韩avvvv在线播放| av av在线| 国产精品久久久久久亚洲毛片| 日韩高清精品免费观看| 欧美日韩久久一区二区| 亚洲三区在线观看无套内射| 久久在精品线影院精品国产| 日本综合字幕| 国产精品免费一区二区三区在线观看| 欧美一区二区三区激情视频| 黄色www网站| 国产成人在线影院| 日韩视频在线观看免费视频| 亚洲va欧美va国产va天堂影院| 在线免费看91| 亚洲欧洲一区二区三区在线观看| 日本小视频在线免费观看| 国产视频福利一区| 久久99高清| 亚洲国产成人精品无码区99| 国产乱子伦一区二区三区国色天香 | 精品国产一区二| 日本一区二区三区视频免费看| 亚洲三级国产| 在线中文字日产幕| 亚洲天堂精品在线观看| 一区二区视频网| 亚洲美女精品久久| 成年人在线网站| 国产一区二区精品免费| 欧美日韩三级电影在线| 亚洲精品乱码久久久久久动漫| 国产欧美日韩精品在线| 天天干天天色综合| 国产网站欧美日韩免费精品在线观看| 免费污视频在线| 97人人做人人人难人人做| 亚洲mv大片欧洲mv大片| 午夜啪啪小视频| 中文字幕五月欧美| 中文字幕在线播放不卡| 一区二区三区在线播放欧美| 欧美人体一区二区三区| 欧美成人dvd在线视频| 国产亚洲毛片| 国产男女猛烈无遮挡a片漫画 | 国产欧美一区二区精品久导航| 国产专区第一页| 亚洲美女av在线播放| 伊人久久在线| 日本婷婷久久久久久久久一区二区| 国产亚洲精品v| 亚洲女优在线观看| 欧美午夜一区二区三区| 日本在线看片免费人成视1000| 国产又爽又黄的激情精品视频| 91蜜臀精品国产自偷在线| 污污的网站免费| 亚洲视频在线一区观看| 国产后入清纯学生妹| 欧美日韩电影在线观看| 哺乳挤奶一区二区三区免费看| 国产高清av在线播放| 97精品国产露脸对白| 久久99国产综合精品免费| 国产一区二区日韩| 91国产精品| 国产九色porny| 91啪九色porn原创视频在线观看| 免费视频久久久| 中文字幕亚洲一区| 久久免费精品| 青青草成人免费在线视频| 久久久久国色av免费看影院| 中文字幕a级片| 美女福利视频一区| 秋霞在线一区| 麻豆三级在线观看| 一区二区三区成人| 日本福利午夜视频在线| 国产精品偷伦免费视频观看的| 1024精品久久久久久久久| 你懂的在线观看网站| 91国内精品野花午夜精品| 黄色成年人视频在线观看| 国产综合第一页| 美女mm1313爽爽久久久蜜臀| 欧美人妻一区二区| 亚洲欧美日韩精品| 91麻豆精品一二三区在线| 日本中文字幕网址| 国产精品女同一区二区三区| 国产 日韩 欧美 精品| 国产成人在线亚洲欧美| 欧美日韩ab| 中文字幕av久久爽一区| 日韩三级.com| 日本欧美一区| 国产在线播放观看| 国产精品欧美经典| 丝袜视频国产在线播放| 91中文在线观看|