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

Spring Cloud Hystrix的請求合并

開發 開發工具
通常微服務架構中的依賴通過遠程調用實現,而遠程調用中最常見的問題就是通信消耗與連接數占用。在高并發的情況之下,因通信次數的增加,總的通信時間消耗將會變的不那么理想。同時,因為對依賴服務的線程池資源有限,將出現排隊等待與響應延遲的情況。為了優化這兩個問題,Hystrix提供了HystrixCollapser來實現請求的合并,以減少通信消耗和線程數的占用。

[[211861]]

通常微服務架構中的依賴通過遠程調用實現,而遠程調用中最常見的問題就是通信消耗與連接數占用。在高并發的情況之下,因通信次數的增加,總的通信時間消耗將會變的不那么理想。同時,因為對依賴服務的線程池資源有限,將出現排隊等待與響應延遲的情況。為了優化這兩個問題,Hystrix提供了HystrixCollapser來實現請求的合并,以減少通信消耗和線程數的占用。

HystrixCollapser實現了在HystrixCommand之前放置一個合并處理器,它將處于一個很短時間窗(默認10毫秒)內對同一依賴服務的多個請求進行整合并以批量方式發起請求的功能(服務提供方也需要提供相應的批量實現接口)。通過HystrixCollapser的封裝,開發者不需要去關注線程合并的細節過程,只需要關注批量化服務和處理。下面我們從HystrixCollapser的使用實例,對其合并請求的過程一探究竟。

Hystrix的請求合并示例

  1. public abstract class HystrixCollapser<BatchReturnType, ResponseType, RequestArgumentType> implements  
  2.         HystrixExecutable<ResponseType>, HystrixObservable<ResponseType> { 
  3.     ... 
  4.     public abstract RequestArgumentType getRequestArgument(); 
  5.  
  6.     protected abstract HystrixCommand<BatchReturnType> createCommand(Collection<CollapsedRequest<ResponseType, RequestArgumentType>> requests); 
  7.  
  8.     protected abstract void mapResponseToRequests(BatchReturnType batchResponse, Collection<CollapsedRequest<ResponseType, RequestArgumentType>> requests); 
  9.     ... 

從HystrixCollapser抽象類的定義中可以看到,它指定了三個不同的類型:

  • BatchReturnType:合并后批量請求的返回類型
  • ResponseType:單個請求返回的類型
  • RequestArgumentType:請求參數類型

而對于這三個類型的使用可以在它的三個抽象方法中看到:

  • RequestArgumentType getRequestArgument():該函數用來定義獲取請求參數的方法。
  • HystrixCommand<BatchReturnType> createCommand(Collection<CollapsedRequest<ResponseType, RequestArgumentType>> requests):合并請求產生批量命令的具體實現方法。
  • mapResponseToRequests(BatchReturnType batchResponse, Collection<CollapsedRequest<ResponseType, RequestArgumentType>> requests):批量命令結果返回后的處理,這里需要實現將批量結果拆分并傳遞給合并前的各個原子請求命令的邏輯。

接下來,我們通過一個簡單的示例來直觀的理解實現請求合并的過程。

假設,當前微服務USER-SERVICE提供了兩個獲取User的接口:

  • /users/{id}:根據id返回User對象的GET請求接口。
  • /users?ids={ids}:根據ids參數返回User對象列表的GET請求接口,其中ids為以逗號分割的id集合。

而在服務消費端,為這兩個遠程接口已經通過RestTemplate實現了簡單的調用,具體如下:

  1. @Service 
  2. public class UserServiceImpl implements UserService { 
  3.  
  4.     @Autowired 
  5.     private RestTemplate restTemplate; 
  6.  
  7.     @Override 
  8.     public User find(Long id) { 
  9.         return restTemplate.getForObject("http://USER-SERVICE/users/{1}"User.class, id); 
  10.     } 
  11.  
  12.     @Override 
  13.     public List<User> findAll(List<Long> ids) { 
  14.         return restTemplate.getForObject("http://USER-SERVICE/users?ids={1}", List.class, StringUtils.join(ids, ",")); 
  15.     } 
  16.  

接著,我們來實現將短時間內多個獲取單一User對象的請求命令進行合并的實現:

  • ***步:為請求合并的實現準備一個批量請求命令的實現,具體如下:
  1. public class UserBatchCommand extends HystrixCommand<List<User>> { 
  2.  
  3.     UserService userService; 
  4.     List<Long> userIds; 
  5.  
  6.     public UserBatchCommand(UserService userService, List<Long> userIds) { 
  7.         super(Setter.withGroupKey(asKey("userServiceCommand"))); 
  8.         this.userIds = userIds; 
  9.         this.userService = userService; 
  10.     } 
  11.  
  12.     @Override 
  13.     protected List<User> run() throws Exception { 
  14.         return userService.findAll(userIds); 
  15.     } 
  16.  

批量請求命令實際上就是一個簡單的HystrixCommand實現,從上面的實現中可以看到它通過調用userService.findAll方法來訪問/users?ids={ids}接口以返回User的列表結果。

  • 第二步,通過繼承HystrixCollapser實現請求合并器:
  1. public class UserCollapseCommand extends HystrixCollapser<List<User>, User, Long> { 
  2.  
  3.     private UserService userService; 
  4.     private Long userId; 
  5.  
  6.     public UserCollapseCommand(UserService userService, Long userId) { 
  7.         super(Setter.withCollapserKey(HystrixCollapserKey.Factory.asKey("userCollapseCommand")).andCollapserPropertiesDefaults( 
  8.                 HystrixCollapserProperties.Setter().withTimerDelayInMilliseconds(100))); 
  9.         this.userService = userService; 
  10.         this.userId = userId; 
  11.     } 
  12.  
  13.     @Override 
  14.     public Long getRequestArgument() { 
  15.         return userId; 
  16.     } 
  17.  
  18.     @Override 
  19.     protected HystrixCommand<List<User>> createCommand(Collection<CollapsedRequest<User, Long>> collapsedRequests) { 
  20.         List<Long> userIds = new ArrayList<>(collapsedRequests.size()); 
  21.         userIds.addAll(collapsedRequests.stream().map(CollapsedRequest::getArgument).collect(Collectors.toList())); 
  22.         return new UserBatchCommand(userService, userIds); 
  23.     } 
  24.  
  25.     @Override 
  26.     protected void mapResponseToRequests(List<User> batchResponse, Collection<CollapsedRequest<User, Long>> collapsedRequests) { 
  27.         int count = 0; 
  28.         for (CollapsedRequest<User, Long> collapsedRequest : collapsedRequests) { 
  29.             User user = batchResponse.get(count++); 
  30.             collapsedRequest.setResponse(user); 
  31.         } 
  32.     } 
  33.  

在上面的構造函數中,我們為請求合并器設置了時間延遲屬性,合并器會在該時間窗內收集獲取單個User的請求并在時間窗結束時進行合并組裝成單個批量請求。下面getRequestArgument方法返回給定的單個請求參數userId,而createCommand和mapResponseToRequests是請求合并器的兩個核心:

  • createCommand:該方法的collapsedRequests參數中保存了延遲時間窗中收集到的所有獲取單個User的請求。通過獲取這些請求的參數來組織上面我們準備的批量請求命令
  • UserBatchCommand實例。

mapResponseToRequests:在批量命令UserBatchCommand實例被觸發執行完成之后,該方法開始執行,其中batchResponse參數保存了createCommand中組織的批量請求命令的返回結果,而collapsedRequests參數則代表了每個被合并的請求。在這里我們通過遍歷批量結果batchResponse對象,為collapsedRequests中每個合并前的單個請求設置返回結果,以此完成批量結果到單個請求結果的轉換。

請求合并的原理分析

下圖展示了在未使用HystrixCollapser請求合并器之前的線程使用情況。可以看到當服務消費者同時對USER-SERVICE的/users/{id}接口發起了五個請求時,會向該依賴服務的獨立線程池中申請五個線程來完成各自的請求操作。

而在使用了HystrixCollapser請求合并器之后,相同情況下的線程占用如下圖所示。由于同一時間發生的五個請求處于請求合并器的一個時間窗內,這些發向/users/{id}接口的請求被請求合并器攔截下來,并在合并器中進行組合,然后將這些請求合并成一個請求發向USER-SERVICE的批量接口/users?ids={ids},在獲取到批量請求結果之后,通過請求合并器再將批量結果拆分并分配給每個被合并的請求。從圖中我們可以看到以來,通過使用請求合并器有效地減少了對線程池中資源的占用。所以在資源有效并且在短時間內會產生高并發請求的時候,為避免連接不夠用而引起的延遲可以考慮使用請求合并器的方式來處理和優化。

使用注解實現請求合并器

在快速入門的例子中,我們使用@HystrixCommand注解優雅地實現了HystrixCommand的定義,那么對于請求合并器是否也可以通過注解來定義呢?答案是肯定!

以上面實現的請求合并器為例,也可以通過如下方式實現:

  1. @Service 
  2. public class UserService { 
  3.  
  4.     @Autowired 
  5.     private RestTemplate restTemplate; 
  6.  
  7.     @HystrixCollapser(batchMethod = "findAll", collapserProperties = { 
  8.             @HystrixProperty(name="timerDelayInMilliseconds", value = "100"
  9.     }) 
  10.     public User find(Long id) { 
  11.         return null
  12.     } 
  13.  
  14.     @HystrixCommand 
  15.     public List<User> findAll(List<Long> ids) { 
  16.         return restTemplate.getForObject("http://USER-SERVICE/users?ids={1}", List.class, StringUtils.join(ids, ",")); 
  17.     } 

@HystrixCommand我們之前已經介紹過了,可以看到這里通過它定義了兩個Hystrix命令,一個用于請求/users/{id}接口,一個用于請求/users?ids={ids}接口。而在請求/users/{id}接口的方法上通過@HystrixCollapser注解為其創建了合并請求器,通過batchMethod屬性指定了批量請求的實現方法為findAll方法(即:請求/users?ids={ids}接口的命令),同時通過collapserProperties屬性為合并請求器設置相關屬性,這里使用@HystrixProperty(name="timerDelayInMilliseconds", value = "100")將合并時間窗設置為100毫秒。這樣通過@HystrixCollapser注解簡單而又優雅地實現了在/users/{id}依賴服務之前設置了一個批量請求合并器。

請求合并的額外開銷

雖然通過請求合并可以減少請求的數量以緩解依賴服務線程池的資源,但是在使用的時候也需要注意它所帶來的額外開銷:用于請求合并的延遲時間窗會使得依賴服務的請求延遲增高。比如:某個請求在不通過請求合并器訪問的平均耗時為5ms,請求合并的延遲時間窗為10ms(默認值),那么當該請求的設置了請求合并器之后,最壞情況下(在延遲時間窗結束時才發起請求)該請求需要15ms才能完成。

由于請求合并器的延遲時間窗會帶來額外開銷,所以我們是否使用請求合并器需要根據依賴服務調用的實際情況來選擇,主要考慮下面兩個方面:

  • 請求命令本身的延遲。如果依賴服務的請求命令本身是一個高延遲的命令,那么可以使用請求合并器,因為延遲時間窗的時間消耗就顯得莫不足道了。
  • 延遲時間窗內的并發量。如果一個時間窗內只有1-2個請求,那么這樣的依賴服務不適合使用請求合并器,這種情況下不但不能提升系統性能,反而會成為系統瓶頸,因為每個請求都需要多消耗一個時間窗才響應。相反,如果一個時間窗內具有很高的并發量,并且服務提供方也實現了批量處理接口,那么使用請求合并器可以有效的減少網絡連接數量并極大地提升系統吞吐量,此時延遲時間窗所增加的消耗就可以忽略不計了。

【本文為51CTO專欄作者“翟永超”的原創稿件,轉載請通過51CTO聯系作者獲取授權】

戳這里,看該作者更多好文

責任編輯:武曉燕 來源: 51CTO專欄
相關推薦

2023-02-03 15:16:42

SpringHystrix

2022-12-08 08:27:18

HystrixQPS數據

2022-09-15 15:25:47

spring-微服務

2017-07-04 17:35:46

微服務架構Spring Clou

2017-07-03 09:50:07

Spring Clou微服務架構

2021-11-16 11:45:00

SpringSpring ClouJava

2018-06-01 23:08:01

Spring Clou微服務服務器

2017-09-20 09:46:38

Spring BootSpring Clou內存

2023-11-26 00:42:07

微服務日志

2022-03-30 08:21:57

合并HTTP

2022-08-11 09:17:38

架構開發

2021-06-04 08:48:46

Spring ClouMaven Centr版本

2024-05-20 09:19:45

請求合并容器

2022-05-26 00:00:00

網絡請求合并優化

2018-07-24 13:01:52

前端優化前端性能瀏覽器

2018-07-27 15:43:24

Spring Clou管理架構

2023-12-19 09:33:40

微服務監控

2025-06-09 01:01:00

2020-12-30 07:49:32

KubernetesJava Spring Clo

2017-09-05 14:05:11

微服務spring clou路由
點贊
收藏

51CTO技術棧公眾號

国产偷人妻精品一区二区在线| aa片在线观看视频在线播放| 成人在线观看亚洲| 国产精品一二三四五| 午夜精品福利视频| 欧美特级黄色录像| 国产高清亚洲| 黄色成人av网| 亚洲精蜜桃久在线| 色婷婷激情五月| 麻豆91在线看| 97超碰色婷婷| 在线观看亚洲大片短视频| 精品国产不卡一区二区| 色综合久久久久综合| 正在播放91九色| 熟妇人妻av无码一区二区三区| 日韩精品乱码av一区二区| 久久福利视频网| 免费毛片视频网站| 综合中文字幕| 欧美日韩色综合| 国产素人在线观看| 国产淫片在线观看| 国产日韩亚洲欧美综合| 99久久精品久久久久久ai换脸| 六月丁香婷婷综合| 激情91久久| 久久精品国产久精国产一老狼| 男男做爰猛烈叫床爽爽小说 | 亚洲成在人线免费观看| 欧美日韩免费在线视频| 亚洲午夜精品久久久久久人妖| 老司机福利在线视频| 久久精品这里都是精品| 国产精品三区www17con| 国产乱码一区二区| 首页综合国产亚洲丝袜| 97精品国产97久久久久久| 人妻久久一区二区| 日韩一区二区在线| 日韩极品精品视频免费观看| 亚洲av毛片在线观看| 成人国产在线| 欧美性猛交xxxxxxxx| 黑人糟蹋人妻hd中文字幕| 国内小视频在线看| 亚洲精品老司机| 黄色影视在线观看| 成人短视频在线| 日韩一区中文字幕| 亚洲精品一卡二卡三卡四卡| 成人在线免费公开观看视频| 久久精品夜色噜噜亚洲aⅴ| 久久视频在线观看中文字幕| 天堂在线观看视频| 99久久久无码国产精品| 国产在线欧美日韩| 三级做a全过程在线观看| 99久久综合99久久综合网站| 国产精品久久波多野结衣| 午夜精品久久久久久久99| 韩国毛片一区二区三区| 亚洲一区二区三区四区视频| 99热这里只有精品1| 国产一区中文字幕| 亚洲综合第一页| 亚洲av无码乱码国产麻豆| 国产99久久久国产精品| 国产一区精品在线| 日韩av免费观影| 久久久久久久综合| 一级做a爰片久久| 国产黄色小视频在线| 一区二区三区.www| 成人免费视频91| 中文字幕 在线观看| 日本国产一区二区| 深夜黄色小视频| 亚洲美女色播| 欧美一二三四在线| 人妻 丝袜美腿 中文字幕| 亚洲免费专区| 搡老女人一区二区三区视频tv | 亚洲人成在线观看一区二区| 91免费版看片| 最新欧美色图| 欧美喷潮久久久xxxxx| 男人添女人荫蒂国产| 台湾亚洲精品一区二区tv| 一区二区三区无码高清视频| 老熟妇高潮一区二区三区| 欧美日韩伊人| 国产精品福利在线观看| 99久久婷婷国产一区二区三区| 丁香网亚洲国际| 日韩国产在线一区| 97caopor国产在线视频| 欧美日韩另类视频| 免费在线观看污网站| 成人av激情人伦小说| 一区二区三区四区在线观看视频| 五月天av网站| 亚洲专区免费| 5566av亚洲| 国内三级在线观看| 亚洲一区二区四区蜜桃| 少妇网站在线观看| 精品欧美午夜寂寞影院| 俺去了亚洲欧美日韩| 日韩三级视频在线| 国产做a爰片久久毛片| 久久久久久九九九九| 美女免费久久| 精品久久久久久中文字幕| 岛国毛片在线播放| 亚洲va久久久噜噜噜久久| 久久99精品视频一区97| 少妇一级淫片日本| av不卡在线观看| 女女同性女同一区二区三区按摩| 性孕妇free特大另类| 日韩欧美一区二区在线视频| 国产真人做爰视频免费| 精品91视频| 91在线视频免费| 丁香婷婷在线观看| 欧美性xxxxxxx| 色哟哟视频在线| 亚洲影视一区| 国产在线a不卡| 国产主播福利在线| 欧美日韩精品二区| 无码人妻精品一区二区三区99不卡| 性xxxx欧美老肥妇牲乱| 国产免费观看久久黄| 国产污视频在线| 欧美午夜性色大片在线观看| 看全色黄大色黄女片18| 欧美激情麻豆| 91视频网页| 九七久久人人| 欧美区视频在线观看| 在线观看免费小视频| 毛片一区二区| 欧美lavv| 欧美日韩大片| 亚洲欧美在线一区| 国产又大又黄视频| 99国产精品国产精品毛片| 3d动漫一区二区三区| 99re6热只有精品免费观看| 久久夜色精品亚洲噜噜国产mv| 亚洲一级在线播放| 亚洲欧美怡红院| www激情五月| 欧美精品国产| 成人在线免费网站| 理论片午夜视频在线观看| 亚洲国产精品美女| 久久青青草视频| 久久午夜羞羞影院免费观看| 成人久久久久久久久| 亚洲涩涩av| 国产精品白嫩初高中害羞小美女| 韩日视频在线| 欧美女孩性生活视频| 欧美成欧美va| 成人妖精视频yjsp地址| 男女视频网站在线观看| 亚洲理论电影片| 国产精品免费看久久久香蕉| 日本激情视频在线观看| 日韩久久久精品| 国产精品自拍视频一区| 26uuuu精品一区二区| 丰满少妇在线观看| 亚洲综合五月| 国产一区自拍视频| 日韩一区二区三区免费| 久久久999精品视频| 99热这里只有精品3| 天天操天天干天天综合网| 国产成人无码精品久久二区三| 日本aⅴ亚洲精品中文乱码| 一区精品视频| 成人精品毛片| 国产精品白丝jk喷水视频一区| 久久综合之合合综合久久| 精品国一区二区三区| 无码人妻精品一区二区三区9厂| 国产精品久久久久久久久快鸭| 搡的我好爽在线观看免费视频| 尹人成人综合网| 日韩欧美国产二区| 中文字幕日韩在线| 国产精品va在线| av网址在线播放| 亚洲欧美国产日韩中文字幕| 国产毛片在线视频| 欧美色视频日本高清在线观看| 婷婷丁香综合网| 99视频一区二区| 狠狠干狠狠操视频| 亚洲少妇诱惑| 成人免费看片视频在线观看| 伊人成综合网伊人222| 91国产在线免费观看| 性欧美videohd高精| 色在人av网站天堂精品| 国产在线观看高清视频| 精品国产a毛片| 97成人在线观看| 色一情一乱一乱一91av| 九九九在线视频| 国产精品美女一区二区| www.色多多| 福利电影一区二区| 欧美一级视频在线| 三级在线观看一区二区| 激情五月宗合网| 欧美另类综合| 人人妻人人澡人人爽精品欧美一区| 男人的天堂久久| 97人摸人人澡人人人超一碰| 欧美日韩女优| 热久久免费视频精品| aa国产成人| 欧美日韩国产91| 精品黄色免费中文电影在线播放 | 欧美成年黄网站色视频| 亚洲欧美日韩在线高清直播| 欧美一级在线免费观看| 91精品国产一区二区| 在线观看视频中文字幕| 欧美性色xo影院| 久久久久久少妇| 午夜精品一区二区三区免费视频 | 亚洲一区二区在线播放| 狠狠久久综合| 国产精品一区二区三| 经典三级一区二区| 日韩av快播网址| 日本少妇一区| 国产精品 欧美在线| 欧美大电影免费观看| 51精品在线观看| 蜜桃视频在线观看播放| 欧美一级高清免费| 天堂av中文在线观看| 奇米四色中文综合久久| 波多野结衣亚洲| 国产精品99久久久久久久久久久久 | 色噜噜狠狠一区二区| 麻豆视频一区二区| 五月天激情播播| 国产成人综合在线| 国产免费a级片| 91最新地址在线播放| 欧美色图亚洲激情| 欧美激情一区三区| 在线免费看av网站| 亚洲综合激情网| 国产 欧美 日韩 在线| 欧美色videos| 伊人免费在线观看| 欧美一区二区三区免费| 亚洲av少妇一区二区在线观看| 欧美精品一区二区三区久久久 | 99久久国产免费看| 中文字幕日韩三级片| 国产欧美日韩另类一区| 色哟哟一一国产精品| 亚洲精品大片www| 日韩激情在线播放| 欧美怡红院视频| 国产精品美女一区| 欧美日韩小视频| 久久国产视频精品| 欧美艳星brazzers| 欧美成人精品网站| 欧美日本在线视频| 亚洲乱码国产乱码精品精软件| 日韩黄色av网站| 国产高清av在线| 久久影院资源网| 二区三区不卡| 国产精品视频自拍| 韩国理伦片久久电影网| 国产成人看片| 国产一区二区三区探花| 日本aa在线观看| 国产精品日韩欧美一区| 精品日韩久久久| 国产a精品视频| 法国空姐电影在线观看| √…a在线天堂一区| 亚洲黄色激情视频| 欧美日韩高清一区| 手机看片1024国产| 久久视频在线视频| 黄视频网站在线观看| 成人免费自拍视频| 青青操综合网| 咪咪色在线视频| 久久激情视频| 欧美性猛交xx| 国产性天天综合网| 国产精品不卡av| 欧美婷婷六月丁香综合色| 欧美特级特黄aaaaaa在线看| 中文字幕成人精品久久不卡| 色老头在线观看| 国产专区欧美专区| 亚洲自拍都市欧美小说| 一本色道久久综合亚洲精品婷婷 | 久久久.com| 麻豆精品一区二区三区视频| 日韩欧美aⅴ综合网站发布| 亚洲成a人片在线| 一区二区av在线| 黄色成人在线网| 亚洲在线第一页| 国产亚洲电影| 欧美亚洲国产成人| 国产成人精品午夜视频免费| 丁香六月激情综合| 色又黄又爽网站www久久| 丰满肥臀噗嗤啊x99av| 亚洲人成五月天| 黑人巨大精品| 国产亚洲精品自在久久| 国产综合久久| 在线a免费观看| 亚洲国产精品av| 中文字幕乱码人妻二区三区| 日韩精品免费在线播放| 国产色播av在线| 91视频免费进入| 亚洲国产精品成人| 亚洲理论中文字幕| 亚洲国产精品av| 这里只有精品999| 亚洲欧美中文日韩v在线观看| 国精产品一区一区三区mba下载| 97久久人人超碰caoprom欧美| 天天揉久久久久亚洲精品| 成年人小视频网站| 国产喂奶挤奶一区二区三区| www.国产高清| 亚洲香蕉在线观看| 成人免费影院| 久久精品人成| 日韩精彩视频在线观看| 偷拍女澡堂一区二区三区| 日韩欧美在线一区| 视频一区二区三区国产 | 肉色欧美久久久久久久免费看| 精品在线一区| 日韩午夜av在线| 亚洲精品视频大全| 欧美日韩性视频| 嫩草研究院在线观看| 日韩av男人的天堂| 国产99久久精品一区二区300| 免费看污污网站| 国产精品免费av| 国产精品玖玖玖| 午夜精品福利电影| 丝袜av一区| 男人午夜视频在线观看| 一区二区三区中文字幕电影| 天堂在线观看av| 国产成一区二区| 久久资源中文字幕| 国产裸体视频网站| 亚洲午夜久久久久久久久久久| 日韩电影网址| 国产精品入口夜色视频大尺度| 久久精品影视| 日本xxxx免费| 天天亚洲美女在线视频| 在线观看完整版免费| 7777精品伊久久久大香线蕉语言| 亚洲精品一二| 欧美熟妇激情一区二区三区| 在线视频一区二区三| 污污在线观看| 久久99精品久久久久子伦| 日韩在线一二三区| 97在线观看免费高| 亚洲第一网中文字幕| 成人短视频app| 中文字幕免费在线不卡| 国产91丝袜在线播放0| 国产亚洲欧美日韩高清| 欧美黄色小视频| 国产99精品一区| 国产免费一区二区三区最新6| 91黄色小视频|