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

深入解析 SpringCloud 的負(fù)載衡器 Loadbalancer

開發(fā)
本文結(jié)合源碼的方式深入分析了SpringCloud Loadbalancer負(fù)載均衡調(diào)用時(shí)所涉及的內(nèi)一些內(nèi)容。

這期我們結(jié)合之前幾篇關(guān)于nacos客戶端緩存來說明一下集成loadbalancer后服務(wù)調(diào)用時(shí)可能存在的問題和解決方案。

一、詳解Spring Cloud loadbalancer服務(wù)調(diào)用機(jī)制

1. loadbalancer使用說明

首先我們引出本文所使用的loadbalancer依賴,可以看到版本為3.1.5,作為服務(wù)消費(fèi)者我們通過loadbalancer作為負(fù)載均衡器替換到默認(rèn)的ribbon,同時(shí)我們還引入caffeine觸發(fā)Loadbalancer完成基于caffeine的服務(wù)緩存裝配:

<!--使用loadbalancer負(fù)載均衡器替換ribbon-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-loadbalancer</artifactId>
            <version>3.1.5</version>
        </dependency>

<dependency>
            <groupId>com.github.ben-manes.caffeine</groupId>
            <artifactId>caffeine</artifactId>
            <version>2.9.3</version>
        </dependency>

對應(yīng)我們還是給出本文項(xiàng)目的架構(gòu)圖,可以看到當(dāng)前項(xiàng)目給出兩個(gè)服務(wù)提供者nacos-provider和一個(gè)服務(wù)消費(fèi)者nacos-consumer,當(dāng)服務(wù)消費(fèi)者從nacos拉取到可用服務(wù)之后,會(huì)通過權(quán)重算法調(diào)用可用的服務(wù)示例:

對應(yīng)的我們也給出本文服務(wù)消費(fèi)者所用到的負(fù)載均衡算法的配置:

/**
     * 將負(fù)載均衡算法設(shè)置為權(quán)重算法
     *
     * @param environment
     * @param loadBalancerClientFactory
     * @return
     */
    @Bean
    ReactorLoadBalancer<ServiceInstance> weightedLoadBalancer(Environment environment, LoadBalancerClientFactory loadBalancerClientFactory) {
        String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);
        return new WeightedLoadBalancer(loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class), name);

    }

同時(shí)我們也給出WeightedLoadBalancer 這個(gè)權(quán)重算法的實(shí)現(xiàn),讀者可基于代碼自行了解一下:

/**
 * 基于權(quán)重的負(fù)載均衡算法
 */
public class WeightedLoadBalancer implements ReactorServiceInstanceLoadBalancer {


    /**
     * loadbalancer 提供的訪問當(dāng)前服務(wù)的名稱
     */
    final String serviceId;

    /**
     * 基于nacos緩存獲取服務(wù)列表
     */
    ObjectProvider<ServiceInstanceListSupplier> serviceInstanceListSupplierProvider;


    public WeightedLoadBalancer(ObjectProvider<ServiceInstanceListSupplier> serviceInstanceListSupplierProvider, String serviceId) {
      this.serviceId = serviceId;
      this.serviceInstanceListSupplierProvider = serviceInstanceListSupplierProvider;
    }

    @Autowired
    private NacosDiscoveryProperties nacosDiscoveryProperties;

    @Override
    public Mono<Response<ServiceInstance>> choose(Request request) {
        //如果serviceInstanceListSupplierProvider不存在則采用NoopServiceInstanceListSupplier返回空實(shí)例列表
        ServiceInstanceListSupplier supplier = this.serviceInstanceListSupplierProvider.getIfAvailable(NoopServiceInstanceListSupplier::new);
        //基于服務(wù)獲取策略supplier略獲取可用實(shí)例,采用權(quán)重算法返回本地調(diào)用的服務(wù)實(shí)例
        return supplier.get(request)
                .next()
                .map(serviceInstances -> new DefaultResponse(NacosBalancer.getHostByRandomWeight3(serviceInstances)));
    }




}

2. loadbalancer自動(dòng)裝配初始化

基于上述的配置,loadbalancer進(jìn)行自動(dòng)裝配的時(shí)候就會(huì)識(shí)別到Caffeine和CaffeineCacheManager的存在,于是觸發(fā)caffeineLoadBalancerCacheManager的裝配,該管理類內(nèi)部有一個(gè)cacheMap,本次裝配將會(huì)以cachingServiceInstanceListSupplierCache為key,caffeine cache為value作為鍵值對存入,后續(xù)所有的服務(wù)緩存實(shí)例信息都會(huì)存儲(chǔ)在這個(gè)鍵值對中的caffeine cache中:

對應(yīng)的我們也給出自動(dòng)裝配的源碼,如下所示,可以看到因?yàn)镃affeine和CaffeineCacheManager的存在,我們觸發(fā)了CaffeineBasedLoadBalancerCacheManager的裝配:

@Configuration(proxyBeanMethods = false)
 //Caffeine和CaffeineCacheManager都存在觸發(fā)自動(dòng)裝配
 @ConditionalOnClass({ Caffeine.class, CaffeineCacheManager.class })
 protected static class CaffeineLoadBalancerCacheManagerConfiguration {

  @Bean(autowireCandidate = false)
  @ConditionalOnMissingBean
  LoadBalancerCacheManager caffeineLoadBalancerCacheManager(LoadBalancerCacheProperties cacheProperties) {
  //生成CaffeineBasedLoadBalancerCacheManager管理類
   return new CaffeineBasedLoadBalancerCacheManager(cacheProperties);
  }

 }

通過查看CaffeineBasedLoadBalancerCacheManager內(nèi)部初始化邏輯,最終可以看到setCacheNames這個(gè)方法,該方法就會(huì)執(zhí)行就是我們上文中所說的以cachingServiceInstanceListSupplierCache為key,以caffeineCache這個(gè)緩存為value的鍵值對初始化工作:

public CaffeineCacheManager(String... cacheNames) {
  //基于
  setCacheNames(Arrays.asList(cacheNames));
 }

public void setCacheNames(@Nullable Collection<String> cacheNames) {
  if (cacheNames != null) {
   for (String name : cacheNames) {
    this.cacheMap.put(name, createCaffeineCache(name));
   }
   this.dynamic = false;
  }
  else {
   this.dynamic = true;
  }
 }

初始化后的調(diào)試結(jié)果如下,我們可以很直觀的看到這個(gè)記錄服務(wù)實(shí)例的緩存鍵值對:

3. loadbalancer如何基于緩存完成服務(wù)調(diào)用

默認(rèn)情況下loadbalancer緩存是沒有任何信息的,假設(shè)我們nacos-consumer即服務(wù)消費(fèi)者發(fā)起對nacos-provider的調(diào)用,loadbalancer是如何拿到服務(wù)實(shí)例的信息呢?

實(shí)際上,在loadbalancer初始化的時(shí)候,服務(wù)實(shí)例查詢組件ServiceInstanceListSupplier內(nèi)部聚合了nacos的服務(wù)查詢組件DiscoveryClientServiceInstanceListSupplier,所以當(dāng)我們通過feign發(fā)起調(diào)用時(shí),loadbalancer的執(zhí)行步驟為:

  • loadbalancer代理會(huì)先通過ServiceInstanceListSupplier到緩存中查看是否存在服務(wù)提供者nacos-provider的信息,如果不為空直接返回調(diào)用即可,如果不存在則執(zhí)行步驟2。
  • 嘗試到基于nacos服務(wù)查詢組件DiscoveryClientServiceInstanceListSupplier查看是否存在nacos-provider如果有直接返回。
  • ServiceInstanceListSupplier基于nacos服務(wù)組件的結(jié)果拿到實(shí)例信息,將其緩存起來,并基于負(fù)載均衡策略返回服務(wù)實(shí)例給服務(wù)消費(fèi)者進(jìn)行調(diào)用。

基于上圖我們給出loadbalancer自動(dòng)裝配的服務(wù)查詢組件源碼,可以看到ServiceInstanceListSupplier通過withBlockingDiscoveryClient方法聚合了nacos服務(wù)查詢組件:

@Bean
  @ConditionalOnBean(DiscoveryClient.class)
  @ConditionalOnMissingBean
  @Conditional(DefaultConfigurationCondition.class)
  public ServiceInstanceListSupplier discoveryClientServiceInstanceListSupplier(
    ConfigurableApplicationContext context) {
    //ServiceInstanceListSupplier通過withBlockingDiscoveryClient方法聚合了nacos服務(wù)查詢組件
   return ServiceInstanceListSupplier.builder().withBlockingDiscoveryClient().withCaching().build(context);
  }

當(dāng)我們發(fā)起服務(wù)調(diào)用時(shí),feign代理會(huì)走到FeignBlockingLoadBalancerClient上,其內(nèi)部會(huì)執(zhí)行如下步驟:

  • 通過loadBalancerClient的choose嘗試上文的多級緩存查詢服務(wù)示例的步驟,并完成負(fù)載均衡選取服務(wù)實(shí)例返回。
  • 基于上述實(shí)例生成請求地址和參數(shù)。
  • 發(fā)起請求并響應(yīng)結(jié)果給服務(wù)消費(fèi)者。
@Override
 public Response execute(Request request, Request.Options options) throws IOException {
   //......
  //嘗試從緩存中拿服務(wù),然后執(zhí)行負(fù)載均衡調(diào)用
  ServiceInstance instance = loadBalancerClient.choose(serviceId, lbRequest);
   //......
   //基于上述實(shí)例生成請求地址和參數(shù)
  String reconstructedUrl = loadBalancerClient.reconstructURI(instance, originalUri).toString();
  Request newRequest = buildRequest(request, reconstructedUrl);
  LoadBalancerProperties loadBalancerProperties = loadBalancerClientFactory.getProperties(serviceId);
  //發(fā)起請求
  return executeWithLoadBalancerLifecycleProcessing(delegate, options, newRequest, lbRequest, lbResponse,
    supportedLifecycleProcessors, loadBalancerProperties.isUseRawStatusCodeInResponseData());
 }

步入loadBalancerClient.choose的調(diào)用路徑,我們就可以看到上文所說的多級緩存查詢步驟:

  • 到lb緩存即cacheManager通過cachingServiceInstanceListSupplierCache查詢是否存在服務(wù)提供者nacos-provider的實(shí)例。
  • 如果沒有則到nacos中的查詢。
  • 基于查詢結(jié)果寫入lb的cache中:
public CachingServiceInstanceListSupplier(ServiceInstanceListSupplier delegate, CacheManager cacheManager) {
 
  this.serviceInstances = CacheFlux.lookup(key -> {
   // 到lb緩存管理拿緩存
   Cache cache = cacheManager.getCache(SERVICE_INSTANCE_CACHE_NAME);
   //......
   //查看lb緩存有沒有
   List<ServiceInstance> list = cache.get(key, List.class);
   //如果沒有返回空
   if (list == null || list.isEmpty()) {
    return Mono.empty();
   }
   return Flux.just(list).materialize().collectList();
  }, 
  //若lb緩存沒有則觸發(fā)onCacheMissResume回調(diào),就會(huì)通過delegate.get()觸發(fā)nacos服務(wù)組件查詢
  delegate.getServiceId()).onCacheMissResume(delegate.get().take(1))
    .andWriteWith((key, signals) -> Flux.fromIterable(signals).dematerialize()
    .doOnNext(instances -> {//doOnNext得到nacos緩存后寫入lb緩存中
     Cache cache = cacheManager.getCache(SERVICE_INSTANCE_CACHE_NAME);
     if (cache == null) {
      //.......
     }
     else {
       //寫入lb緩存
      cache.put(key, instances);
     }
    }).then());
 }

4. loadbalancer緩存更新策略

默認(rèn)情況下,lb緩存每35s完成一次更新,這也就意味著緩存在lb緩存中的服務(wù)實(shí)例信息只有在存入后的35s內(nèi)是有效的,為了避免定時(shí)輪詢更新服務(wù)實(shí)例的開銷,lb的緩存采用了一種惰性更新的思想。

假設(shè)我們此時(shí)此刻緩存將nacos-provider的實(shí)例信息緩存到lb裝配的CaffeineCache中,服務(wù)消費(fèi)者在35s之后發(fā)起調(diào)用,此時(shí)CaffeineCache就會(huì)基于緩存服務(wù)實(shí)例的起始時(shí)間判斷緩存是否過期,如果發(fā)現(xiàn)過期則直接返回null,讓loadbalancer到nacos緩存中獲取nacos-provider實(shí)例信息并覆蓋掉當(dāng)前過期的緩存:

對應(yīng)我們給出cache緩存默認(rèn)過期時(shí)間的默認(rèn)值,即位于LoadBalancerCacheProperties 中對應(yīng)ttl 的賦值:

@ConfigurationProperties("spring.cloud.loadbalancer.cache")
public class LoadBalancerCacheProperties {

 //.......

 private Duration ttl = Duration.ofSeconds(35);

 //......
}

為方便說明,我們再次貼出lb緩存查詢的源碼,如下所示, cache.get(key, List.class)這一段就是從Loadbalancer的緩存中獲取服務(wù)實(shí)例的信息,如果過期也會(huì)返回null,然后到nacos緩存中獲取信息并更新過期緩存:

public CachingServiceInstanceListSupplier(ServiceInstanceListSupplier delegate, CacheManager cacheManager) {
 
  this.serviceInstances = CacheFlux.lookup(key -> {
   // 到lb緩存管理拿緩存
   Cache cache = cacheManager.getCache(SERVICE_INSTANCE_CACHE_NAME);
   //......
   //查看lb緩存有沒有查詢服務(wù)實(shí)例信息,如果不存在或者過期則返回null
   List<ServiceInstance> list = cache.get(key, List.class);
   //如果沒有返回空
   if (list == null || list.isEmpty()) {
    return Mono.empty();
   }
   return Flux.just(list).materialize().collectList();
  }, 
  //若lb緩存沒有則觸發(fā)onCacheMissResume回調(diào),就會(huì)通過delegate.get()觸發(fā)nacos服務(wù)組件查詢
  delegate.getServiceId()).onCacheMissResume(delegate.get().take(1))
    .andWriteWith((key, signals) -> Flux.fromIterable(signals).dematerialize()
    .doOnNext(instances -> {//doOnNext得到nacos緩存后寫入lb緩存中
     Cache cache = cacheManager.getCache(SERVICE_INSTANCE_CACHE_NAME);
     if (cache == null) {
      //.......
     }
     else {
       //寫入lb緩存,并更新寫入時(shí)間
      cache.put(key, instances);
     }
    }).then());
 }

步入Loadbalancer緩存CaffeineCache的get方法,最終就會(huì)來到BoundedLocalCache的getIfPresent,這段就是查詢緩存并判斷過期的核心實(shí)現(xiàn),對應(yīng)步驟為:

  • 基于要調(diào)用的服務(wù)實(shí)例的字符串(以本文示例來說就是nacos-provider)作為key進(jìn)行查詢,并得到一個(gè)node。
  • 通過node的writeTime比對當(dāng)前時(shí)間now判斷是否過期。
  • 如果過期返回null,讓loadbalancer到nacos緩存中獲取最新的值并覆蓋掉當(dāng)前緩存。
  • 如果沒過期則直接返回。

對應(yīng)的我們也給出這段說明的源碼,讀者可結(jié)合表述和源碼注釋理解上述步驟:

public @Nullable V getIfPresent(Object key, boolean recordStats) {
    Node<K, V> node = data.get(nodeFactory.newLookupKey(key));
    //......
 //獲取服務(wù)實(shí)例信息
    V value = node.getValue();
    
    //......
    //判斷是否過期,如果過期則返回null
    if (hasExpired(node, now) || (collectValues() && (value == null))) {
      //......
      return null;
    }

  //......
  //沒過期直接返回緩存中的服務(wù)實(shí)例信息
    return value;
  }

二、關(guān)于loadbalancer的一些注意事項(xiàng)

經(jīng)過上述的說明相信筆者對于loadbalancer的底層工作機(jī)制有所了解,所以需要做灰度發(fā)布或者服務(wù)平滑下線的場景,我們建議將loadbalancer緩存直接禁用,一律采用nacos緩存,這一點(diǎn)筆者在之前的文章中也分析過nacos客戶端的中的服務(wù)實(shí)例緩存是實(shí)時(shí)刷新的,只要服務(wù)端感知到服務(wù)下線就會(huì)以RPC的方式通知nacos客戶端更新緩存。

對應(yīng)的我們也給出禁用緩存的配置:

spring.cloud.loadbalancer.cache.enabled=false

三、小結(jié)

本文結(jié)合源碼的方式深入分析了SpringCloud Loadbalancer負(fù)載均衡調(diào)用時(shí)所涉及的:

  • Loadbalancer緩存同步
  • Loadbalancer如何進(jìn)行過期緩存刪除
  • Loadbalancer如何基于裝飾者模式和nacos緩存結(jié)合

由此得出Loadbalancer緩存實(shí)時(shí)性上的存在的風(fēng)險(xiǎn),希望對你有幫助。

責(zé)任編輯:趙寧寧 來源: 寫代碼的SharkChili
相關(guān)推薦

2024-02-22 10:11:00

負(fù)載均衡器反向代理

2023-09-28 19:49:26

負(fù)載均衡API網(wǎng)關(guān)反向代理

2010-05-06 10:14:31

負(fù)載均衡器

2010-05-10 14:13:26

2024-06-18 08:14:21

2023-02-13 16:39:45

Kubernetes容器負(fù)載均衡器

2011-03-17 09:27:07

HAProxy負(fù)載均衡

2011-08-24 13:45:49

HAProxy負(fù)載均衡負(fù)載均衡器

2010-05-10 14:05:31

負(fù)載均衡器

2010-04-26 15:04:08

負(fù)載均衡器

2010-04-22 10:36:06

負(fù)載均衡器

2010-05-04 13:32:37

nginx負(fù)載均衡器

2023-03-30 13:32:51

負(fù)載均衡器HDFS

2022-07-14 08:53:48

MetalLBkubernetes

2017-05-19 14:45:01

OVN負(fù)載均衡器路由器

2010-04-28 17:01:30

Apusic負(fù)載均衡器

2010-05-05 19:05:03

負(fù)載均衡器會(huì)話保持

2010-04-22 10:46:40

Lvs負(fù)載均衡故障負(fù)載均衡器

2010-04-22 09:54:12

負(fù)載均衡器

2010-05-05 19:10:23

Nginx負(fù)載均衡器
點(diǎn)贊
收藏

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

成人免费在线一区二区三区| 亚洲第一精品夜夜躁人人躁| 翔田千里亚洲一二三区| 波多野结衣在线电影| 成人嫩草影院| 欧美精品一卡二卡| 日本一区二区三区四区五区六区| 国产精品一区二区av白丝下载 | 日韩成人手机在线| 成人h动漫精品一区二区无码 | 久久综合色之久久综合| 日本精品久久久久久久| 亚洲一级理论片| 视频精品国内| 一本到不卡免费一区二区| 亚洲永久激情精品| 空姐吹箫视频大全| 三级欧美韩日大片在线看| 亚洲免费av网址| 一本色道久久亚洲综合精品蜜桃| 18+激情视频在线| 99re热这里只有精品免费视频| 国产精品99久久久久久久久 | 91精品国产综合久久香蕉| 影音先锋亚洲天堂| 欧美精品观看| 最新国产精品拍自在线播放| 亚洲久久久久久| 欧美专区一区| 在线观看91精品国产麻豆| 男女午夜激情视频| а√在线中文在线新版| 亚洲美女淫视频| 欧美大片va欧美在线播放| 欧美成人aa大片| 日本a在线免费观看| 国产网站在线免费观看| 久久精品欧美日韩| 久久99精品久久久久久三级| 超碰在线观看99| 国产在线精品一区二区不卡了| 国产精品久久久久久久久久久不卡| 久久国产在线观看| 在线电影一区二区| 色偷偷888欧美精品久久久| 白白色免费视频| 精品中文一区| 亚洲免费av电影| 性欧美13一14内谢| 精品av一区二区| 亚洲欧美中文字幕| 女~淫辱の触手3d动漫| 日韩有码中文字幕在线| 精品无人国产偷自产在线| 黄色录像a级片| 天堂日韩电影| 亚洲欧美日韩爽爽影院| 久久久久亚洲av无码专区桃色| 欧美freesex8一10精品| 亚洲精品成人久久久| 日韩成人av一区二区| 国产一区在线电影| 日韩av在线资源| 加勒比一区二区| 欧美一区二区三区激情视频| 亚洲性夜色噜噜噜7777| 久久久久久久毛片| 91一区二区三区四区| 久久激情视频免费观看| 青草草在线视频| 亚洲国产午夜| 国产精品1区2区在线观看| 波多野结衣在线电影| 久热成人在线视频| 亚洲一区二区在线播放| 欧美 日韩 综合| 97se亚洲国产综合自在线不卡| 久久久福利视频| 91在线导航| 一区二区免费看| 欧美在线观看成人| 日本欧美在线| 亚洲成色999久久网站| 无码h肉动漫在线观看| 久久国产电影| 久久噜噜噜精品国产亚洲综合| 少妇一级淫片免费放中国 | 日本一区二区三区在线不卡| 中日韩在线视频| 黄色影院在线看| 亚洲成av人影院| 日韩精品一区中文字幕| 嫩呦国产一区二区三区av| 亚洲成人网久久久| 四虎成人免费影院| 欧美视频久久| 国产精品网站视频| 亚州精品国产精品乱码不99按摩| 欧美国产一区视频在线观看| 免费在线看黄色片| 精品久久毛片| 日韩大陆欧美高清视频区| 亚洲女人毛茸茸高潮| 亚洲高清免费| 91精品久久久久久| 男人的天堂在线| 亚洲在线一区二区三区| 三级a三级三级三级a十八发禁止| 成人资源在线播放| www高清在线视频日韩欧美| 日韩欧美a级片| 韩国精品在线观看| 欧美三级网色| 国内在线免费视频| 7777精品伊人久久久大香线蕉完整版 | 日本一本草久p| 写真福利精品福利在线观看| 欧美一级黄色片| 久久久久亚洲AV成人无在| 亚洲精品123区| 成人免费淫片aa视频免费| 手机亚洲第一页| 又紧又大又爽精品一区二区| www.com黄色片| 蜜桃精品wwwmitaows| 欧美高清在线视频观看不卡| 在线免费a视频| 久久精品亚洲国产奇米99| 国产日本在线播放| 亚洲超碰在线观看| 久久久国产一区二区| 波多野结衣毛片| 91免费在线看| 青娱乐自拍偷拍| 超碰在线成人| 欧美精品电影免费在线观看| 99国产精品久久久久99打野战| 欧美国产精品v| 蜜臀久久99精品久久久酒店新书| 女仆av观看一区| 午夜精品久久久久久久99热| 成人av手机在线| 亚洲一区二区美女| 精品国产aⅴ一区二区三区东京热 久久久久99人妻一区二区三区 | 久久99精品国产一区二区三区| 国产又色又爽又黄刺激在线视频| 欧美美女bb生活片| 日韩三级久久久| 视频一区二区欧美| 日本不卡一区二区三区在线观看 | 成人性生交大片免费看视频直播| 91大神xh98hx在线播放| 欧美写真视频网站| 中国极品少妇videossexhd| 国产欧美91| 日韩av大全| 深夜福利亚洲| 美女少妇精品视频| 亚洲精品字幕在线观看| 亚洲三级久久久| 久久aaaa片一区二区| 亚洲婷婷免费| 久久精品人成| 正义之心1992免费观看全集完整版| 欧美亚洲日本精品| 亚洲毛片在线观看| 久久国产香蕉视频| 国产精品免费免费| 国产一区二区在线观看免费视频| 亚洲在线久久| 国产精品一区免费观看| 成人福利视频| 久久精品电影一区二区| 成人黄色免费视频| 大桥未久av一区二区三区| 91成年人网站| 国产一区二区0| 久久国产精品视频在线观看| 国产伦精品一区二区三区视频| 国产精品国产自产拍高清av水多| 日本免费中文字幕在线| 日韩午夜电影av| 亚洲GV成人无码久久精品| 中文字幕乱码亚洲精品一区 | 日本三级一区二区| 欧美激情自拍偷拍| 18深夜在线观看免费视频| 国产视频欧美| 亚洲人一区二区| 大香伊人久久精品一区二区| 国产精品扒开腿做爽爽爽视频| 老司机午夜在线视频| 亚洲精品国产精品乱码不99按摩| 日韩av免费播放| 亚洲最大成人综合| 成年人在线免费看片| 国产传媒久久文化传媒| 久久久久狠狠高潮亚洲精品| 午夜影院欧美| 日本公妇乱淫免费视频一区三区| 久久综合给合| 国产精品大陆在线观看| 日本乱理伦在线| 日韩视频―中文字幕| 天天干天天摸天天操| 91麻豆精品国产91久久久使用方法 | 五月婷婷伊人网| 7777精品伊人久久久大香线蕉完整版| 亚洲免费在线观看av| 亚洲欧美一区二区久久| 中文字幕被公侵犯的漂亮人妻| 国产高清久久久久| 蜜臀一区二区三区精品免费视频| 一本久道久久综合婷婷鲸鱼| 久久久久久久久久久久久国产| 国产亚洲一区二区三区不卡| 国产伦精品一区二区三区四区免费 | 91.成人天堂一区| 亚洲国产成人精品女人久久| 亚洲午夜在线视频| 日韩视频中文字幕在线观看| 国产日产精品1区| 你懂的在线观看网站| 国产成人在线网站| 中文字幕亚洲影院| 日韩av一级片| 中文字幕在线观看第三页| 亚洲免费精品| 国产中文字幕二区| 在线播放精品| 久久99久久久久久| 欧美日韩免费观看一区=区三区| 亚洲一区二区三区色| 国产精品免费不| 鲁丝片一区二区三区| 国产精品宾馆| 国产一区在线免费观看| 成人在线视频你懂的| 不卡一卡2卡3卡4卡精品在| 成人国产精品久久| 成人免费视频在线观看超级碰| 日韩成人亚洲| 国产精品入口夜色视频大尺度| 欧美精品日日操| 国产精品999999| 日韩毛片一区| 国产精品丝袜久久久久久高清| 成人国产精品一区二区免费麻豆 | 凹凸av导航大全精品| 99在线观看视频| 操欧美女人视频| 国产一区二区黄色| 色狠狠久久av综合| 欧美理论一区二区| 激情综合网五月| 亚洲三区视频| 亚洲一区二区| 男女日批视频在线观看| 一本不卡影院| 亚洲激情在线观看视频| 久久国产福利国产秒拍| 永久免费黄色片| 风间由美性色一区二区三区| 精品国产人妻一区二区三区| 26uuu久久综合| 成人免费视频入口| 自拍偷拍亚洲综合| 国产第100页| 欧美午夜丰满在线18影院| 看黄色一级大片| 制服丝袜在线91| 国模私拍视频在线| 亚洲性猛交xxxxwww| 久久日韩视频| 91高清视频免费| 久久久久伊人| 超碰在线观看97| 久9久9色综合| 免费看啪啪网站| 亚洲激情精品| 成人免费视频久久| 国产精品18久久久久久久久| 特级西西人体4444xxxx| 中文字幕乱码一区二区免费| 久久黄色免费网站| 色素色在线综合| 国产视频一区二区三区四区五区| 亚洲国产精品成人va在线观看| 浮生影视网在线观看免费| 大胆欧美人体视频| 春暖花开亚洲一区二区三区| 亚洲伊人第一页| 天堂99x99es久久精品免费| 制服国产精品| 久久精品91| 精品国产一二区| 2021中文字幕一区亚洲| 91禁男男在线观看| 午夜激情一区二区| 艳妇乳肉豪妇荡乳av| 日韩成人中文字幕| 羞羞的网站在线观看| 国产精品久久久久久久久久免费| 一区二区三区欧洲区| 蜜桃成人在线| 91成人免费| 亚洲人辣妹窥探嘘嘘| 99re这里只有精品首页| 欧美黑吊大战白妞| 欧美色视频在线观看| 日韩午夜影院| 久久久久久久久久久国产| 国产成人精品一区二三区在线观看| 成人欧美一区二区三区视频| 欧美丰满日韩| 欧美自拍小视频| 9人人澡人人爽人人精品| 午夜精品福利在线视频| 欧美性猛交xxxxxx富婆| 日韩精品系列| 97在线视频一区| jizz国产精品| 国产午夜精品视频一区二区三区| 精品一区二区三区欧美| 欧美黄色一级生活片| 色综合久久天天| 日韩专区一区二区| 国外成人性视频| 91精品国产自产精品男人的天堂 | 制服.丝袜.亚洲.中文.综合| 国产h在线观看| 国产成人97精品免费看片| 色天下一区二区三区| 人妻久久久一区二区三区| 成人午夜免费av| 亚洲精品在线观看av| 日韩免费高清av| 色呦呦在线观看视频| 成人在线视频网站| 欧美成人直播| 999久久久精品视频| 国产精品初高中害羞小美女文| 伊人网视频在线| 色哟哟入口国产精品| 亚洲天堂1区| 亚洲欧美精品| 激情欧美一区二区| www.xxxx日本| 日韩手机在线导航| 美足av综合网| 国模一区二区三区私拍视频| 亚洲深夜激情| 第一次破处视频| 欧美日韩国产综合视频在线观看| 日本免费视频在线观看| 亚洲最大的av网站| 欧美色综合网| 国产福利短视频| 在线一区二区视频| 色开心亚洲综合| 亚洲一区二区在线播放| 一区免费视频| 国产精品高清无码在线观看| 欧美在线不卡视频| 黄色一级大片在线免费看产| 97se国产在线视频| av成人激情| 自拍偷拍你懂的| 欧美一区二区久久久| 国产传媒在线| 日韩高清国产一区在线观看| 久久福利资源站| 国产91av视频| 亚洲视频axxx| 久久久91麻豆精品国产一区| 色欲色香天天天综合网www| 26uuu精品一区二区在线观看| 奴色虐av一区二区三区| 久久精品国产电影| 免费成人蒂法| 欧美在线aaa| 亚洲高清不卡在线| av资源种子在线观看| 福利精品视频| 日本在线不卡一区| 人妻久久一区二区| 亚洲视频日韩精品| 久久久久久爱| 国产成人精品无码播放| 一区二区三区精品在线| 国产区在线视频| 成人激情直播| 美国十次了思思久久精品导航 | 欧美日韩a区| 女女互磨互喷水高潮les呻吟 | 精品成人在线视频| 免费a在线看| 久久久久久久免费| 国产一区91精品张津瑜| 亚洲av中文无码乱人伦在线视色|