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

SpringCloud原理之Feign

開(kāi)發(fā) 前端
Feign是聲明性Web服務(wù)客戶端。它使編寫(xiě)Web服務(wù)客戶端更加容易。要使用Feign,請(qǐng)創(chuàng)建一個(gè)接口并對(duì)其進(jìn)行注釋。它具有可插入注釋支持,包括Feign注釋和JAX-RS注釋。

[[419659]]

絮叨

前面一節(jié)我們學(xué)習(xí)了一下eureka,我們來(lái)回顧一下,首先它是一個(gè)cs架構(gòu),分為客戶端和服務(wù)端,

客戶端 也分為 生成者和消費(fèi)者,也就是服務(wù)提供方和服務(wù)消費(fèi)方,具體客戶端的作用如下

  • 當(dāng)客戶端啟動(dòng)的時(shí)候向服務(wù)端注冊(cè)當(dāng)前服務(wù)
  • 并和服務(wù)端維持心跳,用的是后臺(tái)線程
  • 拉取服務(wù)端的各個(gè)節(jié)點(diǎn)集合,然后定時(shí)更新服務(wù)的信息到本地,因?yàn)榭蛻舳艘彩菚?huì)緩存服務(wù)節(jié)點(diǎn)信息的
  • 當(dāng)服務(wù)掛掉的時(shí)候,監(jiān)聽(tīng)shutdown 然后上報(bào)自己掛掉的狀態(tài)給服務(wù)端

服務(wù)端

  • 啟動(dòng)后,從其他節(jié)點(diǎn)獲取服務(wù)注冊(cè)信息。
  • 運(yùn)行過(guò)程中,定時(shí)運(yùn)行evict任務(wù),剔除沒(méi)有按時(shí)renew的服務(wù)(包括非正常停止和網(wǎng)絡(luò)故障的服務(wù))。
  • 運(yùn)行過(guò)程中,接收到的register、renew、cancel請(qǐng)求,都會(huì)同步至其他注冊(cè)中心節(jié)點(diǎn),分布式數(shù)據(jù)同步(AP)
  • 運(yùn)行過(guò)程中,自我保護(hù)機(jī)制。等等
  • SpringCloud原理之eureka

什么是Feign

Feign是一種聲明式、模板化的HTTP客戶端(僅在Application Client中使用)。聲明式調(diào)用是指,就像調(diào)用本地方法一樣調(diào)用遠(yuǎn)程方法,無(wú)需感知操作遠(yuǎn)程http請(qǐng)求。Spring Cloud的聲明式調(diào)用, 可以做到使用 HTTP請(qǐng)求遠(yuǎn)程服務(wù)時(shí)能就像調(diào)用本地方法一樣的體驗(yàn),開(kāi)發(fā)者完全感知不到這是遠(yuǎn)程方法,更感知不到這是個(gè)HTTP請(qǐng)求。Feign的應(yīng)用,讓Spring Cloud微服務(wù)調(diào)用像Dubbo一樣,Application Client直接通過(guò)接口方法調(diào)用Application Service,而不需要通過(guò)常規(guī)的RestTemplate構(gòu)造請(qǐng)求再解析返回?cái)?shù)據(jù)。它解決了讓開(kāi)發(fā)者調(diào)用遠(yuǎn)程接口就跟調(diào)用本地方法一樣,無(wú)需關(guān)注與遠(yuǎn)程的交互細(xì)節(jié),更無(wú)需關(guān)注分布式環(huán)境開(kāi)發(fā)。

Feign是聲明性Web服務(wù)客戶端。它使編寫(xiě)Web服務(wù)客戶端更加容易。要使用Feign,請(qǐng)創(chuàng)建一個(gè)接口并對(duì)其進(jìn)行注釋。它具有可插入注釋支持,包括Feign注釋和JAX-RS注釋。Feign還支持可插拔編碼器和解碼器。Spring Cloud添加了對(duì)Spring MVC注釋的支持,并支持使用HttpMessageConvertersSpring Web中默認(rèn)使用的注釋。當(dāng)使用Feign時(shí),Spring Cloud集成了Ribbon和Eureka以提供負(fù)載平衡的http客戶端。

使用Feign開(kāi)發(fā)時(shí)的應(yīng)用部署結(jié)構(gòu)

Feign是如何設(shè)計(jì)的?

原生的Feign

雖然我們用SpringCloud全家桶比較多,但是其實(shí)呢?他只是對(duì)原生的fegin做了一些封裝,所以刨根問(wèn)底的話,我們還是多了解了解原生的Fegin,對(duì)于我們理解Spring Cloud feign是很有幫助的

Feign使用簡(jiǎn)介

基本用法

基本的使用如下所示,一個(gè)對(duì)于canonical Retrofit sample的適配。

  1. interface GitHub { 
  2.  // RequestLine注解聲明請(qǐng)求方法和請(qǐng)求地址,可以允許有查詢參數(shù) 
  3.  @RequestLine("GET /repos/{owner}/{repo}/contributors"
  4.  List<Contributor> contributors(@Param("owner") String owner, @Param("repo") String repo); 
  5. static class Contributor { 
  6.  String login; 
  7.  int contributions; 
  8. public static void main(String... args) { 
  9.  GitHub github = Feign.builder() 
  10.             .decoder(new GsonDecoder()) 
  11.             .target(GitHub.class, "https://api.github.com"); 
  12.  // Fetch and print a list of the contributors to this library. 
  13.  List<Contributor> contributors = github.contributors("OpenFeign""feign"); 
  14.  for (Contributor contributor : contributors) { 
  15.   System.out.println(contributor.login + " (" + contributor.contributions + ")"); 
  16.  } 

自定義

Feign 有許多可以自定義的方面。舉個(gè)簡(jiǎn)單的例子,你可以使用 Feign.builder() 來(lái)構(gòu)造一個(gè)擁有你自己組件的API接口。如下:

  1. interface Bank { 
  2.  @RequestLine("POST /account/{id}"
  3.  Account getAccountInfo(@Param("id") String id); 
  4. ... 
  5. // AccountDecoder() 是自己實(shí)現(xiàn)的一個(gè)Decoder 
  6. Bank bank = Feign.builder().decoder(new AccountDecoder()).target(Bank.class, https://api.examplebank.com); 

Feign 動(dòng)態(tài)代理

 

Feign 的默認(rèn)實(shí)現(xiàn)是 ReflectiveFeign,通過(guò) Feign.Builder 構(gòu)建。再看代碼前,先了解一下 Target 這個(gè)對(duì)象。

  1. public interface Target<T> { 
  2.   // 接口的類(lèi)型 
  3.   Class<T> type(); 
  4.  
  5.   // 代理對(duì)象的名稱,默認(rèn)為url,負(fù)載均衡時(shí)有用 
  6.   String name(); 
  7.   // 請(qǐng)求的url地址,eg: https://api/v2 
  8.   String url(); 

其中 Target.type 是用來(lái)生成代理對(duì)象的,url 是 Client 對(duì)象發(fā)送請(qǐng)求的地址。

  1. public Feign build() { 
  2.     // client 有三種實(shí)現(xiàn) JdkHttp/ApacheHttp/okHttp,默認(rèn)是 jdk 的實(shí)現(xiàn) 
  3.     SynchronousMethodHandler.Factory synchronousMethodHandlerFactory = 
  4.         new SynchronousMethodHandler.Factory(client, retryer, requestInterceptors, logger, 
  5.                                              logLevel, decode404, closeAfterDecode, propagationPolicy); 
  6.     ParseHandlersByName handlersByName = 
  7.         new ParseHandlersByName(contract, options, encoder, decoder, queryMapEncoder, 
  8.                                 errorDecoder, synchronousMethodHandlerFactory); 
  9.     return new ReflectiveFeign(handlersByName, invocationHandlerFactory, queryMapEncoder); 

總結(jié):介紹一下幾個(gè)主要的參數(shù):

  • Client 這個(gè)沒(méi)什么可說(shuō)的,有三種實(shí)現(xiàn) JdkHttp/ApacheHttp/okHttp
  • RequestInterceptor 請(qǐng)求攔截器
  • Contract REST 注解解析器,默認(rèn)為 Contract.Default(),即支持 Feign 的原生注解。
  • InvocationHandlerFactory 生成 JDK 動(dòng)態(tài)代理,實(shí)際執(zhí)行是委托給了 MethodHandler。

生成代理對(duì)象

  1. public <T> T newInstance(Target<T> target) { 
  2.     // 1. Contract 將 target.type 接口類(lèi)上的方法和注解解析成 MethodMetadata, 
  3.     //    并轉(zhuǎn)換成內(nèi)部的MethodHandler處理方式 
  4.     Map<String, MethodHandler> nameToHandler = targetToHandlersByName.apply(target); 
  5.     Map<Method, MethodHandler> methodToHandler = new LinkedHashMap<Method, MethodHandler>(); 
  6.     List<DefaultMethodHandler> defaultMethodHandlers = new LinkedList<DefaultMethodHandler>(); 
  7.  
  8.     for (Method method : target.type().getMethods()) { 
  9.         if (method.getDeclaringClass() == Object.class) { 
  10.             continue
  11.         } else if (Util.isDefault(method)) { 
  12.             DefaultMethodHandler handler = new DefaultMethodHandler(method); 
  13.             defaultMethodHandlers.add(handler); 
  14.             methodToHandler.put(method, handler); 
  15.         } else { 
  16.             methodToHandler.put(method, nameToHandler.get(Feign.configKey(target.type(), method))); 
  17.         } 
  18.     } 
  19.  
  20.     // 2. 生成 target.type 的 jdk 動(dòng)態(tài)代理對(duì)象 
  21.     InvocationHandler handler = factory.create(target, methodToHandler); 
  22.     T proxy = (T) Proxy.newProxyInstance(target.type().getClassLoader(), 
  23.                                          new Class<?>[]{target.type()}, handler); 
  24.  
  25.     for (DefaultMethodHandler defaultMethodHandler : defaultMethodHandlers) { 
  26.         defaultMethodHandler.bindTo(proxy); 
  27.     } 
  28.     return proxy; 

總結(jié):newInstance 生成了 JDK 的動(dòng)態(tài)代理,從 factory.create(target, methodToHandler) 也可以看出 InvocationHandler 實(shí)際委托給了 methodToHandler。methodToHandler 默認(rèn)是 SynchronousMethodHandler.Factory 工廠類(lèi)創(chuàng)建的。

MethodHandler 方法執(zhí)行器

ParseHandlersByName.apply 生成了每個(gè)方法的執(zhí)行器 MethodHandler,其中最重要的一步就是通過(guò) Contract 解析 MethodMetadata。

  1. public Map<String, MethodHandler> apply(Target key) { 
  2.     // 1. contract 將接口類(lèi)中的方法和注解解析 MethodMetadata 
  3.     List<MethodMetadata> metadata = contract.parseAndValidatateMetadata(key.type()); 
  4.     Map<String, MethodHandler> result = new LinkedHashMap<String, MethodHandler>(); 
  5.     for (MethodMetadata md : metadata) { 
  6.         // 2. buildTemplate 實(shí)際上將 Method 方法的參數(shù)轉(zhuǎn)換成 Request 
  7.         BuildTemplateByResolvingArgs buildTemplate; 
  8.         if (!md.formParams().isEmpty() && md.template().bodyTemplate() == null) { 
  9.             // 2.1 表單 
  10.             buildTemplate = new BuildFormEncodedTemplateFromArgs(md, encoder, queryMapEncoder); 
  11.         } else if (md.bodyIndex() != null) { 
  12.             // 2.2 @Body 注解 
  13.             buildTemplate = new BuildEncodedTemplateFromArgs(md, encoder, queryMapEncoder); 
  14.         } else { 
  15.             // 2.3 其余 
  16.             buildTemplate = new BuildTemplateByResolvingArgs(md, queryMapEncoder); 
  17.         } 
  18.         // 3. 將 metadata 和 buildTemplate 封裝成 MethodHandler 
  19.         result.put(md.configKey(), 
  20.                    factory.create(key, md, buildTemplate, options, decoder, errorDecoder)); 
  21.     } 
  22.     return result; 

總結(jié):這個(gè)方法由以下幾步:

Contract 統(tǒng)一將方法解析 MethodMetadata(*),這樣就可以通過(guò)實(shí)現(xiàn)不同的 Contract 適配各種 REST 聲明式規(guī)范。buildTemplate 實(shí)際上將 Method 方法的參數(shù)轉(zhuǎn)換成 Request。將 metadata 和 buildTemplate 封裝成 MethodHandler。

這樣通過(guò)以上三步就創(chuàng)建了一個(gè) Target.type 的代理對(duì)象 proxy,這個(gè)代理對(duì)象就可以像訪問(wèn)普通方法一樣發(fā)送 Http 請(qǐng)求,其實(shí)和 RPC 的 Stub 模型是一樣的。了解 proxy 后,其執(zhí)行過(guò)程其實(shí)也就一模了然。

Feign 調(diào)用過(guò)程

FeignInvocationHandler#invoke

  1. private final Map<Method, MethodHandler> dispatch; 
  2. public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { 
  3.     ... 
  4.     // 每個(gè)Method方法對(duì)應(yīng)一個(gè)MethodHandler 
  5.     return dispatch.get(method).invoke(args); 

總結(jié):和上面的結(jié)論一樣,實(shí)際的執(zhí)行邏輯實(shí)際上是委托給了 MethodHandler。

SynchronousMethodHandler#invoke

  1. // 發(fā)起 http 請(qǐng)求,并根據(jù) retryer 進(jìn)行重試 
  2. public Object invoke(Object[] argv) throws Throwable { 
  3.     // template 將 argv 參數(shù)構(gòu)建成 Request 
  4.     RequestTemplate template = buildTemplateFromArgs.create(argv); 
  5.     Options options = findOptions(argv); 
  6.     Retryer retryer = this.retryer.clone(); 
  7.  
  8.     // 調(diào)用client.execute(request, options) 
  9.     while (true) { 
  10.         try { 
  11.             return executeAndDecode(template, options); 
  12.         } catch (RetryableException e) { 
  13.             try { 
  14.                 // 重試機(jī)制 
  15.                 retryer.continueOrPropagate(e); 
  16.             } catch (RetryableException th) { 
  17.                 ... 
  18.             } 
  19.             continue
  20.         } 
  21.     } 

總結(jié):invoke 主要進(jìn)行請(qǐng)求失敗的重試機(jī)制,至于具體執(zhí)行過(guò)程委托給了 executeAndDecode 方法。

  1. // 一是編碼生成Request;二是http請(qǐng)求;三是解碼生成Response 
  2. Object executeAndDecode(RequestTemplate template, Options options) throws Throwable { 
  3.     // 1. 調(diào)用攔截器 RequestInterceptor,并根據(jù) template 生成 Request 
  4.     Request request = targetRequest(template); 
  5.     // 2. http 請(qǐng)求 
  6.     Response response = client.execute(request, options); 
  7.  // 3. response 解碼 
  8.     if (Response.class == metadata.returnType()) { 
  9.         byte[] bodyData = Util.toByteArray(response.body().asInputStream()); 
  10.         return response.toBuilder().body(bodyData).build(); 
  11.     } 
  12.     ... 
  13.  
  14. Request targetRequest(RequestTemplate template) { 
  15.     // 執(zhí)行攔截器 
  16.     for (RequestInterceptor interceptor : requestInterceptors) { 
  17.         interceptor.apply(template); 
  18.     } 
  19.     // 生成 Request 
  20.     return target.apply(template); 

這個(gè)是原生feign的調(diào)用過(guò)程,總的來(lái)說(shuō)分為2部 一個(gè)是 客戶端的封裝,一個(gè)調(diào)用方法的封裝

Spring Cloud Feign 的原理解析

我們前面看了原生的feign之后呢?對(duì)于Spring Cloud的Feign的話理解起來(lái)就很簡(jiǎn)單了,我們知道Spring cloud 是基于SpringBoot SpringBoot 又是基于Spring,那么Spring就是一個(gè)膠水框架,它就是把各個(gè)組件把它封裝起來(lái),所以呢,這樣就簡(jiǎn)單很多了嘛

小六六在這邊就不一一的給大家演示SpringCloud 是如何使用Feign的了,小六六默認(rèn)大家都懂,哈哈,那么就直接說(shuō)原理吧

工作原理

我們來(lái)想想平時(shí)我們使用feign的時(shí)候,會(huì)是一個(gè)怎么樣的流程

  • 添加了 Spring Cloud OpenFeign 的依賴
  • 在 SpringBoot 啟動(dòng)類(lèi)上添加了注解 @EnableFeignCleints
  • 按照 Feign 的規(guī)則定義接口 DemoService, 添加@FeignClient 注解
  • 在需要使用 Feign 接口 DemoService 的地方, 直接利用@Autowire 進(jìn)行注入
  • 使用接口完成對(duì)服務(wù)端的調(diào)用

那我們基于這些步驟來(lái)分析分析,本文并不會(huì)說(shuō)非常深入去看每一行的源碼

  • SpringBoot 應(yīng)用啟動(dòng)時(shí), 由針對(duì) @EnableFeignClient 這一注解的處理邏輯觸發(fā)程序掃描 classPath中所有被@FeignClient 注解的類(lèi), 這里以 XiaoLiuLiuService 為例, 將這些類(lèi)解析為 BeanDefinition 注冊(cè)到 Spring 容器中
  • Sping 容器在為某些用的 Feign 接口的 Bean 注入 XiaoLiuLiuService 時(shí), Spring 會(huì)嘗試從容器中查找 XiaoLiuLiuService 的實(shí)現(xiàn)類(lèi)
  • 由于我們從來(lái)沒(méi)有編寫(xiě)過(guò) XiaoLiuLiuService 的實(shí)現(xiàn)類(lèi), 上面步驟獲取到的 XiaoLiuLiuService 的實(shí)現(xiàn)類(lèi)必然是 feign 框架通過(guò)擴(kuò)展 spring 的 Bean 處理邏輯, 為 XiaoLiuLiuService 創(chuàng)建一個(gè)動(dòng)態(tài)接口代理對(duì)象, 這里我們將其稱為 XiaoLiuLiuServiceProxy 注冊(cè)到spring 容器中。
  • Spring 最終在使用到 XiaoLiuLiuService 的 Bean 中注入了 XiaoLiuLiuServiceProxy 這一實(shí)例。
  • 當(dāng)業(yè)務(wù)請(qǐng)求真實(shí)發(fā)生時(shí), 對(duì)于 XiaoLiuLiuService 的調(diào)用被統(tǒng)一轉(zhuǎn)發(fā)到了由 Feign 框架實(shí)現(xiàn)的 InvocationHandler 中, InvocationHandler 負(fù)責(zé)將接口中的入?yún)⑥D(zhuǎn)換為 HTTP 的形式, 發(fā)到服務(wù)端, 最后再解析 HTTP 響應(yīng), 將結(jié)果轉(zhuǎn)換為 Java 對(duì)象, 予以返回。

所以我們基于原生的feign來(lái)分析分析,其實(shí)就是多了2步,前面的原生feign會(huì)幫助我們生成代理對(duì)象,這個(gè)是我們調(diào)用方法的主體,也是這個(gè)代理對(duì)象才有能力去請(qǐng)求http請(qǐng)求,那么spring就想辦法,把這一類(lèi)的對(duì)象放到spring的上下文中,那么我們下次調(diào)用的時(shí)候,這個(gè)對(duì)象當(dāng)然就有了http請(qǐng)求的能力了。

結(jié)束

 

我是小六六,三天打魚(yú),兩天曬網(wǎng),今天我的分享就到了。

 

責(zé)任編輯:武曉燕 來(lái)源: 六脈神劍小六六
相關(guān)推薦

2025-01-15 13:30:48

FeignHTTPJava

2021-04-30 08:19:32

SpringCloud客戶端負(fù)載Ribbo

2022-05-26 08:12:52

debugSpringFeign

2021-03-26 06:01:45

日志MongoDB存儲(chǔ)

2022-07-04 08:14:24

架構(gòu)演變Tomcat容器架構(gòu)

2024-07-02 10:58:53

2021-07-07 06:38:33

SpringCloud路由配置定位原理分析

2023-07-17 08:02:44

ZuulIO反應(yīng)式

2022-05-13 09:05:49

Hystrix熔斷器

2022-11-17 17:19:44

SpringEureka

2023-07-20 10:04:37

底層路由配置

2021-06-30 07:34:21

SpringCloudHystrix 監(jiān)控

2021-07-02 08:20:53

SpringCloudHystrix Tur監(jiān)控

2023-02-07 07:43:27

微服務(wù)應(yīng)用框架

2025-08-12 00:22:00

Spring監(jiān)控Hystrix

2012-12-03 16:57:37

HDFS

2024-03-27 09:01:53

微服務(wù)FeignToken

2020-11-18 11:26:45

SpringCloudZuulJava

2022-06-02 15:34:45

vmstorage監(jiān)控

2022-03-22 07:37:04

FeignSpringRibbon
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

国产成人亚洲综合| 夜夜躁日日躁狠狠久久88av| 精品国偷自产一区二区三区| 日批视频在线播放| 青青草伊人久久| 久久精品在线播放| 日韩少妇一区二区| 亚洲四虎影院| 亚洲精品久久7777| 蜜桃导航-精品导航| 中文字幕在线观看精品| 精品成人在线| 日韩中文字幕国产| 91精品国产自产| 香蕉成人在线| 一本色道久久综合精品竹菊| 国产一二三四五| 麻豆导航在线观看| 国产凹凸在线观看一区二区| 国产成+人+综合+亚洲欧洲| 日韩一级片大全| 伊甸园亚洲一区| 欧美va亚洲va在线观看蝴蝶网| 超碰影院在线观看| 91超碰免费在线| 亚洲欧洲av色图| 秋霞在线观看一区二区三区| 成人精品在线播放| 加勒比av一区二区| 国产精品免费观看在线| 欧美三级韩国三级日本三斤在线观看| 99热国内精品| 一区二区三区国产视频| 国产精品久久不卡| 国产精品17p| 日韩视频一区二区| 爱豆国产剧免费观看大全剧苏畅| 一区二区乱码| 亚洲午夜视频在线| 国产视频在线观看网站| 精品孕妇一区二区三区| 日本一区二区三区免费乱视频| 国产69精品久久久久9999apgf| 97精品久久人人爽人人爽| 久久亚洲不卡| 欧美在线免费观看| 黄网在线观看视频| 99精品免费视频| 韩国精品久久久999| 免费无码毛片一区二区app| 国产精品精品国产一区二区| 丝袜亚洲另类欧美重口| 国产又黄又粗视频| 北条麻妃国产九九九精品小说| 亚洲区免费影片| 人妻体内射精一区二区| 国产成人1区| 国产一区二区三区高清在线观看| 亚洲成人日韩在线| 精品亚洲成人| 日韩在线激情视频| 国产日产精品一区二区三区的介绍| 欧美艳星介绍134位艳星| 在线视频欧美性高潮| 人人人妻人人澡人人爽欧美一区| 欧美极品中文字幕| 中文字幕欧美亚洲| 全网免费在线播放视频入口| 欧美久久成人| 91精品国产色综合久久不卡98口 | www.久久com| 欧洲一区在线| 亚洲国产私拍精品国模在线观看| 91av在线免费| 精品免费av| 精品国产一区二区三区久久| 日本天堂中文字幕| 99国产精品| 国产成人精品最新| 国产精品毛片一区二区在线看舒淇| 韩国欧美国产1区| 国产精品国产精品国产专区蜜臀ah | 亚洲国产第一| 秋霞av国产精品一区| 国产乡下妇女三片| 国产精品一区免费在线观看| 精品国产免费人成电影在线观...| 飘雪影视在线观看免费观看 | 国产微拍精品一区| 日韩 欧美一区二区三区| 成人字幕网zmw| 日本成人动漫在线观看| 国产拍欧美日韩视频二区| 中文字幕日韩精品一区二区| 欧美黑人猛交的在线视频| 狠狠久久亚洲欧美专区| 亚洲男人天堂av在线| 麻豆成人入口| 日日噜噜噜夜夜爽亚洲精品 | 国产视频在线播放| 午夜av一区二区| www.色就是色.com| 麻豆一区一区三区四区| www.亚洲一区| 特黄视频免费看| 国产在线日韩欧美| 欧美性天天影院| 日本性爱视频在线观看| 欧美视频一区二区在线观看| 尤物网站在线观看| 99久久这里只有精品| 日韩av黄色在线观看| 亚洲精品喷潮一区二区三区| 欧美国产精品劲爆| 精品国产免费av| 嫩呦国产一区二区三区av| 亚洲视频在线播放| 久久精品国产亚洲av无码娇色| 蜜臀久久99精品久久久久久9| 国产精品视频福利| 国产盗摄在线观看| 欧美视频一区二区三区| asian性开放少妇pics| 黄色亚洲精品| 成人久久一区二区三区| 成人在线免费公开观看视频| 五月天激情小说综合| wwwww在线观看| 天天做综合网| 国产精品一区二区三区在线播放| 欧洲成人av| 五月婷婷久久丁香| 激情综合激情五月| 综合一区二区三区| 成人亚洲欧美一区二区三区| 9色在线视频| 色八戒一区二区三区| 黄色国产在线观看| 一本色道久久精品| 国新精品乱码一区二区三区18| 超鹏97在线| 日韩一区二区三区三四区视频在线观看 | 色婷婷狠狠五月综合天色拍| 久久久久久综合网天天| 亚洲成人精品女人久久久| 亚洲麻豆国产自偷在线| www.色就是色.com| 在线成人直播| 亚洲在线免费观看| av超碰免费在线| 3atv一区二区三区| 午夜精品一区二区三级视频| 精品一区二区三区在线观看国产| 亚洲精品电影在线一区| 91九色综合| 中文字幕最新精品| 国产精品人人妻人人爽| 亚洲女同女同女同女同女同69| 欧美性受xxxxxx黑人xyx性爽| 全球成人免费直播| 成人免费午夜电影| 永久免费网站在线| 亚洲高清av在线| 高清欧美性猛交xxxx黑人猛交| 日韩和一区二区| 91麻豆国产香蕉久久精品| 日日鲁鲁鲁夜夜爽爽狠狠视频97| 欧美18免费视频| 日韩美女视频中文字幕| 91caoporm在线视频| 777奇米成人网| 久久成人国产精品入口| 91在线porny国产在线看| 日韩精品一区二区三区久久| 神马久久一区二区三区| 国产精品丝袜久久久久久高清| 蜜桃视频在线观看www社区| 日韩欧美国产一二三区| 国产在线观看99| 久久综合色鬼综合色| 日本xxxx黄色| 欧美日韩一卡| 欧美一区二区三区四区在线观看地址| 久久69成人| 久久久久久久久久久免费 | 亚洲欧美日韩区| 91 中文字幕| 午夜精品久久久久久久久久 | av中文字幕网址| 雨宫琴音一区二区在线| 天堂精品一区二区三区| 91精品国产自产精品男人的天堂 | 中文字幕精品网| www.色呦呦| 欧美午夜精品一区二区蜜桃| 亚洲成人生活片| 久久久电影一区二区三区| 国产九九九视频| 欧美亚洲免费| 9191国产视频| 青草国产精品| 精品国产乱码久久久久久蜜柚| 日韩黄色三级在线观看| 68精品久久久久久欧美| 国产区在线观看| 亚洲人成免费电影| 丰满人妻一区二区三区免费视频 | 亚洲av电影一区| 91精品国产免费| 高潮无码精品色欲av午夜福利| 亚洲图片欧美综合| 国产乱子轮xxx农村| 91免费视频观看| 又黄又色的网站| 麻豆精品国产传媒mv男同| 欧美二区在线视频| 国产精品vip| 大地资源第二页在线观看高清版| 久久av免费| 久久国产精品 国产精品| 久久精品免视看国产成人| 国产精品美乳一区二区免费| 欧美a级在线观看| 九九精品在线观看| 欧美一级二级三级区| 亚洲片av在线| 日韩电影在线观看完整版| 精品国产电影一区二区| 国产伦精品一区二区三区视频痴汉| 色中色一区二区| 超碰超碰超碰超碰| 亚洲aⅴ怡春院| 国产精品99re| 亚洲大尺度视频在线观看| 欧美国产日韩在线观看成人 | 日韩最新中文字幕| 国产精品精品| 特级黄色录像片| 国产大片一区| 综合色婷婷一区二区亚洲欧美国产| 国产一区二区区别| 秋霞久久久久久一区二区| 亚洲传媒在线| 任我爽在线视频精品一| 亚洲人和日本人hd| 久久伊人一区| 免费看成人吃奶视频在线| 久久青青草原| 国产成人精品免费视| 欧美精品久久| 欧美色图激情小说| 正在播放亚洲| 你懂的成人av| 妞干网视频在线观看| 尹人成人综合网| 九九爱精品视频| 国产亚洲精品v| 久久久久狠狠高潮亚洲精品| 日韩一区欧美二区| 亚洲黄色小视频在线观看| 久色婷婷小香蕉久久| 国产欧美激情视频| 国产精品2024| 久久久久亚洲无码| 久久影视一区二区| 久久久视频6r| 日韩码欧中文字| 欧美片一区二区| 狠狠色香婷婷久久亚洲精品| 狠狠狠狠狠狠狠| 欧美电影一区二区| 亚洲国产成人一区二区| 日韩精品视频在线| 91网在线播放| 九九热精品视频国产| 欧美gv在线观看| 国产免费一区二区三区在线观看| 久久av网站| 欧美日韩在线一二三| 国产精品精品国产一区二区| 草b视频在线观看| 日韩电影在线免费观看| 天天色天天干天天色| 99精品欧美一区二区三区小说 | 91黄色在线观看| 国产欧美综合视频| 亚洲男人天堂2023| 成人日韩欧美| 日本欧美国产在线| 国产激情精品一区二区三区| 久久精品美女| 中文精品电影| 少妇性l交大片| 国产成人激情av| 手机看片日韩av| 亚洲高清三级视频| 怡红院男人的天堂| 精品国产99国产精品| av中文天堂在线| 久久久久国色av免费观看性色| 日韩电影av| 国产精品久久7| 91综合久久| 免费av网址在线| 国产成人精品1024| 黄色录像免费观看| 色哟哟在线观看一区二区三区| 99在线观看免费| 中文字幕综合在线| 成人午夜视屏| 国产精品久久波多野结衣| 99精品国产一区二区三区| 欧美韩国日本在线| 懂色av中文字幕一区二区三区| 老司机精品免费视频| 欧美日韩一区二区三区| www.国产黄色| 日韩有码在线播放| 三上悠亚亚洲一区| 精品一区二区久久久久久久网站| 欧美一区综合| 欧美国产日韩另类| 国产精品三级av| 婷婷激情五月综合| 精品夜色国产国偷在线| hd国产人妖ts另类视频| 99国产超薄肉色丝袜交足的后果 | 久久艳片www.17c.com| 欧美色片在线观看| 欧美日韩视频在线一区二区观看视频| 亚洲成人资源| 韩国三级视频在线观看| 一区二区在线看| 精品国自产拍在线观看| 久久精品精品电影网| 外国成人毛片| 日韩 欧美 自拍| 国产一区二区剧情av在线| 天堂在线中文视频| 欧美性大战久久久久久久蜜臀| 免费看男男www网站入口在线 | 日韩在线观看成人| 欧洲美女精品免费观看视频| 亚洲国产欧美日韩| 日本网站在线观看一区二区三区 | 午夜国产精品视频| 日本r级电影在线观看| 亚洲免费观看高清完整版在线观看| 一本色道久久综合精品婷婷| 丝袜情趣国产精品| 精品视频在线观看网站| 成人午夜视频免费观看| 国内精品第一页| 久久精品久久国产| 亚洲精品按摩视频| 欧美特黄aaaaaaaa大片| 日本免费高清一区| 美女性感视频久久| www深夜成人a√在线| 日韩视频一区在线观看| 91豆花视频在线播放| 久久久久久久久久久久久久一区| 鲁大师影院一区二区三区| 一级片手机在线观看| 欧美三级日韩在线| 快射视频在线观看| 成人午夜电影免费在线观看| 亚洲激情国产| 欧美 日韩 成人| 欧美精品乱人伦久久久久久| 婷婷丁香在线| 精品国产免费一区二区三区| 日韩1区2区日韩1区2区| 极品魔鬼身材女神啪啪精品| 精品久久久久久久久久久久久久久| 高潮在线视频| 亚洲春色在线| 东方aⅴ免费观看久久av| 在线观看 亚洲| 久久亚洲电影天堂| 秋霞影视一区二区三区| 污视频网站观看| 亚洲国产精品一区二区久久| 偷拍自拍在线视频| 成人做爽爽免费视频| 亚洲国产精品第一区二区| 无码少妇一区二区| 日韩久久久久久| 成人日韩精品| 国产freexxxx性播放麻豆| 日本一区二区在线不卡| 亚洲乱色熟女一区二区三区| 国产不卡一区二区在线播放| 综合日韩在线| 国产不卡在线观看视频| 欧美精品一区二区久久久| 精品久久福利| 日本三级免费网站| 亚洲精品一二三| 国产爆初菊在线观看免费视频网站|