精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

91欧美精品成人综合在线观看| 色av中文字幕一区| 国产91美女视频| 国产高清视频在线观看| 美女国产一区二区三区| 两个人的视频www国产精品| 午夜视频在线免费看| 欧美aa在线观看| 国产欧美日韩视频一区二区 | 992tv快乐视频| 午夜视频福利在线| 国模娜娜一区二区三区| 久久久免费观看| jizzjizzjizz国产| 日本成人中文| 欧美一区二区视频免费观看| 高清在线观看免费| 呦呦在线视频| 国产精品三级视频| 国产伦精品一区二区三区免| 中文字幕乱码视频| 国产精品mv在线观看| 亚洲二区中文字幕| 999这里有精品| 成人影院网站| 午夜国产精品一区| 三年中国中文在线观看免费播放| 三级毛片在线免费看| 国产精品亚洲一区二区三区在线| 国产成人97精品免费看片| 久久伊人成人网| 天天射天天综合网| 国产亚洲美女精品久久久| 一边摸一边做爽的视频17国产| 国产精品美女午夜爽爽| 欧美日韩一区二区精品| 精品国产一区二区三区无码| 男人天堂手机在线| 中文字幕欧美三区| 免费看污久久久| 天堂在线视频免费| gogo大胆日本视频一区| 99在线观看| 午夜久久久久久噜噜噜噜| 九色|91porny| 成人网在线免费观看| 波多野结衣一区二区在线| 国产精品美女久久久| 久久久久久久999| 免费在线观看国产精品| 欧美ab在线视频| 久久的精品视频| www日韩在线| 中文字幕乱码亚洲无线精品一区| 啊v视频在线一区二区三区 | 图片区小说区国产精品视频| 人妻av无码专区| 青春草在线视频| 一区二区三区中文在线| 日本高清视频免费在线观看| 18在线观看的| 亚洲一区二区三区在线播放| 久久久久久久香蕉| 538视频在线| 欧美午夜视频一区二区| 男人亚洲天堂网| 国精产品一区二区三区有限公司| 色妞www精品视频| 国产wwwxx| 人人玩人人添人人澡欧美| 欧美久久久久中文字幕| 1314成人网| 爱爱精品视频| 国产视频久久久久久久| 人妻精品久久久久中文字幕| 精品成人影院| 日韩在线播放av| 欧美日韩国产精品综合| 日韩天堂av| 国产精品第三页| 99精品视频在线播放免费| 国产成人在线视频网站| 国产九色精品| 国产福利在线视频| 中文字幕永久在线不卡| 国产美女作爱全过程免费视频| 免费毛片b在线观看| 色老汉一区二区三区| 在线观看免费污视频| 亚洲国产中文在线二区三区免| 亚洲精品国产品国语在线| 手机免费看av| 欧美激情综合色综合啪啪| 欧美亚洲国产日韩2020| 中文字幕在线视频第一页| 国产精品亚洲一区二区三区在线| 蜜桃麻豆www久久国产精品| 欧美性天天影视| 欧美日韩国产综合新一区 | 欧美日韩综合在线观看| 日本欧美在线看| 古典武侠综合av第一页| 国产一级免费在线观看| 伊人色综合久久天天人手人婷| 69堂免费视频| 美女精品视频在线| 亚洲天堂免费观看| 麻豆一区产品精品蜜桃的特点| 久久亚洲色图| 国产高清一区二区三区| av在线女优影院| 午夜精品一区二区三区电影天堂| 亚洲免费看av| 天堂一区二区三区四区| 欧美另类极品videosbest最新版本| 欧美日韩乱国产| 国产白丝精品91爽爽久久| 亚洲精品视频一区二区三区| 美女高潮在线观看| 日韩欧美亚洲国产另类| 国产一二三四视频| 在线综合亚洲| 国产精品区一区二区三在线播放| 黄色网址免费在线观看| 91福利在线观看| 亚洲欧美在线不卡| 欧美日韩一区二区高清| 成人黄色在线观看| 成人影院免费观看| 欧美丝袜一区二区| 好吊色视频一区二区三区| 亚洲欧美一区在线| 成人免费大片黄在线播放| h视频在线播放| 在线免费av一区| www.色天使| 99视频精品| 国产精品视频免费一区二区三区| 老司机在线永久免费观看| 欧美亚洲日本一区| 欧美老熟妇乱大交xxxxx| 18成人免费观看视频| 成人国产一区二区| 日本资源在线| 欧美本精品男人aⅴ天堂| 青娱乐av在线| 国产在线精品一区二区不卡了| 一道精品一区二区三区| 国产成人精品一区二区三区在线 | 欧美日韩一区二区视频在线| 久草在线中文最新视频| 亚洲精品mp4| 久久夜色精品亚洲| 91亚洲国产成人精品一区二区三 | 吴梦梦av在线| 国产一区二区三区黄网站| 久久久av一区| www.av在线.com| 亚洲国产视频直播| 亚洲最大的黄色网| 亚洲影视在线| 日产精品一线二线三线芒果| 99只有精品| 欧美成年人视频网站| 性做久久久久久久| 午夜亚洲国产au精品一区二区| 添女人荫蒂视频| 久久久亚洲人| 综合久久国产| 爱高潮www亚洲精品| 66m—66摸成人免费视频| 久久经典视频| 91精品国产福利在线观看| 国产乱国产乱老熟300| 成人免费三级在线| 人妻熟妇乱又伦精品视频| 国产成人精品999在线观看| 国产精品黄页免费高清在线观看| 九七电影韩国女主播在线观看| 日韩一区二区中文字幕| 日韩成人在线免费视频| 国产午夜亚洲精品理论片色戒 | 成人av资源网址| 欧洲成人在线视频| 免费在线午夜视频| 欧美精品v国产精品v日韩精品| 国产极品美女高潮无套嗷嗷叫酒店| 91视视频在线观看入口直接观看www | 九九热精品在线观看| 91丨porny丨首页| 91女神在线观看| 樱桃成人精品视频在线播放| 日本成人黄色免费看| 国产一区二区三区黄网站| 2020国产精品视频| gogogogo高清视频在线| 亚洲欧美国产精品久久久久久久| 97人人爽人人爽人人爽| 黑人精品xxx一区一二区| 欧美成人777| www国产成人| 三级网站免费看| 日韩福利电影在线| www.射射射| 99久久www免费| 女女同性女同一区二区三区91| 国产精品久久久久久久久久辛辛| 日本一区二区三区四区视频| 日韩伦理av| 色狠狠久久aa北条麻妃| 日韩午夜影院| 精品美女在线观看| 国产精品天天操| 在线观看视频一区二区欧美日韩| 久久精品亚洲无码| 亚洲日本va午夜在线影院| 中文字幕在线观看免费高清| 成人免费看的视频| 亚洲成人手机在线观看| 日本亚洲天堂网| 日本免费黄视频| 亚洲国产激情| 国产精品久久国产| 亚洲最新av| 在线播放 亚洲| 成人羞羞视频在线看网址| 国产精品初高中精品久久| av国产精品| 国产精品一区二区三区毛片淫片| 中文字幕在线直播| 26uuu另类亚洲欧美日本一| av免费在线免费| 久久久国产成人精品| 春暖花开成人亚洲区| 亚洲欧美日韩一区在线| 性xxxxbbbb| 日韩精品极品在线观看播放免费视频| 欧美一级性视频| 精品日本一线二线三线不卡| 精品人妻午夜一区二区三区四区 | 一本大道av伊人久久综合| 国产乱码久久久久久| 亚洲综合激情小说| 青娱乐在线视频免费观看| 一区二区三区欧美久久| 亚洲成人生活片| 亚洲精品福利视频网站| 69av视频在线| 一区二区成人在线视频| 欧美又粗又大又长| 亚洲一区自拍偷拍| 久久老司机精品视频| 午夜视频在线观看一区二区| www日韩精品| 欧美日韩在线影院| 天天操中文字幕| 在线免费不卡电影| 一级黄色a视频| 欧美一二三区在线观看| 亚洲欧美强伦一区二区| 亚洲国产精品电影在线观看| 视频一区二区在线播放| 亚洲视频在线观看视频| 在线播放麻豆| 欧美精品性视频| www.51av欧美视频| 国产精品高清在线| 9999精品免费视频| 99久久免费国| 五月激激激综合网色播| 日韩一区国产在线观看| 午夜免费一区| 日韩欧美猛交xxxxx无码| 国产精品嫩草99av在线| 三级在线视频观看| 高清日韩电视剧大全免费| 一女三黑人理论片在线| 中文字幕免费在线观看视频一区| 暗呦丨小u女国产精品| 天天综合日日夜夜精品| 一区二区三区麻豆| 91精品国产品国语在线不卡| 姝姝窝人体www聚色窝| 尤物精品国产第一福利三区| huan性巨大欧美| 欧洲一区二区视频| 精品国产伦一区二区三区观看说明| 国产日本一区二区三区| 精品国产一区一区二区三亚瑟| 中文字幕中文字幕一区三区| 国产视频一区欧美| 中文字幕资源在线观看| 99精品一区二区| 熟女少妇a性色生活片毛片| 午夜欧美在线一二页| 自拍偷拍色综合| 精品国产伦理网| 午夜伦理在线| 国产91精品高潮白浆喷水| 天堂综合在线播放| 蜜桃欧美视频| 精品成人国产| 黄色片免费网址| 国产免费成人在线视频| 久久久久久久极品内射| 欧美色精品天天在线观看视频| 国精品人妻无码一区二区三区喝尿 | 无码一区二区精品| 亚洲人成小说网站色在线 | 制服丝袜国产精品| 久久久久久久久亚洲精品| 欧美国产日韩一区二区三区| 999国产精品亚洲77777| 黄色99视频| 国语自产精品视频在线看8查询8| 人人干人人干人人| 久久亚洲精精品中文字幕早川悠里 | 亚洲天堂小视频| 中文字幕亚洲一区二区va在线| 国产www在线| 欧美精品一区二区三区四区| 麻豆av在线导航| 91精品久久久久久| 国产欧美亚洲精品a| 色欲av无码一区二区人妻| 国产福利一区二区三区在线视频| 久久久国产一级片| 91成人在线精品| 福利在线视频导航| 欧美在线亚洲在线| 欧美午夜寂寞| 鲁一鲁一鲁一鲁一色| aaa欧美日韩| 好吊操这里只有精品| 精品99一区二区三区| 污污片在线免费视频| 91亚洲午夜在线| 一区二区三区四区在线观看国产日韩| 91制片厂毛片| 国产精品毛片无遮挡高清| 国产一级片免费在线观看| 亚洲精品影视在线观看| 中文不卡1区2区3区| 久久亚洲免费| 久久久久.com| 日本二区在线观看| 欧美伊人精品成人久久综合97 | 日本欧美黄网站| 国产日韩欧美一区二区三区| 久久久免费视频网站| 久久久久久99精品| 中文字幕第三页| 久久久www成人免费精品张筱雨| a一区二区三区亚洲| 特色特色大片在线| 国产v综合v亚洲欧| 精品国产免费观看| 亚洲丝袜在线视频| 日韩国产一二三区| 91精品一区二区三区四区| 岛国一区二区在线观看| 日韩美女一级片| 亚洲人成五月天| 欧美成人福利| 伊人再见免费在线观看高清版 | 国产精品美女诱惑| 99亚洲视频| 99久久99久久精品免费看小说.| 欧美喷水一区二区| 毛片网站在线看| 日本不卡一区| 国产一区视频导航| 日本熟妇毛茸茸丰满| 亚洲一区二区国产| 亚洲免费一区| 国产原创中文在线观看| 国产日韩欧美一区二区三区乱码| 在线免费观看视频网站| 欧美大片免费观看在线观看网站推荐 | 欧美日韩成人激情| 国产第一页在线视频| 欧美日韩国产高清视频| 国产真实乱偷精品视频免| 国产污视频在线看| 一本大道久久加勒比香蕉| 亚洲视频国产| 欧美激情成人网| 一区二区三区在线视频观看| 日本在线一二三| 成人淫片在线看| 亚洲综合99| 私库av在线播放| 亚洲欧美色婷婷| 亚洲精品午夜| 手机在线成人免费视频| 亚洲va欧美va人人爽| 亚洲1卡2卡3卡4卡乱码精品| 国产一区二区久久久| 美女国产一区二区三区| 成年人免费看毛片|