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

聊聊分布式服務下的八種異步實現方式

開發 架構
異步執行對于開發者來說并不陌生,在實際的開發過程中,很多場景多會使用到異步,相比同步執行,異步可以大大縮短請求鏈路耗時時間,比如:「發送短信、郵件、異步更新等」,這些都是典型的可以通過異步實現的場景。

一、異步的八種實現方式

1、線程Thread

2、Future

3、異步框架CompletableFuture

4、Spring注解@Async

5、Spring ApplicationEvent事件

6、消息隊列

7、第三方異步框架,比如Hutool的ThreadUtil

8、Guava異步

二、什么是異步?

首先我們先看一個常見的用戶下單的場景:

什么是異步?

在同步操作中,我們執行到 發送短信 的時候,我們必須等待這個方法徹底執行完才能執行 贈送積分 這個操作,如果 贈送積分 這個動作執行時間較長,發送短信需要等待,這就是典型的同步場景。

實際上,發送短信和贈送積分沒有任何的依賴關系,通過異步,我們可以實現贈送積分和發送短信這兩個操作能夠同時進行,比如:

異步異步

這就是所謂的異步,是不是非常簡單,下面就說說異步的幾種實現方式吧。

三、異步編程

1、線程異步

public class AsyncThread extends Thread {


    @Override
    public void run() {
        System.out.println("Current thread name:" + Thread.currentThread().getName() + " Send email success!");
    }


    public static void main(String[] args) {
        AsyncThread asyncThread = new AsyncThread();
        asyncThread.run();
    }
}

當然如果每次都創建一個Thread線程,頻繁的創建、銷毀,浪費系統資源,我們可以采用線程池:

private ExecutorService executorService = Executors.newCachedThreadPool();


public void fun() {
    executorService.submit(new Runnable() {
        @Override
        public void run() {
            log.info("執行業務邏輯...");
        }
    });
}

可以將業務邏輯封裝到Runnable或Callable中,交由線程池來執行。

2、 Future異步

@Slf4j
public class FutureManager {


    public String execute() throws Exception {
        ExecutorService executor = Executors.newFixedThreadPool(1);
        Future<String> future = executor.submit(new Callable<String>() {
            @Override
            public String call() throws Exception {
                System.out.println(" --- task start --- ");
                Thread.sleep(3000);
                System.out.println(" --- task finish ---");
                return "this is future execute final result!!!";
            }
        });
        //這里需要返回值時會阻塞主線程
        String result = future.get();
        log.info("Future get result: {}", result);
        return result;
    }


    @SneakyThrows
    public static void main(String[] args) {
        FutureManager manager = new FutureManager();
        manager.execute();
    }
}

輸出結果:

--- task start --- 
 --- task finish ---
 Future get result: this is future execute final result!!!

(1) Future的不足之處

Future的不足之處的包括以下幾點:

  • 無法被動接收異步任務的計算結果:雖然我們可以主動將異步任務提交給線程池中的線程來執行,但是待異步任務執行結束之后,主線程無法得到任務完成與否的通知,它需要通過get方法主動獲取任務執行的結果。
  • Future件彼此孤立:有時某一個耗時很長的異步任務執行結束之后,你想利用它返回的結果再做進一步的運算,該運算也會是一個異步任務,兩者之間的關系需要程序開發人員手動進行綁定賦予,Future并不能將其形成一個任務流(pipeline),每一個Future都是彼此之間都是孤立的,所以才有了后面的CompletableFuture,CompletableFuture就可以將多個Future串聯起來形成任務流。
  • Futrue沒有很好的錯誤處理機制:截止目前,如果某個異步任務在執行發的過程中發生了異常,調用者無法被動感知,必須通過捕獲get方法的異常才知曉異步任務執行是否出現了錯誤,從而在做進一步的判斷處理。

3、CompletableFuture實現異步

public class CompletableFutureCompose {
    /**
     * thenAccept子任務和父任務公用同一個線程
     */
    @SneakyThrows
    public static void thenRunAsync() {
        CompletableFuture<Integer> cf1 = CompletableFuture.supplyAsync(() -> {
            System.out.println(Thread.currentThread() + " cf1 do something....");
            return 1;
        });
        CompletableFuture<Void> cf2 = cf1.thenRunAsync(() -> {
            System.out.println(Thread.currentThread() + " cf2 do something...");
        });
        //等待任務1執行完成
        System.out.println("cf1結果->" + cf1.get());
        //等待任務2執行完成
        System.out.println("cf2結果->" + cf2.get());
    }


    public static void main(String[] args) {
        thenRunAsync();
    }
}

我們不需要顯式使用ExecutorService,CompletableFuture 內部使用了ForkJoinPool來處理異步任務,如果在某些業務場景我們想自定義自己的異步線程池也是可以的。

4、Spring的@Async異步

(1)自定義異步線程池

/**
 * 線程池參數配置,多個線程池實現線程池隔離,@Async注解,默認使用系統自定義線程池,可在項目中設置多個線程池,在異步調用的時候,指明需要調用的線程池名稱,比如:@Async("taskName")
@EnableAsync
@Configuration
public class TaskPoolConfig {
    /**
     * 自定義線程池
     *
     **/
    @Bean("taskExecutor")
    public Executor taskExecutor() {
        //返回可用處理器的Java虛擬機的數量 12
        int i = Runtime.getRuntime().availableProcessors();
        System.out.println("系統最大線程數  :" + i);
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        //核心線程池大小
        executor.setCorePoolSize(16);
        //最大線程數
        executor.setMaxPoolSize(20);
        //配置隊列容量,默認值為Integer.MAX_VALUE
        executor.setQueueCapacity(99999);
        //活躍時間
        executor.setKeepAliveSeconds(60);
        //線程名字前綴
        executor.setThreadNamePrefix("asyncServiceExecutor -");
        //設置此執行程序應該在關閉時阻止的最大秒數,以便在容器的其余部分繼續關閉之前等待剩余的任務完成他們的執行
        executor.setAwaitTerminationSeconds(60);
        //等待所有的任務結束后再關閉線程池
        executor.setWaitForTasksToCompleteOnShutdown(true);
        return executor;
    }
}

(2) AsyncService

public interface AsyncService {


    MessageResult sendSms(String callPrefix, String mobile, String actionType, String content);


    MessageResult sendEmail(String email, String subject, String content);
}


@Slf4j
@Service
public class AsyncServiceImpl implements AsyncService {
    @Autowired
    private IMessageHandler mesageHandler;


    @Override
    @Async("taskExecutor")
    public MessageResult sendSms(String callPrefix, String mobile, String actionType, String content) {
        try {




            Thread.sleep(1000);
            mesageHandler.sendSms(callPrefix, mobile, actionType, content);




        } catch (Exception e) {
            log.error("發送短信異常 -> ", e)
        }
    }
    
    @Override
    @Async("taskExecutor")
    public sendEmail(String email, String subject, String content) {
        try {


            Thread.sleep(1000);
            mesageHandler.sendsendEmail(email, subject, content);


        } catch (Exception e) {
            log.error("發送email異常 -> ", e)
        }
    }
}

在實際項目中, 使用@Async調用線程池,推薦等方式是是使用自定義線程池的模式,不推薦直接使用@Async直接實現異步。

5、Spring ApplicationEvent事件實現異步

(1)定義事件

public class AsyncSendEmailEvent extends ApplicationEvent {
    /**
     * 郵箱
     **/
    private String email;
   /**
     * 主題
     **/
    private String subject;
    /**
     * 內容
     **/
    private String content;
  
    /**
     * 接收者
     **/
    private String targetUserId;


}

(2)定義事件處理器

@Slf4j
@Component
public class AsyncSendEmailEventHandler implements ApplicationListener<AsyncSendEmailEvent> {


    @Autowired
    private IMessageHandler mesageHandler;
    
    @Async("taskExecutor")
    @Override
    public void onApplicationEvent(AsyncSendEmailEvent event) {
        if (event == null) {
            return;
        }


        String email = event.getEmail();
        String subject = event.getSubject();
        String content = event.getContent();
        String targetUserId = event.getTargetUserId();
        mesageHandler.sendsendEmailSms(email, subject, content, targerUserId);
      }
}

另外,可能有些時候采用ApplicationEvent實現異步的使用,當程序出現異常錯誤的時候,需要考慮補償機制,那么這時候可以結合Spring Retry重試來幫助我們避免這種異常造成數據不一致問題。

6、消息隊列

(1)回調事件消息生產者

@Slf4j
@Component
public class CallbackProducer {


    @Autowired
    AmqpTemplate amqpTemplate;


    public void sendCallbackMessage(CallbackDTO allbackDTO, final long delayTimes) {


        log.info("生產者發送消息,callbackDTO,{}", callbackDTO);


        amqpTemplate.convertAndSend(CallbackQueueEnum.QUEUE_GENSEE_CALLBACK.getExchange(), CallbackQueueEnum.QUEUE_GENSEE_CALLBACK.getRoutingKey(), JsonMapper.getInstance().toJson(genseeCallbackDTO), new MessagePostProcessor() {
            @Override
            public Message postProcessMessage(Message message) throws AmqpException {
                //給消息設置延遲毫秒值,通過給消息設置x-delay頭來設置消息從交換機發送到隊列的延遲時間
                message.getMessageProperties().setHeader("x-delay", delayTimes);
                message.getMessageProperties().setCorrelationId(callbackDTO.getSdkId());
                return message;
            }
        });
    }
}

(2)回調事件消息消費者

@Slf4j
@Component
@RabbitListener(queues = "message.callback", containerFactory = "rabbitListenerContainerFactory")
public class CallbackConsumer {


    @Autowired
    private IGlobalUserService globalUserService;


    @RabbitHandler
    public void handle(String json, Channel channel, @Headers Map<String, Object> map) throws Exception {


        if (map.get("error") != null) {
            //否認消息
            channel.basicNack((Long) map.get(AmqpHeaders.DELIVERY_TAG), false, true);
            return;
        }


        try {
            CallbackDTO callbackDTO = JsonMapper.getInstance().fromJson(json, CallbackDTO.class);
            //執行業務邏輯
            globalUserService.execute(callbackDTO);
            //消息消息成功手動確認,對應消息確認模式acknowledge-mode: manual
            channel.basicAck((Long) map.get(AmqpHeaders.DELIVERY_TAG), false);
        } catch (Exception e) {
            log.error("回調失敗 -> {}", e);
        }
    }
}

7、ThreadUtil異步工具類

@Slf4j
public class ThreadUtils {


    public static void main(String[] args) {
        for (int i = 0; i < 3; i++) {
            ThreadUtil.execAsync(() -> {
                ThreadLocalRandom threadLocalRandom = ThreadLocalRandom.current();
                int number = threadLocalRandom.nextInt(20) + 1;
                System.out.println(number);
            });
            log.info("當前第:" + i + "個線程");
        }


        log.info("task finish!");
    }
}

8、Guava異步

Guava的ListenableFuture顧名思義就是可以監聽的Future,是對java原生Future的擴展增強。我們知道Future表示一個異步計算任務,當任務完成時可以得到計算結果。如果我們希望一旦計算完成就拿到結果展示給用戶或者做另外的計算,就必須使用另一個線程不斷的查詢計算狀態。這樣做,代碼復雜,而且效率低下。使用「Guava ListenableFuture」可以幫我們檢測Future是否完成了,不需要再通過get()方法苦苦等待異步的計算結果,如果完成就自動調用回調函數,這樣可以減少并發程序的復雜度。

ListenableFuture是一個接口,它從jdk的Future接口繼承,添加了void addListener(Runnable listener, Executor executor)方法。

我們看下如何使用ListenableFuture。首先需要定義ListenableFuture的實例:

ListeningExecutorService executorService = MoreExecutors.listeningDecorator(Executors.newCachedThreadPool());
        final ListenableFuture<Integer> listenableFuture = executorService.submit(new Callable<Integer>() {
            @Override
            public Integer call() throws Exception {
                log.info("callable execute...")
                TimeUnit.SECONDS.sleep(1);
                return 1;
            }
        });

首先通過MoreExecutors類的靜態方法listeningDecorator方法初始化一個ListeningExecutorService的方法,然后使用此實例的submit方法即可初始化ListenableFuture對象。

ListenableFuture要做的工作,在Callable接口的實現類中定義,這里只是休眠了1秒鐘然后返回一個數字1,有了ListenableFuture實例,可以執行此Future并執行Future完成之后的回調函數。

Futures.addCallback(listenableFuture, new FutureCallback<Integer>() {
    @Override
    public void onSuccess(Integer result) {
        //成功執行...
        System.out.println("Get listenable future's result with callback " + result);
    }


    @Override
    public void onFailure(Throwable t) {
        //異常情況處理...
        t.printStackTrace();
    }
});

那么,以上就是本期介紹的分布式服務下實現異步的八種方式了,供您參考。

責任編輯:華軒 來源: 架構精進之路
相關推薦

2022-04-08 08:27:08

分布式鎖系統

2022-07-01 08:00:44

異步編程FutureTask

2021-09-17 07:51:24

RedissonRedis分布式

2024-07-05 08:26:54

2020-09-23 09:52:01

分布式WebSocketMQ

2021-09-26 09:16:45

RedisGeo 類型數據類型

2017-01-16 14:13:37

分布式數據庫

2018-04-03 16:24:34

分布式方式

2025-08-04 02:21:00

2023-09-13 09:52:14

分布式鎖Java

2017-12-20 16:15:30

分布式系統架構

2018-04-03 09:27:42

分布式架構系統

2023-11-29 10:26:52

分布式數據

2021-02-01 09:35:53

關系型數據庫模型

2023-02-10 00:04:53

2022-06-13 10:01:36

Apollo攜程框架

2025-03-06 11:30:15

2018-01-23 15:55:23

分布式系統架構

2023-05-29 14:07:00

Zuul網關系統

2022-06-28 08:16:35

MySQL數據容災
點贊
收藏

51CTO技術棧公眾號

一区二区黄色| 国产激情一区| 国产精品乱码久久久久久| 国产精欧美一区二区三区| 一二三四国产精品| 久久精品免视看国产成人| 精品国产乱码久久久久久天美| 日韩精品极品视频在线观看免费| 国产又粗又长又大视频| 国模吧视频一区| 亚洲日韩中文字幕| 亚洲国产综合av| 中文字幕色婷婷在线视频| 国产精品久久久久7777按摩| 国产伦精品一区| 艳妇乳肉豪妇荡乳av| 禁久久精品乱码| 中文字幕亚洲第一| 黄色污在线观看| www.成人在线.com| 色吊一区二区三区| av在线免费观看国产| 日韩精品123| 国产精品夜夜嗨| 国产精品主播视频| 日韩久久中文字幕| 女人天堂亚洲aⅴ在线观看| 亚洲网站视频福利| 中文字幕在线永久| 日韩欧美一级| 欧美精品一级二级| 97公开免费视频| 日本在线高清| 亚洲成va人在线观看| 三级在线免费观看| 日韩子在线观看| 国产欧美精品在线观看| 九色综合日本| 手机在线精品视频| 激情综合色播五月| 国产精品色悠悠| 亚洲欧美一二三区| 亚洲免费影院| 2019av中文字幕| 国产午夜精品无码| 国产精品a级| 久久大大胆人体| 99自拍视频在线| 日本久久精品| 一本大道久久加勒比香蕉| aaaaa级少妇高潮大片免费看| 波多野结衣欧美| 精品三级在线观看| 99久久久无码国产精品性波多 | 欧美视频亚洲视频| 久久九九国产精品怡红院| 日本成人免费在线观看| 欧美艳星介绍134位艳星| 亚洲午夜av久久乱码| 中文幕无线码中文字蜜桃| 精品一区亚洲| 影音先锋欧美精品| 农村老熟妇乱子伦视频| 日韩理论电影院| 精品国产自在精品国产浪潮 | 亚洲一级二级在线| 国产精品视频二| jizzjizz中国精品麻豆| 欧美日韩加勒比精品一区| 日本免费不卡一区二区| 亚洲性受xxx喷奶水| 一本大道综合伊人精品热热| 久久久久久香蕉| 国内欧美日韩| 欧美大片一区二区| 男人网站在线观看| 秋霞影院一区二区三区| 亚洲人成电影在线观看天堂色| 人与嘼交av免费| 99精品国产一区二区三区| 九九热这里只有精品6| 日韩av免费网址| 在线一区视频| 国产欧美精品一区二区| 亚洲av少妇一区二区在线观看| 99国内精品久久| 视频在线99re| 欧美78videosex性欧美| 狠狠色噜噜狠狠狠狠97| 天天干天天操天天玩| 视频一区中文字幕精品| 亚洲美女性视频| 五月天色婷婷丁香| 日韩香蕉视频| 成人精品在线视频| 天堂av网在线| 自拍偷拍国产精品| 国产成人在线免费看| 国外成人福利视频| 欧美精品一区二区三| 日本人亚洲人jjzzjjz| 午夜亚洲福利| 国产精品久久久久免费a∨大胸 | 中文字幕在线乱| 国产精品高颜值在线观看| 欧美日韩一区不卡| 一级特级黄色片| 亚洲欧美文学| 国产精品99久久99久久久二8| 国产高清视频免费观看| 国产人成亚洲第一网站在线播放| wwwjizzjizzcom| 日本综合视频| 亚洲国产成人精品久久| 91日韩中文字幕| 日韩国产成人精品| 久久精彩视频| 任你弄在线视频免费观看| 在线观看视频欧美| av鲁丝一区鲁丝二区鲁丝三区| 婷婷中文字幕一区| 国产精品∨欧美精品v日韩精品| 国产91麻豆视频| 亚洲欧美一区二区久久| 久草福利视频在线| 精品一区亚洲| 欧美中文在线免费| 凸凹人妻人人澡人人添| 伊人婷婷欧美激情| 一级做a免费视频| 成人av资源电影网站| 欧美性视频在线| 人人妻人人澡人人爽久久av| 亚洲人成伊人成综合网小说| 欧美黄色性生活| 国产一区二区三区天码| 91av在线影院| 丝袜+亚洲+另类+欧美+变态| 亚洲国产毛片aaaaa无费看 | 18成人在线观看| 一区二区三区 日韩| 国内黄色精品| 国产ts人妖一区二区三区 | 一起草av在线| 国产精品素人视频| 91福利国产成人精品播放| 精品国产一区二区三区久久久蜜臀| 91精品国产高清| 亚洲色偷精品一区二区三区| 精品久久久久久久中文字幕| 最近中文字幕无免费| 日韩午夜黄色| 欧美激情第六页| 日本久久免费| 自拍视频国产精品| 一级全黄裸体免费视频| 成人欧美一区二区三区在线播放| 狠狠操狠狠干视频| 我不卡神马影院| 91黄在线观看| 不卡视频观看| 亚洲人成啪啪网站| 亚洲精品一区二区二区| 国产精品素人一区二区| 亚洲色图欧美自拍| 好看的亚洲午夜视频在线| 国产精品乱码| www.日韩| 久久精品电影网站| 性欧美8khd高清极品| 亚洲成人av在线电影| 免费看黄色的视频| 久久99精品视频| 国产高清不卡无码视频| 久久视频在线观看| 国产精品爱久久久久久久| 精品麻豆一区二区三区| 精品少妇一区二区三区在线视频| 日韩精品――中文字幕| 国产人成亚洲第一网站在线播放 | 欧美日韩综合一区二区三区| 日本一区二区三区四区在线视频| 亚洲小视频网站| 亚洲欧洲一区| 先锋影音欧美| 亚洲图色一区二区三区| 欧美性在线视频| 国产在线看片| 日韩精品视频免费在线观看| 中文字幕理论片| 亚洲自拍偷拍欧美| 中文字幕成人动漫| 国产v日产∨综合v精品视频| 国产亚洲精品网站| 亚洲成人三区| 欧美日韩亚洲免费| 午夜精品在线| 国产精品久久久久久av福利软件| 污污视频在线| 中文字幕免费精品一区| 日韩在线观看视频一区| 欧美日韩视频在线一区二区| 在线看成人av| 国产精品久久久久久久久免费桃花| 国产香蕉精品视频| 青青国产91久久久久久| 亚洲中文字幕无码av永久| 日韩精品欧美| 久热国产精品视频一区二区三区| 国产一区二区三区国产精品| 日产日韩在线亚洲欧美 | 日韩免费中文字幕| 黄网站在线观| 久久久国产精彩视频美女艺术照福利| 天天干天天舔天天射| 日韩欧美一级精品久久| 中文无码av一区二区三区| 天天色天天爱天天射综合| 91人妻一区二区三区蜜臀| 久久九九久久九九| 亚洲第一黄色网址| 成人午夜视频网站| 97超碰人人看| 精品一区二区三区免费毛片爱| 日韩毛片在线免费看| 亚洲国产日本| 草草草视频在线观看| 亚洲精品888| 中文字幕在线亚洲精品| 波多野结衣的一区二区三区| 欧美大陆一区二区| 免费萌白酱国产一区二区三区| 亚洲自拍av在线| 一区在线不卡| 成人免费视频a| 先锋影音一区二区| 国产精品入口免费视| 亚洲四虎影院| 51视频国产精品一区二区| 波多野结衣精品| 欧美精品久久久久久久久| 性网站在线观看| 蜜臀久久99精品久久久无需会员| 91视频在线观看| 综合网中文字幕| 成人免费视频| 深夜福利日韩在线看| 视频三区在线| 久久精品人人爽| av电影免费在线观看| 欧美乱妇40p| 成人免费高清观看| 97视频免费观看| 裤袜国产欧美精品一区| 日韩暖暖在线视频| 国产精品天堂蜜av在线播放| 国产精品久久久久久久久久新婚| 巨胸喷奶水www久久久免费动漫| 国产成人综合精品| 人人玩人人添人人澡欧美| 国产一区二区在线免费视频| 成人在线精品| 国产高清自拍99| 免费成人蒂法| 日本在线成人一区二区| 欧美wwwww| 91嫩草国产丨精品入口麻豆| 亚洲特级毛片| 黄色网页免费在线观看| 日韩av网站免费在线| 国产精品久久久久久久av福利| 国产一区不卡在线| 漂亮人妻被黑人久久精品| ww久久中文字幕| 成人欧美一区二区三区黑人一 | 中文字字幕在线观看| 91精品国产一区二区三区香蕉| 国产深喉视频一区二区| 亚洲第一免费网站| 国产色在线 com| 欧美成人激情在线| 天堂а√在线最新版中文在线| 国产精品久久色| 欧美影院在线| 欧美日韩一区二区视频在线观看| 久久精品播放| 波多野结衣综合网| 日本亚洲视频在线| 免费黄视频在线观看| 久久综合九色综合欧美98| 国产成人在线网址| 天天综合色天天| 国产精品乱码一区二区| 亚洲国产精品福利| 免费人成在线观看播放视频| 97国产suv精品一区二区62| 99久久伊人| 精品视频在线观看| 91亚洲一区| 92看片淫黄大片一级| 国产另类ts人妖一区二区| 亚洲国产天堂av| 亚洲国产精品久久人人爱蜜臀| 成人小视频在线播放| 欧美精品一区二| 大片免费在线观看| 国产精品69av| 女仆av观看一区| 国产精品视频一二三四区| 麻豆91在线播放免费| 最近日本中文字幕| 亚洲综合激情网| 国产又黄又爽视频| 亚洲香蕉成视频在线观看| 操喷在线视频| 亚洲综合精品伊人久久| jizzjizz欧美69巨大| 岳毛多又紧做起爽| 成人精品免费网站| avtt天堂在线| 欧美乱妇15p| 91亚洲欧美| 国产精品欧美激情| 女人av一区| 欧美a在线视频| 91丝袜国产在线播放| 国产亚洲精品久久777777| 欧美丰满嫩嫩电影| 亚洲1卡2卡3卡4卡乱码精品| 国产精品91一区| 免费精品国产| 午夜精品久久久内射近拍高清| 北条麻妃国产九九精品视频| 激情综合网五月天| 日韩一区二区三区在线| 黄色网页在线看| 91麻豆国产精品| 91精品国产91久久综合| 在线能看的av网站| 亚洲丝袜制服诱惑| 国产又大又黄又爽| 久久的精品视频| 亚洲网一区二区三区| www.夜夜爱| 成人的网站免费观看| 日本少妇在线观看| 亚洲成av人影院在线观看| 成年人视频免费在线播放| 国产精品国产精品国产专区不卡| 牛牛国产精品| 亚洲精品国产成人av在线| 精品国产乱码久久久久久婷婷| 天堂成人在线| 国产精品视频1区| 久久久国产精品| 亚洲 自拍 另类 欧美 丝袜| 伊人性伊人情综合网| 亚洲欧美另类综合| 韩日欧美一区二区| 猛男gaygay欧美视频| 午夜激情福利在线| 国产精品久久久久久久午夜片| 国产精品无码专区av免费播放| 久久成人一区二区| 美女av一区| www.色偷偷.com| 综合久久国产九一剧情麻豆| 精品国产99久久久久久宅男i| 欧美日本在线视频中文字字幕| 欧美日韩夜夜| 99热这里只有精品在线播放| 日韩美女视频一区| 女人18毛片一区二区三区| 欧美一级bbbbb性bbbb喷潮片| 欧洲grand老妇人| 91免费视频污| 天天综合天天综合色| 午夜免费播放观看在线视频| 97人人模人人爽视频一区二区| 在线观看视频日韩| 神马久久久久久久久久久| 日韩欧美一区在线观看| 亚洲三级欧美| 人人妻人人澡人人爽精品欧美一区| 国产丶欧美丶日本不卡视频| 中文字幕激情小说| 久久综合免费视频| 婷婷激情久久| 成人不卡免费视频| 懂色av中文一区二区三区天美| 亚洲搞黄视频| 久久久com| 狠狠v欧美v日韩v亚洲ⅴ| 中文字幕亚洲精品在线| 丝袜亚洲另类欧美重口| 久9re热视频这里只有精品| 乌克兰美女av| 婷婷综合在线观看| 好了av在线| 日韩资源av在线|