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

如何優雅地自定義Prometheus監控指標

安全 應用安全
目前大部分使用Spring Boot構建微服務體系的公司,大都在使用Prometheus來構建微服務的度量指標(Metrics)類監控系統。而一般做法是通過在微服務應用中集成Prometheus指標采集SDK,從而使得Spring Boot暴露相關Metrics采集端點來實現。

[[389927]]

本文轉載自微信公眾號「無敵碼農」,作者無敵碼農。轉載本文請聯系無敵碼農公眾號。

大家好!我是"無敵碼農",今天要和大家分享的是在實際工作中“如何優雅地自定義Prometheus監控指標”!目前大部分使用Spring Boot構建微服務體系的公司,大都在使用Prometheus來構建微服務的度量指標(Metrics)類監控系統。而一般做法是通過在微服務應用中集成Prometheus指標采集SDK,從而使得Spring Boot暴露相關Metrics采集端點來實現。

但一般來說,Spring Boot默認暴露的Metrics數量及類型是有限的,如果想要建立針對微服務應用更豐富的監控維度(例如TP90/TP99分位值指標之類),那么還需要我們在Spring Boot默認已經打開的Metrics基礎之上,配置Prometheus類庫(micrometer-registry-prometheus)所提供的其他指標類型。

但怎么樣才能在Spring Boot框架中以更優雅地方式實現呢?難道需要在業務代碼中編寫各種自定義監控指標代碼的暴露邏輯嗎?接下來的內容我們將通過@注解+AOP的方式來演示如何以更加優雅的方式來實現Prometheus監控指標的自定義!

自定義監控指標配置注解

需要說明的是在Spring Boot應用中,對程序運行信息的收集(如指標、日志),比較常用的方法是通過Spring的AOP代理攔截來實現,但這種攔截程序運行過程的邏輯多少會損耗點系統性能,因此在自定義Prometheus監控指標的過程中,可以將是否上報指標的選擇權交給開發人員,而從易用性角度來說,可以通過注解的方式實現。例如:

  1. package com.wudimanong.monitor.metrics.annotation; 
  2.  
  3. import java.lang.annotation.ElementType; 
  4. import java.lang.annotation.Inherited; 
  5. import java.lang.annotation.Retention; 
  6. import java.lang.annotation.RetentionPolicy; 
  7. import java.lang.annotation.Target; 
  8.  
  9. @Target({ElementType.METHOD}) 
  10. @Retention(RetentionPolicy.RUNTIME) 
  11. @Inherited 
  12. public @interface Tp { 
  13.  
  14.     String description() default ""

如上所示代碼,我們定義了一個用于標注上報計時器指標類型的注解,如果想統計接口的想TP90、TP99這樣的分位值指標,那么就可以通過該注解標注。除此之外,還可以定義上報其他指標類型的注解,例如:

  1. package com.wudimanong.monitor.metrics.annotation; 
  2.  
  3. import java.lang.annotation.ElementType; 
  4. import java.lang.annotation.Inherited; 
  5. import java.lang.annotation.Retention; 
  6. import java.lang.annotation.RetentionPolicy; 
  7. import java.lang.annotation.Target; 
  8.  
  9. @Target({ElementType.METHOD}) 
  10. @Retention(RetentionPolicy.RUNTIME) 
  11. @Inherited 
  12. public @interface Count { 
  13.  
  14.     String description() default ""

如上所示,我們定義了一個用于上報計數器類型指標的注解!如果要統計接口的平均響應時間、接口的請求量之類的指標,那么可以通過該注解標注!

而如果覺得分別定義不同指標類型的注解比較麻煩,對于某些接口上述各種指標類型都希望上報到Prometheus,那么也可以定義一個通用注解,用于同時上報多個指標類型,例如:

  1. package com.wudimanong.monitor.metrics.annotation; 
  2.  
  3. import java.lang.annotation.ElementType; 
  4. import java.lang.annotation.Inherited; 
  5. import java.lang.annotation.Retention; 
  6. import java.lang.annotation.RetentionPolicy; 
  7. import java.lang.annotation.Target; 
  8.  
  9. @Target({ElementType.METHOD}) 
  10. @Retention(RetentionPolicy.RUNTIME) 
  11. @Inherited 
  12. public @interface Monitor { 
  13.  
  14.     String description() default ""

總之,無論是分開定義特定指標注解還是定義一個通用的指標注解,其目標都是希望以更靈活的方式來擴展Spring Boot微服務應用的監控指標類型。

自定義監控指標注解AOP代理邏輯實現

上面我們靈活定義了上報不同指標類型的注解,而上述注解的具體實現邏輯,可以通過定義一個通用的AOP代理類來實現,具體實現代碼如下:

  1. package com.wudimanong.monitor.metrics.aop; 
  2.  
  3. import com.wudimanong.monitor.metrics.Metrics; 
  4. import com.wudimanong.monitor.metrics.annotation.Count
  5. import com.wudimanong.monitor.metrics.annotation.Monitor; 
  6. import com.wudimanong.monitor.metrics.annotation.Tp; 
  7. import io.micrometer.core.instrument.Counter; 
  8. import io.micrometer.core.instrument.MeterRegistry; 
  9. import io.micrometer.core.instrument.Tag; 
  10. import io.micrometer.core.instrument.Tags; 
  11. import io.micrometer.core.instrument.Timer; 
  12. import java.lang.reflect.Method; 
  13. import java.util.function.Function
  14. import org.aspectj.lang.ProceedingJoinPoint; 
  15. import org.aspectj.lang.annotation.Around; 
  16. import org.aspectj.lang.annotation.Aspect; 
  17. import org.aspectj.lang.reflect.MethodSignature; 
  18. import org.springframework.stereotype.Component; 
  19.  
  20. @Aspect 
  21. @Component 
  22. public class MetricsAspect { 
  23.  
  24.     /** 
  25.      * Prometheus指標管理 
  26.      */ 
  27.     private MeterRegistry registry; 
  28.  
  29.     private Function<ProceedingJoinPoint, Iterable<Tag>> tagsBasedOnJoinPoint; 
  30.  
  31.     public MetricsAspect(MeterRegistry registry) { 
  32.         this.init(registry, pjp -> Tags 
  33.                 .of(new String[]{"class", pjp.getStaticPart().getSignature().getDeclaringTypeName(), "method"
  34.                         pjp.getStaticPart().getSignature().getName()})); 
  35.     } 
  36.  
  37.     public void init(MeterRegistry registry, Function<ProceedingJoinPoint, Iterable<Tag>> tagsBasedOnJoinPoint) { 
  38.         this.registry = registry; 
  39.         this.tagsBasedOnJoinPoint = tagsBasedOnJoinPoint; 
  40.     } 
  41.  
  42.     /** 
  43.      * 針對@Tp指標配置注解的邏輯實現 
  44.      */ 
  45.     @Around("@annotation(com.wudimanong.monitor.metrics.annotation.Tp)"
  46.     public Object timedMethod(ProceedingJoinPoint pjp) throws Throwable { 
  47.         Method method = ((MethodSignature) pjp.getSignature()).getMethod(); 
  48.         method = pjp.getTarget().getClass().getMethod(method.getName(), method.getParameterTypes()); 
  49.         Tp tp = method.getAnnotation(Tp.class); 
  50.         Timer.Sample sample = Timer.start(this.registry); 
  51.         String exceptionClass = "none"
  52.         try { 
  53.             return pjp.proceed(); 
  54.         } catch (Exception ex) { 
  55.             exceptionClass = ex.getClass().getSimpleName(); 
  56.             throw ex; 
  57.         } finally { 
  58.             try { 
  59.                 String finalExceptionClass = exceptionClass; 
  60.                 //創建定義計數器,并設置指標的Tags信息(名稱可以自定義) 
  61.                 Timer timer = Metrics.newTimer("tp.method.timed"
  62.                         builder -> builder.tags(new String[]{"exception", finalExceptionClass}) 
  63.                                 .tags(this.tagsBasedOnJoinPoint.apply(pjp)).tag("description", tp.description()) 
  64.                                 .publishPercentileHistogram().register(this.registry)); 
  65.                 sample.stop(timer); 
  66.             } catch (Exception exception) { 
  67.             } 
  68.         } 
  69.     } 
  70.  
  71.     /** 
  72.      * 針對@Count指標配置注解的邏輯實現 
  73.      */ 
  74.     @Around("@annotation(com.wudimanong.monitor.metrics.annotation.Count)"
  75.     public Object countMethod(ProceedingJoinPoint pjp) throws Throwable { 
  76.         Method method = ((MethodSignature) pjp.getSignature()).getMethod(); 
  77.         method = pjp.getTarget().getClass().getMethod(method.getName(), method.getParameterTypes()); 
  78.         Count count = method.getAnnotation(Count.class); 
  79.         String exceptionClass = "none"
  80.         try { 
  81.             return pjp.proceed(); 
  82.         } catch (Exception ex) { 
  83.             exceptionClass = ex.getClass().getSimpleName(); 
  84.             throw ex; 
  85.         } finally { 
  86.             try { 
  87.                 String finalExceptionClass = exceptionClass; 
  88.                 //創建定義計數器,并設置指標的Tags信息(名稱可以自定義) 
  89.                 Counter counter = Metrics.newCounter("count.method.counted"
  90.                         builder -> builder.tags(new String[]{"exception", finalExceptionClass}) 
  91.                                 .tags(this.tagsBasedOnJoinPoint.apply(pjp)).tag("description"count.description()) 
  92.                                 .register(this.registry)); 
  93.                 counter.increment(); 
  94.             } catch (Exception exception) { 
  95.             } 
  96.         } 
  97.     } 
  98.  
  99.     /** 
  100.      * 針對@Monitor通用指標配置注解的邏輯實現 
  101.      */ 
  102.     @Around("@annotation(com.wudimanong.monitor.metrics.annotation.Monitor)"
  103.     public Object monitorMethod(ProceedingJoinPoint pjp) throws Throwable { 
  104.         Method method = ((MethodSignature) pjp.getSignature()).getMethod(); 
  105.         method = pjp.getTarget().getClass().getMethod(method.getName(), method.getParameterTypes()); 
  106.         Monitor monitor = method.getAnnotation(Monitor.class); 
  107.         String exceptionClass = "none"
  108.         try { 
  109.             return pjp.proceed(); 
  110.         } catch (Exception ex) { 
  111.             exceptionClass = ex.getClass().getSimpleName(); 
  112.             throw ex; 
  113.         } finally { 
  114.             try { 
  115.                 String finalExceptionClass = exceptionClass; 
  116.                 //計時器Metric 
  117.                 Timer timer = Metrics.newTimer("tp.method.timed"
  118.                         builder -> builder.tags(new String[]{"exception", finalExceptionClass}) 
  119.                                 .tags(this.tagsBasedOnJoinPoint.apply(pjp)).tag("description", monitor.description()) 
  120.                                 .publishPercentileHistogram().register(this.registry)); 
  121.                 Timer.Sample sample = Timer.start(this.registry); 
  122.                 sample.stop(timer); 
  123.  
  124.                 //計數器Metric 
  125.                 Counter counter = Metrics.newCounter("count.method.counted"
  126.                         builder -> builder.tags(new String[]{"exception", finalExceptionClass}) 
  127.                                 .tags(this.tagsBasedOnJoinPoint.apply(pjp)).tag("description", monitor.description()) 
  128.                                 .register(this.registry)); 
  129.                 counter.increment(); 
  130.             } catch (Exception exception) { 
  131.             } 
  132.         } 
  133.     } 

上述代碼完整的實現了前面我們定義的指標配置注解的邏輯,其中針對@Monitor注解的邏輯就是@Tp和@Count注解邏輯的整合。如果還需要定義其他指標類型,可以在此基礎上繼續擴展!

需要注意,在上述邏輯實現中對“Timer”及“Counter”等指標類型的構建這里并沒有直接使用“micrometer-registry-prometheus”依賴包中的構建對象,而是通過自定義的Metrics.newTimer()這樣的方式實現,其主要用意是希望以更簡潔、靈活的方式去實現指標的上報,其代碼定義如下:

  1. package com.wudimanong.monitor.metrics; 
  2.  
  3. import io.micrometer.core.instrument.Counter; 
  4. import io.micrometer.core.instrument.Counter.Builder; 
  5. import io.micrometer.core.instrument.DistributionSummary; 
  6. import io.micrometer.core.instrument.Gauge; 
  7. import io.micrometer.core.instrument.MeterRegistry; 
  8. import io.micrometer.core.instrument.Timer; 
  9. import io.micrometer.core.lang.NonNull; 
  10. import java.util.function.Consumer; 
  11. import java.util.function.Supplier; 
  12. import org.springframework.beans.BeansException; 
  13. import org.springframework.context.ApplicationContext; 
  14. import org.springframework.context.ApplicationContextAware; 
  15.  
  16. public class Metrics implements ApplicationContextAware { 
  17.  
  18.     private static ApplicationContext context; 
  19.  
  20.     @Override 
  21.     public void setApplicationContext(@NonNull ApplicationContext applicationContext) throws BeansException { 
  22.         context = applicationContext; 
  23.     } 
  24.  
  25.     public static ApplicationContext getContext() { 
  26.         return context; 
  27.     } 
  28.  
  29.     public static Counter newCounter(String name, Consumer<Builder> consumer) { 
  30.         MeterRegistry meterRegistry = context.getBean(MeterRegistry.class); 
  31.         return new CounterBuilder(meterRegistry, name, consumer).build(); 
  32.     } 
  33.  
  34.     public static Timer newTimer(String name, Consumer<Timer.Builder> consumer) { 
  35.         return new TimerBuilder(context.getBean(MeterRegistry.class), name, consumer).build(); 
  36.     } 

上述代碼通過接入Spring容器上下文,獲取了MeterRegistry實例,并以此來構建像Counter、Timer這樣的指標類型對象。而這里之所以將獲取方法定義為靜態的,主要是便于在業務代碼中進行引用!

而在上述代碼中涉及的CounterBuilder、TimerBuilder構造器代碼定義分別如下:

  1. package com.wudimanong.monitor.metrics; 
  2.  
  3. import io.micrometer.core.instrument.Counter; 
  4. import io.micrometer.core.instrument.Counter.Builder; 
  5. import io.micrometer.core.instrument.MeterRegistry; 
  6. import java.util.function.Consumer; 
  7.  
  8. public class CounterBuilder { 
  9.  
  10.     private final MeterRegistry meterRegistry; 
  11.  
  12.     private Counter.Builder builder; 
  13.  
  14.     private Consumer<Builder> consumer; 
  15.  
  16.     public CounterBuilder(MeterRegistry meterRegistry, String name, Consumer<Counter.Builder> consumer) { 
  17.         this.builder = Counter.builder(name); 
  18.         this.meterRegistry = meterRegistry; 
  19.         this.consumer = consumer; 
  20.     } 
  21.  
  22.     public Counter build() { 
  23.         consumer.accept(builder); 
  24.         return builder.register(meterRegistry); 
  25.     } 

上述代碼為CounterBuilder構造器代碼!TimerBuilder構造器代碼如下:

  1. package com.wudimanong.monitor.metrics; 
  2.  
  3. import io.micrometer.core.instrument.MeterRegistry; 
  4. import io.micrometer.core.instrument.Timer; 
  5. import io.micrometer.core.instrument.Timer.Builder; 
  6. import java.util.function.Consumer; 
  7.  
  8. public class TimerBuilder { 
  9.  
  10.     private final MeterRegistry meterRegistry; 
  11.  
  12.     private Timer.Builder builder; 
  13.  
  14.     private Consumer<Builder> consumer; 
  15.  
  16.     public TimerBuilder(MeterRegistry meterRegistry, String name, Consumer<Timer.Builder> consumer) { 
  17.         this.builder = Timer.builder(name); 
  18.         this.meterRegistry = meterRegistry; 
  19.         this.consumer = consumer; 
  20.     } 
  21.  
  22.     public Timer build() { 
  23.         this.consumer.accept(builder); 
  24.         return builder.register(meterRegistry); 
  25.     } 

之所以還特地將構造器代碼單獨定義,主要是從代碼的優雅性考慮!如果涉及其他指標類型的構造,也可以通過類似的方法進行擴展!

自定義指標注解配置類

在上述代碼中我們已經定義了幾個自定義指標注解及其實現邏輯代碼,為了使其在Spring Boot環境中運行,還需要編寫如下配置類,代碼如下:

  1. package com.wudimanong.monitor.metrics.config; 
  2.  
  3. import com.wudimanong.monitor.metrics.Metrics; 
  4. import io.micrometer.core.instrument.MeterRegistry; 
  5. import org.springframework.boot.actuate.autoconfigure.metrics.MeterRegistryCustomizer; 
  6. import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean; 
  7. import org.springframework.context.annotation.Bean; 
  8. import org.springframework.context.annotation.Configuration; 
  9. import org.springframework.core.env.Environment; 
  10.  
  11. @Configuration 
  12. public class CustomMetricsAutoConfiguration { 
  13.  
  14.     @Bean 
  15.     @ConditionalOnMissingBean 
  16.     public MeterRegistryCustomizer<MeterRegistry> meterRegistryCustomizer(Environment environment) { 
  17.         return registry -> { 
  18.             registry.config() 
  19.                     .commonTags("application", environment.getProperty("spring.application.name")); 
  20.         }; 
  21.     } 
  22.  
  23.     @Bean 
  24.     @ConditionalOnMissingBean 
  25.     public Metrics metrics() { 
  26.         return new Metrics(); 
  27.     } 

上述配置代碼主要是約定了上報Prometheus指標信息中所攜帶的應用名稱,并對自定義了Metrics類進行了Bean配置!

業務代碼的使用方式及效果

接下來我們演示在業務代碼中如果要上報Prometheus監控指標應該怎么寫,具體如下:

  1. package com.wudimanong.monitor.controller; 
  2.  
  3. import com.wudimanong.monitor.metrics.annotation.Count
  4. import com.wudimanong.monitor.metrics.annotation.Monitor; 
  5. import com.wudimanong.monitor.metrics.annotation.Tp; 
  6. import com.wudimanong.monitor.service.MonitorService; 
  7. import org.springframework.beans.factory.annotation.Autowired; 
  8. import org.springframework.web.bind.annotation.GetMapping; 
  9. import org.springframework.web.bind.annotation.RequestMapping; 
  10. import org.springframework.web.bind.annotation.RequestParam; 
  11. import org.springframework.web.bind.annotation.RestController; 
  12.  
  13. @RestController 
  14. @RequestMapping("/monitor"
  15. public class MonitorController { 
  16.  
  17.     @Autowired 
  18.     private MonitorService monitorServiceImpl; 
  19.  
  20.     //監控指標注解使用 
  21.     //@Tp(description = "/monitor/test"
  22.     //@Count(description = "/monitor/test"
  23.     @Monitor(description = "/monitor/test"
  24.     @GetMapping("/test"
  25.     public String monitorTest(@RequestParam("name") String name) { 
  26.         monitorServiceImpl.monitorTest(name); 
  27.         return "監控示范工程測試接口返回->OK!"
  28.     } 

如上述代碼所示,在實際的業務編程中就可以比較簡單的通過注解來配置接口所上傳的Prometheus監控指標了!此時在本地啟動程序,可以通過訪問微服務應用的“/actuator/prometheus”指標采集端點來查看相關指標,如下圖所示:

有了這些自定義上報的監控指標,那么Promethues在采集后,我們就可以通過像Grafana這樣的可視化工具,來構建起多維度界面友好地監控視圖了,例如以TP90/TP99為例:

如上所示,在Grafana中可以同時定義多個PromeQL來定于不同的監控指標信息,這里我們分別通過Prometheus所提供的“histogram_quantile”函數統計了接口方法“monitorTest”的TP90及TP95分位值!而所使用的指標就是自定義的“tp_method_timed_xx”指標類型!

后記

以上就是我最近在工作中封裝的一組關于Prometheus自定義監控指標的SDK代碼,在實際工作中可以將其封住為Spring Boot Starter依賴的形式,從而更好地被Spring Boot項目集成!至此我已經毫無保留的將最近兩天的工作成果分享給大家了,也希望各位老鐵可以多多點贊支持,多多轉發傳播!

 

責任編輯:武曉燕 來源: 無敵碼農
相關推薦

2023-12-29 08:01:52

自定義指標模板

2020-12-14 10:26:48

Prometheus 監控Services

2021-10-28 08:39:22

Node Export自定義 監控

2021-05-28 08:58:41

Golang網卡metrics

2023-03-26 08:41:37

2013-01-10 09:36:19

NagiosNagios插件

2022-07-08 08:00:31

Prometheus監控

2021-03-24 10:20:50

Fonts前端代碼

2023-05-28 13:11:43

Plotly指標圖表

2022-05-12 08:01:26

vmagentprometheus

2021-10-14 08:07:33

Go 應用Prometheus監控

2013-06-27 11:10:01

iOS開發自定義UISlider

2022-03-07 07:33:24

Spring自定義機制線程池

2023-09-06 08:46:47

2024-11-13 16:37:00

Java線程池

2009-09-07 22:00:15

LINQ自定義

2010-02-07 14:02:16

Android 界面

2016-02-26 14:57:50

飛象網

2015-02-12 15:33:43

微信SDK

2025-08-27 07:22:12

自定義接口Prometheus
點贊
收藏

51CTO技術棧公眾號

久久久精品日本| 欧美日韩久久不卡| 欧美精彩一区二区三区| 成人一级免费视频| 91精品电影| 亚洲国模精品私拍| 欧美三级午夜理伦三级富婆| 久久不射影院| 中文字幕精品在线不卡| 动漫一区二区在线| 午夜视频网站在线观看| 欧美视频四区| 三级精品视频久久久久| 91丝袜在线观看| 9999精品免费视频| 色一情一乱一乱一91av| 国产精品日韩三级| 三区四区电影在线观看| 91原创在线视频| 91午夜理伦私人影院| 9i精品福利一区二区三区| 欧美日韩国产亚洲一区| 国产午夜精品一区理论片飘花| 亚洲av无一区二区三区久久| 日韩中文影院| 欧美日韩国产中字| 国内自拍中文字幕| 1区2区3区在线观看| 91一区一区三区| 99久久99久久| 国产精品久久久久久免费播放| 99精品国产福利在线观看免费| 久久不射电影网| 欧美人与性囗牲恔配| 欧美色图五月天| 日韩精品一区二区三区在线观看| 成人亚洲精品777777大片| 麻豆国产在线| 偷拍亚洲欧洲综合| 欧美乱做爰xxxⅹ久久久| 亚乱亚乱亚洲乱妇| 中文字幕欧美日本乱码一线二线| 国语精品中文字幕| 可以免费观看的毛片| 国产精品91xxx| 亚洲最大的成人网| av官网在线观看| 国产麻豆精品一区二区| 成人精品视频在线| 97超碰资源站| 精品无人区卡一卡二卡三乱码免费卡| 日本久久久a级免费| 欧美黑人一区二区| 久久婷婷麻豆| 国产精品第一视频| 国产一级片免费视频| 久久国产精品久久w女人spa| 日本sm极度另类视频| 久草手机在线视频| 久久久夜夜夜| 国产精品久久久久久av福利| www.久久网| 奇米888四色在线精品| 国产精品网站大全| 国产精品国产一区二区三区四区| 极品销魂美女一区二区三区| 91视频九色网站| 午夜精品久久久久久久爽| 国产传媒久久文化传媒| 国产精品一区二区在线观看 | 国产精品v亚洲精品v日韩精品| 欧美精品一区二区三区国产精品| 青娱乐国产在线| 最新国产乱人伦偷精品免费网站| 午夜免费在线观看精品视频| 亚洲欧美一区二区三区在线观看| 日本不卡高清视频| 成人伊人精品色xxxx视频| 亚洲国产一二三区| 91免费观看在线| 亚洲看片网站| 人人超在线公开视频| 精品久久久久久久久中文字幕 | 国产综合精品视频| 免费成人你懂的| 99国精产品一二二线| 视频国产在线观看| 中文字幕一区二区三区四区不卡 | 麻豆精品新av中文字幕| 3d精品h动漫啪啪一区二区| 欧美一级在线免费观看| 国产情人综合久久777777| 国产成人精品免费看在线播放 | 91精品一区二区三区综合| 精品中文字幕乱| 无码人妻av免费一区二区三区 | 在线观看免费视频你懂的| 午夜精品久久久| 91精品999| 老牛精品亚洲成av人片| 色噜噜久久综合伊人一本| 国产大片中文字幕| 蜜臀久久99精品久久久久久9| dy888夜精品国产专区| 国产黄在线观看| 亚洲国产视频a| 日本在线一二三区| 欧美大片网址| 欧美另类第一页| 一级一级黄色片| 成人av免费在线播放| 亚洲最新在线| 一区二区三区短视频| 精品国产乱码久久久久久浪潮 | 亚洲午夜一区二区| 五月天开心婷婷| 欧美禁忌电影| 97久久久久久| 精品国产伦一区二区三区| 欧美高清在线精品一区| 亚洲 高清 成人 动漫| 日韩欧美高清一区二区三区| 中文字幕在线看视频国产欧美| 亚洲精品午夜久久久久久久| 国产伦精品一区二区三区免费| 日韩成人av网站| 色资源二区在线视频| 精品国产成人系列| 18岁成人毛片| 精品一区二区三区av| 日韩av不卡播放| 成人免费网站视频| 日韩av在线免费| 久久夜色精品亚洲| 成人精品免费网站| 91黄色在线看| 999久久精品| 欧美激情在线观看| 性生交大片免费看女人按摩| 综合色天天鬼久久鬼色| 欧美一级特黄aaa| 国产精品国产三级国产在线观看| 国产精品高潮呻吟视频| 成人三级黄色免费网站| 在线观看不卡一区| 欧美丰满美乳xxⅹ高潮www| 首页欧美精品中文字幕| 日本高清久久一区二区三区| 日韩电影av| 亚洲性猛交xxxxwww| 波多野结衣家庭主妇| 国产欧美va欧美不卡在线| 美女喷白浆视频| 成人综合专区| 成人福利视频网| 51xtv成人影院| 精品国产三级电影在线观看| 日韩欧美三级在线观看| 91麻豆国产自产在线观看| 久热免费在线观看| 欧美色网址大全| 国产精品一区二区久久精品| 麻豆传媒在线免费| 日韩精品一区二区三区视频在线观看| 黄色一级视频免费观看| 成人av电影在线播放| 日本一区二区黄色| 精品一区二区三区中文字幕老牛| 日韩免费精品视频| 麻豆影院在线| 精品国产区一区| 国产午夜精品久久久久| 国产精品视频九色porn| 青娱乐国产精品视频| 亚洲高清在线| 秋霞久久久久久一区二区| 亚洲欧美在线人成swag| 欧美激情一区二区三区久久久| 日中文字幕在线| 欧美色精品在线视频| 清纯粉嫩极品夜夜嗨av| 97精品视频在线观看自产线路二| 无码日韩人妻精品久久蜜桃| 外国成人免费视频| 九九九九精品九九九九| 成人午夜在线| 国外成人在线视频| 1769视频在线播放免费观看| 日韩欧美精品在线| 欧美日韩一级黄色片| 亚洲三级理论片| 国产三级视频网站| 国产一区二三区| 久久久噜噜噜www成人网| 成人午夜av| 国产精品视频500部| 97久久网站| 性色av一区二区三区| 欧美成人hd| 亚洲欧美日韩爽爽影院| 国产日本精品视频| 色天天综合色天天久久| 欧美被狂躁喷白浆精品| 欧美激情综合五月色丁香| 久久精品无码专区| 麻豆精品在线视频| 日韩精品一区二区三区不卡 | 日本熟妇人妻xxxxx| 欧美a级在线| 日韩三级电影免费观看| 另类ts人妖一区二区三区| 成人精品久久av网站| 日韩天堂在线| 91av网站在线播放| 91精选在线| 日韩一级黄色av| 国产高清一级毛片在线不卡| 日韩电影免费在线观看中文字幕| 国产人妖一区二区| 欧美精品高清视频| 波多野结衣小视频| 色综合久久久网| 国产真人真事毛片| 亚洲免费看黄网站| 刘亦菲国产毛片bd| 久久精品在线免费观看| 黄色网址在线视频| 成人av第一页| 高清中文字幕mv的电影| 国产成人啪免费观看软件| 波多野结衣xxxx| 日本不卡一区二区| 黑森林精品导航| 日韩av午夜在线观看| 黄色高清无遮挡| 丝袜亚洲另类欧美综合| 人妻精品无码一区二区三区| 99香蕉国产精品偷在线观看| 97超碰在线人人| 在线观看一区视频| 亚洲熟妇无码一区二区三区导航| 欧美日韩国产精品一区二区亚洲| 免费观看黄色的网站| 婷婷综合网站| 2021国产视频| 欧美日韩亚洲一区在线观看| 超碰10000| 欧美日韩精选| 三上悠亚久久精品| 99精品视频免费观看| 北条麻妃69av| 老牛嫩草一区二区三区日本| 国产福利一区视频| 奇米888四色在线精品| 亚洲精品性视频| 国产精品资源在线看| 99视频在线观看视频| 国产suv精品一区二区三区| 色婷婷狠狠18禁久久| aaa国产一区| 这里只有久久精品| 国产精品视频第一区| 欧美另类videoxo高潮| 有码一区二区三区| 国产又爽又黄的视频| 色偷偷久久一区二区三区| 超碰在线免费97| 欧美一区二区二区| 免费看国产片在线观看| 亚洲色图日韩av| 久热国产在线| 91国在线精品国内播放| 蜜桃精品在线| 3d精品h动漫啪啪一区二区| 极品一区美女高清| 日本最新一区二区三区视频观看| 日韩一区亚洲二区| 欧美一二三不卡| 美女久久网站| 成人av毛片在线观看| a亚洲天堂av| 欧美一区二区三区粗大| 亚洲精品老司机| 91丝袜一区二区三区| 欧美一区二视频| 日本成人一区二区三区| 久久影院资源网| 日本高清不卡一区二区三区视频| 91美女片黄在线观| 亚州av一区| 日本丰满大乳奶| 蜜桃伊人久久| 成人三级做爰av| 国产欧美一二三区| 精品无码久久久久久久久| 91福利国产精品| 高h震动喷水双性1v1| 在线观看视频亚洲| 91探花在线观看| 92看片淫黄大片欧美看国产片| 欧美毛片免费观看| 看全色黄大色大片| 日韩二区三区在线观看| 性猛交╳xxx乱大交| 国产精品日日摸夜夜摸av| 国产精品黄色网| 日韩一卡二卡三卡四卡| yjizz视频网站在线播放| 久久男人的天堂| 精品国产乱码久久久久久樱花| 日本精品一区| 亚洲免费一区二区| 蜜臀aⅴ国产精品久久久国产老师| 国产女主播视频一区二区| 国产香蕉视频在线| 欧美va在线播放| 久操视频在线观看| 国产精品一二三视频| 久久av免费看| www.中文字幕在线| 丰满白嫩尤物一区二区| 国产精品夜夜夜爽阿娇| 在线观看av一区| 黑人与亚洲人色ⅹvideos| 97精品欧美一区二区三区| 亚洲成人五区| 热久久最新网址| 激情六月婷婷综合| 五月婷婷婷婷婷| 在线免费观看不卡av| 麻豆av电影在线观看| 日本精品视频在线播放| 欧美色资源站| 久久久999视频| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 日本黄色中文字幕| 亚洲人成欧美中文字幕| 欧美freesex| 日本一区二区不卡高清更新| 久久xxxx精品视频| 男人天堂av电影| 在线视频综合导航| 国产高清一级毛片在线不卡| 国产精品久久久久久久久久| 精品视频免费| 污污动漫在线观看| 亚洲欧洲国产专区| www.香蕉视频| 国内精品美女av在线播放| 国产精品毛片视频| 可以在线看的av网站| 91丨九色丨尤物| 免费黄色片视频| 中文字幕在线亚洲| 日韩一区二区三区精品视频第3页| 一二三在线视频| av一区二区三区在线| 黄色片免费观看视频| 亚洲天堂开心观看| 日韩成人在线电影| 日本免费成人网| 91麻豆免费在线观看| 天天综合久久综合| 北条麻妃一区二区三区中文字幕| www999久久| 一二三四视频社区在线| 国产日韩欧美综合一区| 一级片免费观看视频| 欧美肥婆姓交大片| 无码日韩精品一区二区免费| 久久精品免费网站| 亚洲精品ww久久久久久p站 | 色系列之999| 午夜视频在线观看精品中文| 蜜桃传媒一区二区三区| 国产拍揄自揄精品视频麻豆| 一区二区三区免费在线| 久久久亚洲成人| 欧美日韩性在线观看| 亚洲av无码久久精品色欲| 欧美日韩美女在线观看| 在线免费看黄| 国产精品一区二区免费| 青青草国产精品97视觉盛宴| 99久久婷婷国产综合| 欧美精品一区二区精品网| 外国电影一区二区| 久久综合久久久久| 国产农村妇女毛片精品久久麻豆| 亚洲AV无码精品国产| 国产精品福利网| 精品91视频| 黄色香蕉视频在线观看| 亚洲激情中文字幕| 激情五月综合婷婷| 成人性生生活性生交12| 亚洲国产精品精华液网站| 午夜视频在线免费观看| 精品国产一区二区三区麻豆免费观看完整版 | 欧美日韩一二|