成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > Redis延遲隊列和分布式延遲隊列的簡答實現(xiàn)

Redis延遲隊列和分布式延遲隊列的簡答實現(xiàn)

熱門標簽:魔獸2青云地圖標注 日本中國地圖標注 貴州電銷卡外呼系統(tǒng) 鄭州人工智能電銷機器人系統(tǒng) 十堰營銷電銷機器人哪家便宜 山東外呼銷售系統(tǒng)招商 超呼電話機器人 北京400電話辦理收費標準 宿遷便宜外呼系統(tǒng)平臺

        最近,又重新學習了下Redis,Redis不僅能快還能慢,簡直利器,今天就為大家介紹一下Redis延遲隊列和分布式延遲隊列的簡單實現(xiàn)。

  在我們的工作中,很多地方使用延遲隊列,比如訂單到期沒有付款取消訂單,制訂一個提醒的任務(wù)等都需要延遲隊列,那么我們需要實現(xiàn)延遲隊列。我們本文的梗概如下,同學們可以選擇性閱讀。

1. 實現(xiàn)一個簡單的延遲隊列。

  我們知道目前JAVA可以有DelayedQueue,我們首先開一個DelayQueue的結(jié)構(gòu)類圖。DelayQueue實現(xiàn)了Delay、BlockingQueue接口。也就是DelayQueue是一種阻塞隊列。

  我們在看一下Delay的類圖。Delayed接口也實現(xiàn)了Comparable接口,也就是我們使用Delayed的時候需要實現(xiàn)CompareTo方法。因為隊列中的數(shù)據(jù)需要排一下先后,根據(jù)我們自己的實現(xiàn)。Delayed接口里邊有一個方法就是getDelay方法,用于獲取延遲時間,判斷是否時間已經(jīng)到了延遲的時間,如果到了延遲的時間就可以從隊列里邊獲取了。

  我們創(chuàng)建一個Message類,實現(xiàn)了Delayed接口,我們主要把getDelay和compareTo進行實現(xiàn)。在Message的構(gòu)造方法的地方傳入延遲的時間,單位是毫秒,計算好觸發(fā)時間fireTime。同時按照延遲時間的升序進行排序。我重寫了里邊的toString方法,用于將Message按照我寫的方法進行輸出。

package com.hqs.delayQueue.bean;

import java.util.concurrent.BlockingQueue;
import java.util.concurrent.DelayQueue;
import java.util.concurrent.Delayed;
import java.util.concurrent.TimeUnit;

/**
 * @author huangqingshi
 * @Date 2020-04-18
 */
public class Message implements Delayed {

    private String body;
    private long fireTime;

    public String getBody() {
        return body;
    }

    public long getFireTime() {
        return fireTime;
    }

    public Message(String body, long delayTime) {
        this.body = body;
        this.fireTime = delayTime + System.currentTimeMillis();
    }

    public long getDelay(TimeUnit unit) {

        return unit.convert(this.fireTime - System.currentTimeMillis(), TimeUnit.MILLISECONDS);
    }

    public int compareTo(Delayed o) {
        return (int) (this.getDelay(TimeUnit.MILLISECONDS) -o.getDelay(TimeUnit.MILLISECONDS));
    }

    @Override
    public String toString() {
        return System.currentTimeMillis() + ":" + body;
    }

    public static void main(String[] args) throws InterruptedException {
        System.out.println(System.currentTimeMillis() + ":start");
        BlockingQueueMessage> queue = new DelayQueue>();
        Message message1 = new Message("hello", 1000 * 5L);
        Message message2 = new Message("world", 1000 * 7L);

        queue.put(message1);
        queue.put(message2);

        while (queue.size() > 0) {
            System.out.println(queue.take());
        }
    }
}

  里邊的main方法里邊聲明了兩個Message,一個延遲5秒,一個延遲7秒,時間到了之后會將接取出并且打印。輸出的結(jié)果如下,正是我們所期望的。

1587218430786:start
1587218435789:hello
1587218437793:world

  這個方法實現(xiàn)起來真的非常簡單。但是缺點也是很明顯的,就是數(shù)據(jù)在內(nèi)存里邊,數(shù)據(jù)比較容易丟失。那么我們需要采用Redis實現(xiàn)分布式的任務(wù)處理。

  2. 使用Redis的list實現(xiàn)分布式延遲隊列。

  本地需要安裝一個Redis,我自己是使用Docker構(gòu)建一個Redis,非??焖?,命令也沒多少。我們直接啟動Redis并且暴露6379端口。進入之后直接使用客戶端命令即可查看和調(diào)試數(shù)據(jù)。

docker pull redis
docker run -itd --name redisLocal -p 6379:6379 redis
docker exec -it redisLocal /bin/bash
redis-cli

  我本地采用spring-boot的方式連接redis,pom文件列一下,供大家參考。

?xml version="1.0" encoding="UTF-8"?>
project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    modelVersion>4.0.0/modelVersion>
    parent>
        groupId>org.springframework.boot/groupId>
        artifactId>spring-boot-starter-parent/artifactId>
        version>2.2.6.RELEASE/version>
        relativePath/> !-- lookup parent from repository -->
    /parent>
    groupId>com.hqs/groupId>
    artifactId>delayQueue/artifactId>
    version>0.0.1-SNAPSHOT/version>
    name>delayQueue/name>
    description>Demo project for Spring Boot/description>

    properties>
        java.version>1.8/java.version>
    /properties>

    dependencies>
        dependency>
            groupId>org.springframework.boot/groupId>
            artifactId>spring-boot-starter/artifactId>
        /dependency>

        dependency>
            groupId>org.springframework.boot/groupId>
            artifactId>spring-boot-starter-test/artifactId>
            scope>test/scope>
            exclusions>
                exclusion>
                    groupId>org.junit.vintage/groupId>
                    artifactId>junit-vintage-engine/artifactId>
                /exclusion>
            /exclusions>
        /dependency>
        dependency>
            groupId>org.springframework.boot/groupId>
            artifactId>spring-boot-starter-data-redis/artifactId>
        /dependency>
        dependency>
            groupId>org.springframework.boot/groupId>
            artifactId>spring-boot-starter-web/artifactId>
        /dependency>
        dependency>
            groupId>redis.clients/groupId>
            artifactId>jedis/artifactId>
            version>2.9.0/version>
        /dependency>
        dependency>
            groupId>org.springframework.boot/groupId>
            artifactId>spring-boot-devtools/artifactId>
            scope>runtime/scope>
        /dependency>
        dependency>
            groupId>org.projectlombok/groupId>
            artifactId>lombok/artifactId>
            optional>true/optional>
        /dependency>
    /dependencies>

    build>
        plugins>
            plugin>
                groupId>org.springframework.boot/groupId>
                artifactId>spring-boot-maven-plugin/artifactId>
            /plugin>
        /plugins>
    /build>

/project>

  加上Redis的配置放到application.properties里邊即可實現(xiàn)Redis連接,非常的方便。

# redis
redis.host=127.0.0.1
redis.port=6379
redis.password=
redis.maxIdle=100
redis.maxTotal=300
redis.maxWait=10000
redis.testOnBorrow=true
redis.timeout=100000

  接下來實現(xiàn)一個基于Redis的list數(shù)據(jù)類型進行實現(xiàn)的一個類。我們使用RedisTemplate操作Redis,這個里邊封裝好我們所需要的Redis的一些方法,用起來非常方便。這個類允許延遲任務(wù)做多有10W個,也是避免數(shù)據(jù)量過大對Redis造成影響。如果在線上使用的時候也需要考慮延遲任務(wù)的多少。太多幾百萬幾千萬的時候可能數(shù)據(jù)量非常大,我們需要計算Redis的空間是否夠。這個代碼也是非常的簡單,一個用于存放需要延遲的消息,采用offer的方法。另外一個是啟動一個線程, 如果消息時間到了,那么就將數(shù)據(jù)lpush到Redis里邊。

package com.hqs.delayQueue.cache;

import com.hqs.delayQueue.bean.Message;
import lombok.extern.slf4j.Slf4j;
import org.springframework.data.redis.core.RedisTemplate;

import java.util.concurrent.BlockingQueue;

/**
 * @author huangqingshi
 * @Date 2020-04-18
 */
@Slf4j
public class RedisListDelayedQueue{

    private static final int MAX_SIZE_OF_QUEUE = 100000;
    private RedisTemplateString, String> redisTemplate;
    private String queueName;
    private BlockingQueueMessage> delayedQueue;

    public RedisListDelayedQueue(RedisTemplateString, String> redisTemplate, String queueName, BlockingQueueMessage> delayedQueue) {
        this.redisTemplate = redisTemplate;
        this.queueName = queueName;
        this.delayedQueue = delayedQueue;
        init();
    }

    public void offerMessage(Message message) {
        if(delayedQueue.size() > MAX_SIZE_OF_QUEUE) {
            throw new IllegalStateException("超過隊列要求最大值,請檢查");
        }
        try {
            log.info("offerMessage:" + message);
            delayedQueue.offer(message);
        } catch (Exception e) {
            log.error("offMessage異常", e);
        }
    }

    public void init() {
        new Thread(() -> {
            while(true) {
                try {
                    Message message = delayedQueue.take();
                    redisTemplate.opsForList().leftPush(queueName, message.toString());
                } catch (InterruptedException e) {
                    log.error("取消息錯誤", e);
                }
            }
        }).start();
    }
}

  接下來我們看一下,我們寫一個測試的controller。大家看一下這個請求/redis/listDelayedQueue的代碼位置。我們也是生成了兩個消息,然后把消息放到隊列里邊,另外我們在啟動一個線程任務(wù),用于將數(shù)據(jù)從Redis的list中獲取。方法也非常簡單。

package com.hqs.delayQueue.controller;

import com.hqs.delayQueue.bean.Message;
import com.hqs.delayQueue.cache.RedisListDelayedQueue;
import com.hqs.delayQueue.cache.RedisZSetDelayedQueue;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import java.util.Set;
import java.util.concurrent.*;

/**
 * @author huangqingshi
 * @Date 2020-04-18
 */
@Slf4j
@Controller
public class DelayQueueController {

    private static final int CORE_SIZE = Runtime.getRuntime().availableProcessors();

    //注意RedisTemplate用的String,String,后續(xù)所有用到的key和value都是String的
    @Autowired
    RedisTemplateString, String> redisTemplate;

    private static ThreadPoolExecutor taskExecPool = new ThreadPoolExecutor(CORE_SIZE, CORE_SIZE, 0, TimeUnit.SECONDS,
            new LinkedBlockingDeque>());

    @GetMapping("/redisTest")
    @ResponseBody
    public String redisTest() {
        redisTemplate.opsForValue().set("a","b",60L, TimeUnit.SECONDS);
        System.out.println(redisTemplate.opsForValue().get("a"));
        return "s";
    }

    @GetMapping("/redis/listDelayedQueue")
    @ResponseBody
    public String listDelayedQueue() {

        Message message1 = new Message("hello", 1000 * 5L);
        Message message2 = new Message("world", 1000 * 7L);

        String queueName = "list_queue";

        BlockingQueueMessage> delayedQueue = new DelayQueue>();

        RedisListDelayedQueue redisListDelayedQueue = new RedisListDelayedQueue(redisTemplate, queueName, delayedQueue);

        redisListDelayedQueue.offerMessage(message1);
        redisListDelayedQueue.offerMessage(message2);
        asyncListTask(queueName);

        return "success";
    }

    @GetMapping("/redis/zSetDelayedQueue")
    @ResponseBody
    public String zSetDelayedQueue() {

        Message message1 = new Message("hello", 1000 * 5L);
        Message message2 = new Message("world", 1000 * 7L);

        String queueName = "zset_queue";

        BlockingQueueMessage> delayedQueue = new DelayQueue>();

        RedisZSetDelayedQueue redisZSetDelayedQueue = new RedisZSetDelayedQueue(redisTemplate, queueName, delayedQueue);

        redisZSetDelayedQueue.offerMessage(message1);
        redisZSetDelayedQueue.offerMessage(message2);
        asyncZSetTask(queueName);

        return "success";
    }

    public void asyncListTask(String queueName) {
        taskExecPool.execute(() -> {
            for(;;) {
                String message = redisTemplate.opsForList().rightPop(queueName);
                if(message != null) {
                    log.info(message);
                }
            }
        });
    }

    public void asyncZSetTask(String queueName) {
        taskExecPool.execute(() -> {
            for(;;) {
                Long nowTimeInMs = System.currentTimeMillis();
                System.out.println("nowTimeInMs:" + nowTimeInMs);
                SetString> messages = redisTemplate.opsForZSet().rangeByScore(queueName, 0, nowTimeInMs);
                if(messages != null  messages.size() != 0) {
                    redisTemplate.opsForZSet().removeRangeByScore(queueName, 0, nowTimeInMs);
                    for (String message : messages) {
                        log.info("asyncZSetTask:" + message + " " + nowTimeInMs);
                    }
                    log.info(redisTemplate.opsForZSet().zCard(queueName).toString());
                }
                try {
                    TimeUnit.SECONDS.sleep(1);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        });
    }

}

  我就不把運行結(jié)果寫出來了,感興趣的同學自己自行試驗。當然這個方法也是從內(nèi)存中拿出數(shù)據(jù),到時間之后放到Redis里邊,還是會存在程序啟動的時候,任務(wù)進行丟失。我們繼續(xù)看另外一種方法更好的進行這個問題的處理。

3.使用Redis的zSet實現(xiàn)分布式延遲隊列。

  我們需要再寫一個ZSet的隊列處理。下邊的offerMessage主要是把消息直接放入緩存中。采用Redis的ZSET的zadd方法。zadd(key, value, score) 即將key=value的數(shù)據(jù)賦予一個score, 放入緩存中。score就是計算出來延遲的毫秒數(shù)。

package com.hqs.delayQueue.cache;

import com.hqs.delayQueue.bean.Message;
import lombok.extern.slf4j.Slf4j;
import org.springframework.data.redis.core.RedisTemplate;

import java.util.concurrent.BlockingQueue;

/**
 * @author huangqingshi
 * @Date 2020-04-18
 */
@Slf4j
public class RedisZSetDelayedQueue {

    private static final int MAX_SIZE_OF_QUEUE = 100000;
    private RedisTemplateString, String> redisTemplate;
    private String queueName;
    private BlockingQueueMessage> delayedQueue;

    public RedisZSetDelayedQueue(RedisTemplateString, String> redisTemplate, String queueName, BlockingQueueMessage> delayedQueue) {
        this.redisTemplate = redisTemplate;
        this.queueName = queueName;
        this.delayedQueue = delayedQueue;
    }

    public void offerMessage(Message message) {
        if(delayedQueue.size() > MAX_SIZE_OF_QUEUE) {
            throw new IllegalStateException("超過隊列要求最大值,請檢查");
        }
        long delayTime = message.getFireTime() - System.currentTimeMillis();
        log.info("zset offerMessage" + message + delayTime);
        redisTemplate.opsForZSet().add(queueName, message.toString(), message.getFireTime());
    }

}

  上邊的Controller方法已經(jīng)寫好了測試的方法。/redis/zSetDelayedQueue,里邊主要使用ZSet的zRangeByScore(key, min, max)。主要是從score從0,當前時間的毫秒數(shù)獲取。取出數(shù)據(jù)后再采用removeRangeByScore,將數(shù)據(jù)刪除。這樣數(shù)據(jù)可以直接寫到Redis里邊,然后取出數(shù)據(jù)后直接處理。這種方法比前邊的方法稍微好一些,但是實際上還存在一些問題,因為依賴Redis,如果Redis內(nèi)存不足或者連不上的時候,系統(tǒng)將變得不可用。

4. 總結(jié)一下,另外還有哪些可以延遲隊列。

  上面的方法其實還是存在問題的,比如系統(tǒng)重啟的時候還是會造成任務(wù)的丟失。所以我們在生產(chǎn)上使用的時候,我們還需要將任務(wù)保存起來,比如放到數(shù)據(jù)庫和文件存儲系統(tǒng)將數(shù)據(jù)存儲起來,這樣做到double-check,雙重檢查,最終達到任務(wù)的99.999%能夠處理。

  其實還有很多東西可以實現(xiàn)延遲隊列。

  1) RabbitMQ就可以實現(xiàn)此功能。這個消息隊列可以把數(shù)據(jù)保存起來并且進行處理。

  2)Kafka也可以實現(xiàn)這個功能。

  3)Netty的HashedWheelTimer也可以實現(xiàn)這個功能。

最后放上我的代碼: https://github.com/stonehqs/delayQueue

到此這篇關(guān)于Redis延遲隊列和分布式延遲隊列的簡答實現(xiàn)的文章就介紹到這了,更多相關(guān)Redis延遲隊列和分布式延遲隊列內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 基于Redis延遲隊列的實現(xiàn)代碼
  • SpringBoot集成Redisson實現(xiàn)延遲隊列的場景分析
  • php使用redis的有序集合zset實現(xiàn)延遲隊列應用示例

標簽:北京 朝陽 吉安 大慶 臺州 果洛 江蘇 楊凌

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Redis延遲隊列和分布式延遲隊列的簡答實現(xiàn)》,本文關(guān)鍵詞  Redis,延遲,隊列,和,分布式,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Redis延遲隊列和分布式延遲隊列的簡答實現(xiàn)》相關(guān)的同類信息!
  • 本頁收集關(guān)于Redis延遲隊列和分布式延遲隊列的簡答實現(xiàn)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    av中文资源在线资源免费观看| 海角国产乱辈乱精品视频| 性开放的欧美大片| 可以免费看黄色的网站| 精品无人区麻豆乱码久久久| 伪装者在线观看完整版免费| 神马久久午夜| 中文字幕亚洲欧美日韩高清| 三级黄色录像视频| 大伊香蕉精品视频在线| 欧美精品日韩一本| 少妇精品高潮欲妇又嫩中文字幕| 欧美一区二区三区电影| 久久国产激情视频| 正在播放亚洲精品| 黄色三级电影网| 久久在精品线影院精品国产| 女同久久另类69精品国产| 日韩高清在线不卡| 久久精品视频在线看| 欧美一区二区三区视频免费播放| 亚洲一区二区在线视频观看| 国产精品蜜臀在线观看| 日韩一区二区三区视频在线观看| 久久一区视频| 日韩精品在线视频| 国产亚洲精品一区二区| 中文字幕久久久久久久| 伊人影院在线播放| 日韩久久免费av| 日韩欧美亚洲国产另类| 欧美日韩三级在线观看| 欧美jizzhd精品欧美另类| 日本三级视频在线观看| 亚洲va国产日韩欧美精品色婷婷| 日本免费中文字幕在线| 女女百合国产免费网站| 不卡伊人av在线播放| 一区二区三区在线看| 五月天久久久久久| 久久老女人爱爱| 日韩欧美主播在线| 欧美国产一二三区| 国产激情在线播放| 色婷婷久久久久swag精品| 最新版天堂资源在线| 久久久国产影院| 91免费国产精品| 欧美18—19性高清hd4k| 亚洲欧美日韩一区在线观看| 第一区第二区在线| 黑人巨大40厘米重口ysn| 最新国产成人在线观看| 最新av电影| 美女羞羞视频在线观看| 欧美日韩国产专区| 免费看黄色的网站| 欧美日韩一区二区国产| 亚洲最大成人综合网| 亚洲日本乱码在线观看| 波多野结衣中文在线| 先锋男人资源站| 亚亚洲欧洲精品| 影音欧美亚洲| 欧美激情影音先锋| 久久久久国产精品麻豆ai换脸| 亚洲最大福利视频网站| 91蝌蚪porny成人天涯| 精品一区二区三区的国产在线观看| 国产欧美一区二区三区精品酒店| 九色自拍麻豆| 久久九九热视频| 天堂а√在线资源在线| 亚洲一区二区三区av无码| 国产美女永久免费无遮挡| 欧美刺激午夜性久久久久久久| 免费无码一区二区三区| 亚洲成a人片77777在线播放| 国产伦精品一区二区| 国产麻豆一区二区三区在线观看| 三上悠亚av一区二区三区| 国产精品x453.com| 欧美精品videossex性护士| 国产成人激情小视频| a毛片在线播放| 欧美一级视频在线观看| 日韩美女中文字幕| 合欧美一区二区三区| 哥也色在线视频| 免费成人美女在线观看| av在线二区| 欧美大交乱xxxxbbbb| 欧美一级小视频| 国产精品久久久久久99| 91免费人成网站在线观看18| 亚洲第一区中文99精品| 荫蒂被男人添免费视频| 成人直播在线观看| 免费在线看黄色片| 国产青春久久久国产毛片| www.av99| 色狠狠av一区二区三区| 黄色成人在线观看网站| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 欧洲日本在线| 亚洲视频免费观看| www.香蕉视频在线观看| 男女啪啪网站视频| 伊人色综合久久久| 欧洲av在线播放| 99riav久久精品riav| 欧美日韩尤物久久| 国产片高清在线观看| 91在线无精精品白丝| 在线不卡视频一区二区| 大黑人xxx| 亚洲国产成人在线播放| 曰本女人与公拘交酡| 一级全黄少妇性色生活片| 免费看国产片在线观看| 精品成人佐山爱一区二区| 伊人永久在线| 午夜精品一区二区在线观看| 在线视频1区2区| 97久久人人超碰| 杨幂一区二区国产精品| 亚洲自拍偷拍一区二区三区| 麻豆精品密在线观看| 在线观看一区二区精品视频| 国语对白在线视频| 熟女少妇一区二区三区| 免费成人高清在线视频theav| 国产成人jvid在线播放| 久久影院朴妮唛| 午夜精品一区二区三区在线| 欧美日韩免费在线视频| 日本免费网址| 日韩精品免费在线视频观看| 欧美日韩国产第一页| 免费色片视频| 国产绳艺sm调教室论坛| 你懂的视频在线播放| 图片区小说区区亚洲五月| 亚洲黄色高清| 欧美日韩精品二区第二页| 在线视频资源站| 深夜在线视频| 伊人无码高清| 久久精品国产网站| 免费精品99久久国产综合精品应用| 国产麻豆精品高清在线播放| 日韩精品中文字| 三级全黄视频| 欧美亚洲专区| 桃花视频大全不卡免费观看网站| 天天综合天天色| 91九色综合久久| 99久久久无码国产精品不卡| 欧美午夜片欧美片在线观看| 国产一区二区三区视频免费观看| 天天干天天色天天干| 九九**精品视频免费播放| 欧美色图另类| 欧美日韩一区小说| 二区三区四区高清视频在线观看| 欧美激情第六页| 欧美午夜18电影| 九九综合九九| www.亚洲一区二区| 国产精品久久久久久影院8一贰佰| 涩涩涩久久久成人精品| 国内精品国产成人国产三级| 久久精品成人av| 亚洲精品在线视频观看| 麻豆网站免费在线观看| av免费观看网址| 欧美日一区二区三区在线观看国产免| 99久久国产综合精品女不卡| 欧美成人在线免费视频| 日韩少妇高潮抽搐| 亚洲国产精品中文| 黄色免费在线网站| 亚洲成人精品女人久久久| 欧美高清视频在线高清观看mv色露露十八| 婷婷久久综合九色国产成人| 久久精品72免费观看| 久久久久亚洲av成人无码电影| 在线日韩中文| 春意影院免费入口| 日日鲁鲁鲁夜夜爽爽狠狠视频97| 一本色道久久综合亚洲aⅴ蜜桃| 免费av一区二区三区四区| 日韩欧美有码在线| 一区二区三区动漫| 欧美亚洲综合在线| 亚洲高清久久久久久| 自拍日韩欧美| 91社区视频| 天堂av在线网| 婷婷视频一区二区三区| 日韩视频精品| 草草视频在线免费观看| 国产成人h网站| 久草免费在线观看视频| 欧美性猛交xxxx富婆弯腰| 欧美日韩在线一| 四虎地址8848| 麻豆一区二区三区精品视频| 亚洲伦理一区二区| 久草国产在线观看| 久久视频这里只有精品| 国产精品免费观看久久| 综合中文字幕亚洲| 免费在线亚洲欧美| 最猛黑人系列在线播放| 欧美男人的天堂| 蜜乳av一区| 精品一区二区三区国产| 欧美超碰在线观看| 蜜臀av性久久久久蜜臀aⅴ流畅| 欧美日韩国内| 亚洲在线观看视频| 精品无码国产污污污免费网站| 亚洲久久成人| 一本色道久久综合精品竹菊| 亚洲人成网站影音先锋播放| 99久re热视频精品98| 丁香婷婷久久久综合精品国产| 国产又爽又黄无码无遮挡在线观看| 热久久久久久久| 精品久久久久久中文字幕| 中文在线中文资源| 再深点灬舒服灬太大了添少妇视频| 亚洲一区二区在线免费看| 在线观看免费观看在线| 久久品道一品道久久精品| 不卡福利视频| 国产高清精品网站| 欧美福利在线观看| 麻豆亚洲精品| 亚洲午夜精品久久久久久久久久久久| 91在线视频一区| 国产成人午夜片在线观看高清观看| 亚洲精品日韩专区silk| 狠狠色综合欧美激情| 欧美在线精品免播放器视频| 清纯唯美亚洲色图| 精品久久久久久久久久久久久久久久久| 女人体1963| 亚洲网站视频| 欧美日韩精品综合| 久久国产在线观看| 亚洲欧美激情视频在线观看一区二区三区| 青青草视频在线免费观看| 夜色资源站国产www在线视频| 欧美在线xxx| 中文字幕一区二区三区日韩精品| 日韩成人在线一区| 桥本有菜亚洲精品av在线| 69成人在线| av在线资源站| 亚洲按摩av| 91传媒久久久| 久久久久人妻一区精品色欧美| 91丝袜超薄交口足| 国产成人自拍在线| 精品中文字幕一区二区三区av| 天堂中文字幕一二区| 99精品视频在线播放观看| 亚洲精品久久久久中文字幕欢迎你| 日韩一区国产二区欧美三区| 国产精品午夜一区二区三区| 3atv一区二区三区| 国产盗摄一区二区三区| 手机在线免费看av| 国产精品免费人成网站| 亚洲女人天堂色在线7777| xxxx欧美18另类的高清| 欧美视频www| 免费成人在线视频网站| 久久久久99精品成人片试看| 亚洲国产成人综合| 中文字幕第80页| 岛国大片在线观看| 91论坛在线播放| 不卡一区综合视频| 国产精品99久久久精品无码| 快播电影网址老女人久久| 国产综合精品一区二区三区| 日韩中文字幕在线播放| 国产精品理人伦一区二区三区| 国产精品美腿一区在线看| 久久久久国产一区二区| 天天夜碰日日摸日日澡性色av| 亚洲午夜国产成人av电影男同| 欧美韩国亚洲| 国产亚洲福利社区| 亚洲精品国产一区二区三区四区在线| 国产在线一二三| 深夜福利小视频| 呻吟揉丰满对白91乃国产区| 性日韩欧美在线视频| 丁香亚洲综合激情啪啪综合| 日韩三级av在线| 操人视频在线观看欧美| 欧美a级免费视频| 国产香蕉在线观看| 色视频在线观看福利| 欧美成人精品一区二区| 国产小视频免费在线网址| 久久综合久久久| 亚洲美女炮图| 日本电影一区二区三区| 亚洲人视频在线观看| 亚洲国产sm捆绑调教视频| 在线观看成年人视频| 色三级在线观看| 精品视频站长推荐| 制服丝袜第二页| 高清一区二区视频| 免费精品99久久国产综合精品| 久久久亚洲欧洲日产国码aⅴ| 91精品少妇一区二区三区蜜桃臀| 色播五月综合| 91丨九色丨国产| 91成人影院| 亚洲精品不卡在线观看| 国产a∨精品一区二区三区不卡|