日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

SpringCloud微服务架构之,Hystrix 熔断器,Gateway 网关

發布時間:2024/4/15 javascript 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SpringCloud微服务架构之,Hystrix 熔断器,Gateway 网关 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Hystrix 概述

Hystix 是 Netflix 開源的一個延遲和容錯庫,用于隔離訪問遠程服務、第三方庫,防止出現級聯失敗(雪崩)。

pom依耐

<!-- hystrix --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-hystrix</artifactId></dependency>

? 雪崩:一個服務失敗,導致整條鏈路的服務都失敗的情形。
? Hystix 主要功能

  • 隔離:用于隔離不同調用鏈之間相互不受影響
  • 降級:封裝友好的錯誤提示并返回
  • 熔斷:當請求錯誤率較高時,自動降級熔斷
  • 限流:合理分配每個調用的并發請求數量

隔離

1. 線程池隔離
將多個請求線程按照每個服務的配置,分發到不同的微服務去調用,這樣就解決的,線程一窩蜂的同一微服務中,影響的雪崩

2. 信號量隔離

降級

異常,超時
在A調用C的時候,C服務發生了異常,或者執行時間過長,為了避免請求回不友好的錯誤信息或者線程不一直等待,我們提供一個友好的方法,該方法往往返回一個失敗請求的響應結果集,如:服務器繁忙等等,使得請求響應能夠快速獲得,而且異常后是友好的提示,超時后能快速的返回響應,不占用線程.防止服務雪崩.
這個降級不但可以在服務提供方編寫一個降級方法,也可以在服務消費方編寫.

熔斷

使用服務熔斷,首先要導入pom依耐
然后在主啟動開啟熔斷:@EnableCircuitBreaker//開啟hystrix的斷路器
在服務業務類上書寫:
注意的是:不編寫那些超時,請求次數,hystrix都會有默認的值,都默認支持熔斷

//======服務熔斷,providerCircuitBreakerMethod異常或者超時調用的方法@HystrixCommand(fallbackMethod = "providerCircuitBreakerMethod",commandProperties = {@HystrixProperty(name = "circuitBreaker.enabled",value = "true"),//是否開啟斷路器//sleepWindowInMilliseconds請求量閾值 默認失敗次數20次@HystrixProperty(name = "circuitBreaker.requestVolumeThreshold",value = "10"),//請求次數//監控時間,默認5000毫秒 就是打開狀態與半開狀態之間的休眠時間@HystrixProperty(name = "circuitBreaker.sleepWindowInMilliseconds",value = "5000"),//時間窗口日期//誤差閾值百分比errorThresholdPercentage 失敗率默認百分之50@HystrixProperty(name = "circuitBreaker.errorThresholdPercentage",value = "60"),//失敗率60%達到多少跳閘(進行服務熔斷)})public Result providerCircuitBreaker(@PathVariable("id") Integer id){//制作異常,然后調用這個方法就會去調用配置的降級方法if (id==0){//id==0.就異常int i = 1/0;}return new Result(true,"providerCircuitBreaker調用成功");}//熔斷友好提示方法@Overridepublic Result providerCircuitBreakerMethod(Integer id){return new Result(false,"服務器繁忙,請稍候再試~~~熔斷方法");}

限流

服務限流:(flowLimit)
就好比秒殺商品等高并發操作,禁止一窩蜂的請求過來擁擠,大家排隊,一秒鐘處理N個,有序的進行

測試Hystrix的代碼

搭建一個父工程

pom.xml

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.fs</groupId><artifactId>study-springcloud</artifactId><version>1.0-SNAPSHOT</version><modules><module>fs-server-eureka-7001</module><module>fs-provider-hystrix-8001</module><module>fs-consumer-hystrix-80</module></modules><!-- 作為父工程--><packaging>pom</packaging><dependencyManagement><dependencies><!-- spring boot --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-dependencies</artifactId><version>2.3.2.RELEASE</version><type>pom</type> <!-- import 導入父工程的配置--><scope>import</scope></dependency><!-- spring cloud --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>Hoxton.SR6</version><type>pom</type> <!-- import 導入父工程的配置--><scope>import</scope></dependency><!-- spring-cloud-alibaba-dependencies 2.2.1.RELEASE --><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>2.2.1.RELEASE</version><type>pom</type><scope>import</scope></dependency><!-- eureka-server --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId><version>2.2.4.RELEASE</version></dependency><!-- eureka-client --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId><version>2.2.4.RELEASE</version></dependency><!-- 整合MyBatis--><!-- mysql --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.20</version><scope>runtime</scope></dependency><dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>1.1.20</version></dependency><!-- MyBatisPlus --><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.3.2</version></dependency> <!-- lombok--><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.12</version></dependency></dependencies></dependencyManagement><dependencies></dependencies></project>

fs-server-eureka-7001(省略,請查閱上一偏博客,服務治理)

fs-provider-hystrix-8001 服務提供者

pom.xml

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><parent><artifactId>study-springcloud</artifactId><groupId>com.fs</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>fs-provider-hystrix-8001</artifactId><dependencies><!-- hystrix --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-hystrix</artifactId></dependency><!-- spring-boot-starter-web spring-boot-starter-actuator綁定在一塊 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- eureka-Client--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId><!--第一種是:如果你的應用不會再需要返回xml的系列化格式,那么直接在pom.xml文件中將jackson-dataformat-xml這外包排除即可(如果其他包也進行了jackson-dataformat-xml的依賴引用也要視情況排除):第二種是:不排除jackson-dataformat-xml包,而是直接在相應接口方法或Controller上明確指定將返回JSON格式的值:@GetMapping(value = "/user-instance", produces = MediaType.APPLICATION_PROBLEM_JSON_VALUE)--><!-- 排除controller返回的格式為xml--><exclusions><exclusion><groupId>com.fasterxml.jackson.dataformat</groupId><artifactId>jackson-dataformat-xml</artifactId></exclusion></exclusions></dependency><!-- mysql--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><!-- jdbc--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId></dependency><!-- druid--><dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId></dependency><!-- MyBatis-puls--><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId></dependency><!-- 自己的實體類--><dependency><groupId>com.fs</groupId><artifactId>fs-api-commons</artifactId><version>1.0-SNAPSHOT</version></dependency></dependencies></project>

application.yml

server:port: 8001 spring:application:name: fs-provider-hystrixdatasource:username: rootpassword: rooturl: jdbc:mysql://192.168.93.132:3306/fs_springclouddriver-class-name: com.mysql.cj.jdbc.Drivertype: com.alibaba.druid.pool.DruidDataSource #自定義數據源# 配置eureka eureka:instance:hostname: localhost # 主機名,寫的是域名,本機在host文件中映射prefer-ip-address: true # 將當前實例的ip注冊到eureka server中.默認是false 注冊主機名ip-address: 127.0.0.1 # 修改instance-id顯示 # # 修改instance-id顯示,在eureka中的顯示名稱 # instance-id: ${eureka.instance.ip-address}:${spring.application.name}:${server.port} # lease-renewal-interval-in-seconds: 30 # 每一次eureka client 向 eureka server發送心跳的時間間隔 # lease-expiration-duration-in-seconds: 90 # 如果90秒內eureka server沒有收到eureka client的心跳包,則剔除該服務client:register-with-eureka: true # 將提供注冊到注冊eureka中心fetch-registry: true # 從eureka上抓取已有的注冊信息service-url:defaultZone: http://localhost:7001/eureka #,http://localhost2:7002/eureka,http://localhost3:7003/eureka # 注冊中心地址# 配置MyBatis-plus日志 mybatis-plus:configuration:log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

FsProviderHystrix8001 主啟動

注意:@EnableCircuitBreaker//開啟hystrix的斷路器

package com.fs;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.circuitbreaker.EnableCircuitBreaker; import org.springframework.cloud.netflix.eureka.EnableEurekaClient;@SpringBootApplication //開啟Eureka客戶端 @EnableEurekaClient @EnableCircuitBreaker//開啟hystrix的斷路器 public class FsProviderHystrix8001 {public static void main(String[] args) {SpringApplication.run(FsProviderHystrix8001.class,args);} }

PaymentServiceImpl 業務接口實現類

主要注解:@HystrixCommand

package com.fs.service.impl;import com.fs.dao.PaymentDao; import com.fs.pojo.Payment; import com.fs.result.Result; import com.fs.service.PaymentService; import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand; import com.netflix.hystrix.contrib.javanica.annotation.HystrixProperty; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.web.bind.annotation.PathVariable;import java.util.List;@Service public class PaymentServiceImpl implements PaymentService {//注入dao@Autowiredprivate PaymentDao paymentDao;@Overridepublic List<Payment> findAll() {//使用MyBatis提供的方法return paymentDao.selectList(null);}/*測試消費端配置的服務降級方法*/@Overridepublic Result testConsumer(Integer id) {//制作異常,然后調用這個方法就會去調用配置的降級方法if (id==0){//id==0.就異常int i = 1/0;}return new Result(true,"testConsumer調用成功");}/*降級:1.服務出現異常2.服務調用超時,默認為1秒*/@Override//@HystrixCommand一旦調用服務方法失敗并拋出了錯誤信息后,會自動調用標注好的fallbackMethod()指定降級后調用的方法名稱@HystrixCommand(fallbackMethod = "providerFallbackMethod",commandProperties = {//HystrixCommandProperties:這個類中有HystrixCommand注解的所有配置//timeoutInMilliseconds規定這個方法在3秒內沒有正常執行,就服務降級,方法異常會立馬進行降級,不配置默認1秒@HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds",value = "3000")//熔斷不配置默認是 默認失敗次數20次 失敗率默認百分之50 默認5000毫秒 就是打開狀態與半開狀態之間的休眠時間})public Result testFallbackMethod(Integer id){//制作異常,然后調用這個方法就會去調用配置的降級方法if (id==0){//id==0.就異常int i = 1/0;}return new Result(true,"testFallbackMethod調用成功");}//服務對應的降級方法/*1.方法的返回值需要和原方法一樣2,方法的參數需要和原方法一樣*/@Overridepublic Result providerFallbackMethod(Integer id){return new Result(false,"小二開小差中,請稍候再試~~~服務降級方法");}//======服務熔斷,providerCircuitBreakerMethod異常或者超時調用的方法@HystrixCommand(fallbackMethod = "providerCircuitBreakerMethod",commandProperties = {@HystrixProperty(name = "circuitBreaker.enabled",value = "true"),//是否開啟斷路器//sleepWindowInMilliseconds請求量閾值 默認失敗次數20次@HystrixProperty(name = "circuitBreaker.requestVolumeThreshold",value = "10"),//請求次數//監控時間,默認5000毫秒 就是打開狀態與半開狀態之間的休眠時間@HystrixProperty(name = "circuitBreaker.sleepWindowInMilliseconds",value = "5000"),//時間窗口日期//誤差閾值百分比errorThresholdPercentage 失敗率默認百分之50@HystrixProperty(name = "circuitBreaker.errorThresholdPercentage",value = "60"),//失敗率60%達到多少跳閘(進行服務熔斷)})public Result providerCircuitBreaker(@PathVariable("id") Integer id){//制作異常,然后調用這個方法就會去調用配置的降級方法if (id==0){//id==0.就異常int i = 1/0;}return new Result(true,"providerCircuitBreaker調用成功");}//熔斷友好提示方法@Overridepublic Result providerCircuitBreakerMethod(Integer id){return new Result(false,"服務器繁忙,請稍候再試~~~熔斷方法");}}

fs-consumer-hystrix-80 使用feign遠程調用 服務消費端

pom.xml

== hystrix 因為OpenFeign集成了hystrix,所以不用導入hystrix的依耐==

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><parent><artifactId>study-springcloud</artifactId><groupId>com.fs</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>fs-consumer-hystrix-80</artifactId><dependencies> <!-- hystrix 因為OpenFeign集成了hystrix,所以不用導入hystrix的依耐--><!-- spring-boot-starter-web spring-boot-starter-actuator綁定在一塊 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- openFeign--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId></dependency><!-- eureka-Client--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId><!-- 排除controller返回的格式為xml--><exclusions><exclusion><groupId>com.fasterxml.jackson.dataformat</groupId><artifactId>jackson-dataformat-xml</artifactId></exclusion></exclusions></dependency><!-- 自己的實體類--><dependency><groupId>com.fs</groupId><artifactId>fs-api-commons</artifactId><version>1.0-SNAPSHOT</version></dependency></dependencies></project>

application.yml

主要的是加上:
因為feign默認是不開啟hystrix的

# 開啟feign對hystrix的支持,因為feign默認是不開啟hystrix的 feign:hystrix:enabled: true

application.yml

server:port: 80spring:application:name: fs-consumer-hystrix-80 eureka:client:register-with-eureka: false # 消費者我目前的用途不需要將消費者注冊到注冊中心fetch-registry: true # 從注冊中心拉取服務registry-fetch-interval-seconds: 30 # 默認30秒定時去注冊中心拉取服務service-url:defaultZone: http://localhost:7001/eureka #,http://localhost2:7002/eureka,http://localhost3:7003/eureka # 注冊中心地址# 設置feign客戶端超時時間(OpenFeign默認支持Ribbon) 不配置,默認1秒,因為feign底層是使用的Ribbon,Ribbon默認超時是1秒 ribbon:#指的是建立鏈接后從服務器讀取到可用資源所用的時間,等5秒ReadTimeout: 5000#指的是建立連接所用的時間,適用于網絡狀態正常的情況下,兩端連接所用的時間,等5秒ConnectTimeout: 5000 logging:level:# root: debug # 開啟springboot的debug的日志信息,不配置springboot默認是info# com.fs: debug # 開啟部分springboot的debug的日志信息# feign日志以什么級別監控那個feign組件功能使用的接口,使用debug級別(只能記錄debug級別),然后調用服務方法,在控制臺就能看到詳細debug信息com.fs.springcloud.server.PaymentOpenFeignService: debug# 開啟feign對hystrix的支持,因為feign默認是不開啟hystrix的 feign:hystrix:enabled: true

FsConsumerHystrix80 主啟動

package com.fs;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.EnableEurekaClient; import org.springframework.cloud.openfeign.EnableFeignClients;@SpringBootApplication //使用openFeign,激活并開啟,feign集成了robbin同時集成了hystrix,自動默認輪詢的負載均衡規則 @EnableFeignClients @EnableEurekaClient public class FsConsumerHystrix80 {public static void main(String[] args) {SpringApplication.run(FsConsumerHystrix80.class,args);} }

PaymentOpenFeignHystrix 定義 OpenFeign的接口

指定服務降級友好方法類:fallback = PaymentHystrixFallbackServiceImpl.class

package com.fs.feign;import com.fs.config.OpenFeignConfig; import com.fs.pojo.Payment; import com.fs.result.Result; import org.springframework.cloud.openfeign.FeignClient; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping;import java.util.List; /*** feign的聲明式接口,發起遠程調用的,簡化restTemplate** 1.定義接口* 2.接口上添加注解@FeignClient(value = "注冊中心服務提供者名",configuration=定義的OpenFeign的日志類,fallback定義服務降級方法)* 3.編寫調用接口,接口的聲明規則和提供方接口保持一致* 4.去controller注入改接口對象,調用接口方法來完成遠程調用*/ @FeignClient(value = "fs-provider-hystrix",configuration = OpenFeignConfig.class,fallback = PaymentHystrixFallbackServiceImpl.class) public interface PaymentOpenFeignHystrix {//復制服務提供的controller方法,路徑記得加上controller類上的路徑@RequestMapping("/payment/findAll")Result<List<Payment>> findAll();//測試time超時,由于我們在服務提供方的這個方法制作了sleep2秒,由于feign底層基于Ribbon,//Ribbon默認超時時間為1秒,所以報錯java.net.SocketTimeoutException: Read timed out//解決辦法在配置文件中配置Ribbon的超時時間@RequestMapping("/payment/testTimeOut/{id}")Result test(@PathVariable("id") Integer id); }

PaymentHystrixFallbackServiceImpl 遠程調用異常或者超時的服務降級友好方法類

package com.fs.feign;import com.fs.pojo.Payment; import com.fs.result.Result; import org.springframework.stereotype.Component;import java.util.List;/*** Feign 客戶端的降級處理類(feign自動集成hystrix,但是默認關閉,需要在yml中開啟)* 1. 定義類 實現 Feign 客戶端接口* 2. 使用@Component注解將該類的Bean加入SpringIOC容器* 默認異常降級,默認等待超時1秒,默認異常占比百分之50,默認的半開時間5秒,默認10秒20次失敗請求*/ @Component public class PaymentHystrixFallbackServiceImpl implements PaymentOpenFeignHystrix {@Overridepublic Result<List<Payment>> findAll() {return new Result(false,"fs-consumer-hystrix-80-findAll服務降級");}@Overridepublic Result test(Integer id) {return new Result(false,"fs-consumer-hystrix-80-test服務降級");} }

OpenFeignConfig

package com.fs.config;import feign.Logger; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration;/* OpenFeign的日志配置類*/ @Configuration public class OpenFeignConfig {@BeanLogger.Level feignLoggerLevel(){//表示開啟的是詳細的feign日志,FULL表示最為詳細的,點進去有4個return Logger.Level.FULL;}//還需要在yml中配置feign日志已什么級別監控那個接口 }

PaymentController 消費端controller

package com.fs.controller;import com.fs.feign.PaymentOpenFeignHystrix; import com.fs.pojo.Payment; import com.fs.result.Result; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController;import java.util.List;@RestController @RequestMapping("/consumer") public class PaymentController {//注入OpenFeign接口@Autowiredprivate PaymentOpenFeignHystrix paymentOpenFeign;@RequestMapping("/payment/findAll")public Result<List<Payment>> findAll(){//調用OpenFeign接口Result<List<Payment>> all = paymentOpenFeign.findAll();return all;}//測試OpenFeign遠程調用,服務降級方法@RequestMapping("/payment/testTimeOut/{id}")Result test(@PathVariable("id")Integer id){Result test = paymentOpenFeign.test(id);return test;}}

啟動項目測試

先啟動eureka注冊中心:fs-server-eureka-7001
在啟動服務提供端:fs-provider-hystrix-8001
在啟動服務消費端:fs-consumer-hystrix-80

首先瀏覽器輸入:http://localhost:7001/

然后測試服務提供方的業務是否能正常訪問,我們直接訪問被指定降級的業務方法


然后測試服務消費端配置的服務降級接口

Hystrix 熔斷監控

Gateway 網關

網關概述

? 網關旨在為微服務架構提供一種簡單而有效的統一的API路由管理方式。
? 在微服務架構中,不同的微服務可以有不同的網絡地址,各個微服務之間通過互相調用完成用戶請求,客戶端可能通過調用N個微服務的接口完成一個用戶請求。
? 存在的問題:
? 客戶端多次請求不同的微服務,增加客戶端的復雜性
? 認證復雜,每個服務都要進行認證
? http請求不同服務次數增加,性能不高
? 網關就是系統的入口,封裝了應用程序的內部結構,為客戶端提供統一服務,一些與業務本身功能無關的公共邏輯可以在這里實現,諸如認證、鑒權、監控、緩存、負載均衡、流量管控、路由轉發等
? 在目前的網關解決方案里,有Nginx+ Lua、Netflix Zuul 、Spring Cloud Gateway等等

什么是Gateway

  • 定義:前端統一訪問微服務的人口
  • 功能:
    • 認證
    • 鑒權
    • 日志
    • 監控
    • 緩存
    • 負載均衡
    • 流量控制
  • 事實:
    • Gateway自動集成Ribbon,且默認開啟相關功能

Gateway 網關路由配置

Gateway 網關路由配置 – 靜態路由

# 網關配置gateway:discovery:locator:enabled: true #使用情況少,不常用(了解) 開啟從注冊中心動態創建路由的功能,利用微服務進行路由,請求路徑前可以添加微服務名稱lower-case-service-id: true #(了解) 允許請求路徑的微服務名稱為小寫routes:- id: payment_routh #payment_routh 路由的id,若不配置,默認是UUID,沒有固定規則但要求唯一uri: http://localhost:8001 # 靜態路由 這樣配置是死的,不好 匹配后提供服務的路由地址

Gateway 網關路由配置 – 動態路由
? 引入eureka-client配置
? 修改uri屬性:uri: lb://服務名稱

# 網關配置gateway:discovery:locator:enabled: true #使用情況少,不常用(了解) 開啟從注冊中心動態創建路由的功能,利用微服務進行路由,請求路徑前可以添加微服務名稱lower-case-service-id: true #(了解) 允許請求路徑的微服務名稱為小寫routes:- id: payment_routh #payment_routh 路由的id,若不配置,默認是UUID,沒有固定規則但要求唯一uri: lb://FS-PROVIDER # 動態路由 匹配提供服務的路由地址,達到路由是去服務中心找端口,而不是寫死:原理是使用自動集成Ribbon,使用默認配置

Gateway 網關路由配置 – 微服務名稱配置

# 網關配置gateway:discovery:locator:enabled: true #使用情況少,不常用(了解) 開啟從注冊中心動態創建路由的功能,利用微服務進行路由,請求路徑前可以添加微服務名稱lower-case-service-id: true #(了解) 允許請求路徑的微服務名稱為小寫

Gateway 過濾器


局部過濾器配置
predicates 斷言

spring:application:name: fs-gatewaycloud:# 網關配置gateway:discovery:locator:enabled: true #使用情況少,不常用(了解) 開啟從注冊中心動態創建路由的功能,利用微服務進行路由,請求路徑前可以添加微服務名稱lower-case-service-id: true #(了解) 允許請求路徑的微服務名稱為小寫# 路由配置:轉發規則routes:- id: payment_routh #payment_routh 路由的id,若不配置,默認是UUID,沒有固定規則但要求唯一 # uri: http://localhost:8001 # 靜態路由 這樣配置是死的,不好 匹配后提供服務的路由地址uri: lb://FS-PROVIDER # 動態路由 匹配提供服務的路由地址,達到路由是去服務中心找端口,而不是寫死:原理是使用自動集成Ribbon,使用默認配置filters: # 下面是官方給定的局部過濾器,我們一般還是使用自定義過濾器 # - AddRequestParameter=username,xiaofu # 通過過濾工廠會在匹配的請求頭上加上一對請求頭參數,名稱為username值為xiaofupredicates: # predicates就是為了實現一組匹配規則,讓請求過來找到對應的route進行處理- Path=/payment/get/** # 斷言,路徑相匹配的地址 注意Path要大寫 # - Cookie=username,xiaofu #攜帶cookie訪問,斷言是否有,有就允許訪問,這里寫死了 使用cmd命令curl攜帶cookie測試 curl http://localhost:9527/payment/get/2 --cookie "username=xiaofu"# 可以配置多個 # - id: payment_routh02 #payment_routh02 路由的id,沒有固定規則但要求唯一 # uri: http://localhost:8001 #匹配后提供服務的路由地址 # predicates: # - Path=/payment/lb/** # 斷言,路徑相匹配的地址

全局過濾器在下面的案列中

使用Gateway

1.導入依耐
2.編寫application.yml配置

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId> </dependency>

搭建Gateway工程

pom.xml

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><parent><artifactId>shangguiguSpringCloud</artifactId><groupId>com.fs</groupId><version>1.0-SNAPSHOT</version></parent><modelVersion>4.0.0</modelVersion><artifactId>fs_gateway_gateway9527</artifactId><dependencies><!-- gateway--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-gateway</artifactId></dependency><!-- eureka-client--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId></dependency> <!-- 基礎配置--><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency> <!-- test--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId></dependency></dependencies></project>

application.yml

配置

  • 路由配置
    • id:自定義服務名稱(唯一)
    • uri:請求轉發的目的地
      • 靜態路由:http://localhost:8080/
      • 動態路由:lb://服務名稱
    • predicates:那些請求需要使用該路由配置進行轉發
      • Path=/Result/** 依據請求路徑來匹配轉發的請求
    • filter
      • 可以使用官方定義的過濾器,但一般使用我們自己定義的
server:port: 9527spring:application:name: fs-gatewaycloud:# 網關配置gateway:discovery:locator:enabled: true #使用情況少,不常用(了解) 開啟從注冊中心動態創建路由的功能,利用微服務進行路由,請求路徑前可以添加微服務名稱lower-case-service-id: true #(了解) 允許請求路徑的微服務名稱為小寫# 路由配置:轉發規則routes:- id: payment_routh #payment_routh 路由的id,若不配置,默認是UUID,沒有固定規則但要求唯一 # uri: http://localhost:8001 # 靜態路由 這樣配置是死的,不好 匹配后提供服務的路由地址uri: lb://FS-PROVIDER # 動態路由 匹配提供服務的路由地址,達到路由是去服務中心找端口,而不是寫死:原理是使用自動集成Ribbon,使用默認配置filters: # 下面是官方給定的局部過濾器,我們一般還是使用自定義過濾器 # - AddRequestParameter=username,xiaofu # 通過過濾工廠會在匹配的請求頭上加上一對請求頭參數,名稱為username值為xiaofupredicates: # predicates就是為了實現一組匹配規則,讓請求過來找到對應的route進行處理- Path=/payment/get/** # 斷言,路徑相匹配的地址 注意Path要大寫 # - Cookie=username,xiaofu #攜帶cookie訪問,斷言是否有,有就允許訪問,這里寫死了 使用cmd命令curl攜帶cookie測試 curl http://localhost:9527/payment/get/2 --cookie "username=xiaofu"# 可以配置多個 # - id: payment_routh02 #payment_routh02 路由的id,沒有固定規則但要求唯一 # uri: http://localhost:8001 #匹配后提供服務的路由地址 # predicates: # - Path=/payment/lb/** # 斷言,路徑相匹配的地址eureka:instance:hostname: fs-gateway-service#服務提供者provider,注冊進eureka服務列表內client:service-url:register-with-eureka: true # 注冊到服務中心fetch-register: true # 從注冊中心獲取注冊的服務信息defaultZone: http://localhost:7001/eureka #,http://localhost2:7002/eureka,http://localhost3:7003/eureka # 注冊中心地址

主啟動

package com.fs.springcloud;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.EnableEurekaClient;@SpringBootApplication @EnableEurekaClient public class GatewayMain9527 {public static void main(String[] args) {SpringApplication.run(GatewayMain9527.class,args);} }

自定義網關過濾器MyGatewayFilter(全局過濾器)

對請求進行功能的增強(認證、設置憑證信息等)

  • 局部過濾器:只對配置的路由進行生效
    • org.springframework.cloud.gateway.filter.factory.過濾器名稱GatewayFilterFactory
  • 全局過濾器:所有請求都生效
    • GlobalFilter
    • Ordered指定過濾器執行的順序,越小越先執行)
package com.fs.springcloud.filter;import lombok.extern.slf4j.Slf4j; import org.springframework.cloud.gateway.filter.GatewayFilterChain; import org.springframework.cloud.gateway.filter.GlobalFilter; import org.springframework.core.Ordered; import org.springframework.http.HttpStatus; import org.springframework.stereotype.Component; import org.springframework.web.server.ServerWebExchange; import reactor.core.publisher.Mono;import java.util.Date;/* 自定義gateway路由全局過濾器,只需要編碼,不需要進行任何配置implements GlobalFilter, Ordered需要實現這兩個接口*/ @Component @Slf4j public class MyGatewayFilter implements GlobalFilter, Ordered {//過濾方法//測試http://localhost:9527/payment/get/2?username=xiaofu@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {log.info("~~~~~進到了MyGatewayFilter自定義過濾器:"+new Date().getTime());//獲取請求參數中有沒有usernameString username = exchange.getRequest().getQueryParams().getFirst("username");//沒有就非法if (username== null){log.info("~~~用戶名為null,非法用戶~~~~");//沒有傳遞用戶名,就返回個狀態碼不能接受的狀態碼exchange.getResponse().setStatusCode(HttpStatus.NOT_ACCEPTABLE);return exchange.getResponse().setComplete();}//放行,向下繼續執行return chain.filter(exchange);}/*** 過濾器排序* @return 數值越低,越先加載*/@Overridepublic int getOrder() {//加載過濾器順序,數值越低,越先加載return 0;} }

總結

以上是生活随笔為你收集整理的SpringCloud微服务架构之,Hystrix 熔断器,Gateway 网关的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

美国三级黄色大片 | 色婷婷av在线 | 中文字幕精品www乱入免费视频 | 粉嫩一区二区三区粉嫩91 | 国产对白av| 国产视 | 白丝av免费观看 | 国产精品99免视看9 国产精品毛片一区视频 | 亚洲国产精品va在线看黑人动漫 | 中文字幕一区二区三区在线观看 | 亚洲欧美日韩在线一区二区 | 婷婷激情五月综合 | 久久成人一区二区 | 中文字幕在线观看完整版电影 | 国产精品99久久久久久人免费 | 国产一区二区三区高清播放 | 久久成人福利 | 久草爱视频| 国产亚洲午夜高清国产拍精品 | 欧美在线观看小视频 | 99欧美 | 国产精品午夜在线观看 | 亚洲精品成人免费 | 夜色资源站wwwcom | 久久电影中文字幕视频 | 日韩视频一区二区三区 | 午夜久久成人 | 久久久99精品免费观看乱色 | 天天干com| 亚洲永久精品国产 | 亚洲精品中文在线 | 久久不色 | 91桃色在线观看视频 | 国产99久久精品一区二区300 | 人人插人人爱 | 国产亚洲欧洲 | 又爽又黄又刺激的视频 | 韩日电影在线观看 | 国产精品18久久久久vr手机版特色 | 国产一区免费观看 | 六月天综合网 | 欧美成人一二区 | www.888av| 狠狠色噜噜狠狠狠狠2021天天 | 成年人电影免费在线观看 | 热久精品 | 成人在线观看网址 | 人人干人人草 | 亚洲国产中文字幕在线观看 | 天堂在线一区二区 | 日韩动态视频 | 国产视频黄 | 久久亚洲热 | 操操日 | 99久久久成人国产精品 | www.亚洲精品 | 美女国产免费 | 99精品国产免费久久久久久下载 | 黄色片网站免费 | 91视频在线观看免费 | 亚洲综合国产精品 | 激情婷婷久久 | 免费在线观看国产精品 | 国产精品久久久久久久av大片 | 在线观看国产一区二区 | 手机在线永久免费观看av片 | 国产精品 美女 | www视频免费在线观看 | 精品三级av | 日韩中文字幕免费视频 | 日韩在线视频精品 | 91大神一区二区三区 | 中文字幕av有码 | 特级毛片爽www免费版 | 精品一区精品二区 | 亚洲黄色av网址 | 99视频在线看 | 91精品久久久久久久久久入口 | 色小说在线 | 日日夜夜狠狠操 | 色综合天天天天做夜夜夜夜做 | 成人性生交大片免费看中文网站 | 亚洲精品在线视频 | 日日夜夜免费精品视频 | 三级黄色在线 | 黄色91在线 | 制服丝袜在线 | 最新超碰 | 高清av在线免费观看 | 97福利在线 | 波多野结衣电影一区 | 日韩av高清 | 久久99国产精品视频 | 久久综合久久综合九色 | 欧美一级视频在线观看 | 国产成人久久精品77777 | 免费视频在线观看网站 | 在线观看视频一区二区 | 久久在线视频在线 | 国产精品二区在线 | 色婷婷影视 | 麻豆极品 | 97精品久久人人爽人人爽 | 久久免费视频在线观看30 | 91精品国产三级a在线观看 | 激情久久伊人 | 亚洲精品小视频 | 激情五月网站 | 精品成人在线 | 日韩综合第一页 | 九九九在线观看视频 | 97精品在线观看 | 91桃色视频 | 日韩免费三区 | 国产人成看黄久久久久久久久 | 99久久久久久久久 | 爱爱av在线| 97视频播放| 日韩精品在线观看视频 | 国产96在线观看 | 91亚洲激情 | 91一区二区三区久久久久国产乱 | 97超碰在线久草超碰在线观看 | 偷拍视频一区 | 四虎国产精品成人免费影视 | 久久久久黄 | 亚洲视频在线播放 | 天堂av在线中文在线 | 天天干天天拍天天操天天拍 | 成人永久视频 | 久久久久99999 | 亚洲黄色av网址 | 国模精品一区二区三区 | 性色av一区二区三区在线观看 | 九九色综合 | 激情五月在线视频 | 中文一二区 | 一级黄色片在线免费观看 | 欧美精品一区二区免费 | 免费热情视频 | 91av在线免费看 | 亚洲精品中文在线 | 色综合色综合久久综合频道88 | 国产美女无遮挡永久免费 | 五月激情六月丁香 | 久久久香蕉视频 | 国产中文视 | 国产99精品在线观看 | 亚洲中字幕 | 国产精品国产三级国产不产一地 | 最近中文字幕在线中文高清版 | 丁香综合五月 | 国产91区 | 天天摸天天操天天舔 | 中文字幕av一区二区三区四区 | 99热在线免费观看 | 欧美综合在线观看 | 中文字幕在线色 | 日韩在线观看视频免费 | 一区二区三区中文字幕在线 | av在线看网站| 日日夜夜天天干 | 好看的国产精品视频 | 亚洲成aⅴ人在线观看 | 中文字幕色婷婷在线视频 | 81国产精品久久久久久久久久 | 久久久久久久久久久综合 | 国内精品久久久久久 | 欧美日本日韩aⅴ在线视频 插插插色综合 | 91福利社区在线观看 | 丁香五月亚洲综合在线 | 女人18毛片90分钟 | 久久久亚洲电影 | 中文字幕日韩国产 | 日日夜日日干 | 人人插人人爱 | 免费看成人 | 精品播放| 欧美日性视频 | 国内精品久久久精品电影院 | 精品国产99国产精品 | 中文字幕在线观看第三页 | 中文字幕免费一区 | 亚洲国产精品va在线看黑人 | 狠狠狠色丁香综合久久天下网 | 成人av一级片 | 九九热免费视频在线观看 | 国产精品欧美一区二区 | 国产麻豆视频免费观看 | 欧美一级久久久久 | 黄色精品国产 | 97视频网址| 99视频这里有精品 | 久久99久久99久久 | 欧美精品小视频 | 久久精品国产亚洲aⅴ | a天堂在线看 | 国产精品69av | 久久久69| 人人插人人澡 | 亚洲免费在线观看视频 | 激情综合久久 | 欧美一级片免费观看 | 国内精品久久久久久久久 | 国产午夜在线观看视频 | 国产精品99久久久精品免费观看 | 99精品久久久久久久久久综合 | avav99| 成人三级黄色 | 亚洲视屏在线播放 | 久久精品爱爱视频 | 一区二区三区视频网站 | 91精品网站 | 免费高清在线视频一区· | 天天干天天天天 | 久热av| 久久99国产精品自在自在app | 久久精品视频4 | 欧美一级特黄aaaaaa大片在线观看 | 色偷偷中文字幕 | 亚洲欧美视频一区二区三区 | 天天天色 | 亚洲视频电影在线 | 亚洲国产精品久久久久婷婷884 | 国产亚洲精品久久久久久电影 | 天天激情综合 | 成年人在线免费看片 | 亚洲国产美女精品久久久久∴ | 久久久久久久99 | 中文在线免费看视频 | 98涩涩国产露脸精品国产网 | 国产一区国产二区在线观看 | 欧美另类xxx| 蜜臀一区二区三区精品免费视频 | 91视频观看免费 | 麻豆成人在线观看 | www.超碰97.com | 国产成人精品一区二三区 | 99精品在线免费 | 国产一级免费在线观看 | 高清av免费看 | 99精品视频在线观看视频 | 一区二区在线影院 | www.亚洲精品 | 99综合影院在线 | 天天操天天干天天 | 婷婷丁香激情五月 | 啪嗒啪嗒免费观看完整版 | 精品国产乱码久久久久久浪潮 | 国产成人中文字幕 | 中文字幕 在线 一 二 | 麻豆国产精品视频 | 九九视频在线观看视频6 | 国产视频精品网 | 日精品 | 在线一区观看 | 亚洲va天堂va欧美ⅴa在线 | 久久久影视 | 777奇米四色 | 人人爽网站 | 国产高清亚洲 | 久久国语露脸国产精品电影 | 色夜影院 | 天天色综合1 | 97色在线观看免费视频 | 精品综合久久久 | 一级黄色大片 | 天天爱天天操天天爽 | 91免费在线看片 | 99视频在线精品免费观看2 | 成人一级免费电影 | 国产成人精品免费在线观看 | 亚洲丝袜一区二区 | 99日韩精品 | 五月天com| 久草精品电影 | 中文字幕人成人 | 一区二区三区四区免费视频 | 日日操操操 | 91亚洲精品久久久蜜桃网站 | 久久成人国产精品 | 国产成人久久久77777 | 九九热国产视频 | 日本韩国在线不卡 | 天天插天天色 | 欧美精品一区二区三区一线天视频 | 国产成人精品一区二区在线 | 免费男女羞羞的视频网站中文字幕 | 国产一区二三区好的 | 亚洲香蕉在线观看 | 成人app在线免费观看 | 美女久久久久久久久久 | 成人免费一区二区三区在线观看 | 一级免费黄色 | 天天天天天天天天操 | 国产亚洲欧美一区 | 久久免费视频3 | 天天操夜 | 中文字幕丝袜一区二区 | 一区二区在线影院 | 91亚洲精 | 亚洲日韩欧美一区二区在线 | 免费不卡中文字幕视频 | 久久香蕉国产 | 天天干天天操天天做 | 欧美色精品天天在线观看视频 | 亚洲丝袜一区二区 | 亚洲成色| 在线国产能看的 | 欧美日韩亚洲在线观看 | 91精品一区二区三区久久久久久 | av中文字幕不卡 | 日韩高清成人在线 | 日韩在线短视频 | 亚洲视频播放 | 毛片888| 在线观看国产www | 国产精选在线 | 国产 日韩 欧美 自拍 | 午夜性生活 | 最近日韩免费视频 | 九九九热精品免费视频观看网站 | 国产亚洲视频中文字幕视频 | 日本乱码在线 | 麻豆视频免费看 | 成人黄色资源 | 成人全视频免费观看在线看 | 人人爽人人乐 | 成人在线免费视频 | 国产91在线观 | 操操综合 | 国产精品一区二区免费视频 | 国产精品免费一区二区三区在线观看 | 日韩中文字幕免费看 | 天天操,夜夜操 | 日韩性xxxx| 国产精品一区二区久久精品爱微奶 | 国产一区视频免费在线观看 | 久久国产精品久久精品国产演员表 | 亚洲aⅴ一区二区三区 | 亚州精品一二三区 | 国产一线在线 | 999久久国精品免费观看网站 | 婷婷色网视频在线播放 | 国产91丝袜在线播放动漫 | 天天射天天操天天干 | 亚洲蜜桃在线 | 国产日产高清dvd碟片 | 黄色官网在线观看 | 国产一区电影在线观看 | 久久久久免费精品国产小说色大师 | 国产免费高清视频 | 午夜久久网 | 免费福利小视频 | 国产精品va在线 | 国内外成人在线 | 日韩在线中文字幕视频 | 韩国av免费观看 | 我要色综合天天 | 亚洲视频精品在线 | 国内视频在线 | 国产v欧美 | 97视频在线观看播放 | 欧美一区二区三区四区夜夜大片 | 色综合www| 久久久福利视频 | av黄免费看 | 在线亚洲播放 | 日韩欧美xx | 国产91精品看黄网站在线观看动漫 | 99精品黄色 | 国产精品午夜8888 | 91精品秘密在线观看 | 久久免费视频8 | 91精品国产91久久久久久三级 | 亚洲欧美成人综合 | 久久精品国产久精国产 | 黄色av免费电影 | 婷婷激情综合五月天 | 久久久久一区二区三区 | 国产一级免费观看视频 | 欧美日韩1区| 91亚洲精品在线 | 午夜视频在线观看一区二区三区 | 日韩精品一区在线观看 | 亚洲精品久久久蜜桃直播 | 亚洲精品在线看 | 热久久影视 | 九九99 | 久久久精品免费观看 | 久热免费在线观看 | 国产精品一区免费在线观看 | 成年人视频在线免费播放 | 精品三级av | www.亚洲视频| 久久99久久久久 | 九九九热精品 | 午夜电影久久久 | 国产精品爽爽爽 | 日韩高清免费观看 | 色吊丝av中文字幕 | 国产3p视频 | 91麻豆免费视频 | 午夜精品久久一牛影视 | 天天爽夜夜爽人人爽曰av | 日韩激情视频在线观看 | 手机色在线 | 中文字幕之中文字幕 | 亚洲国产偷 | 日韩一区二区三区视频在线 | 99一区二区三区 | 久久久美女 | 久久超级碰 | 天天色天天色天天色 | 成人高清在线观看 | 国产精品mv在线观看 | 色婷婷成人网 | 久久国产麻豆 | 91视频在线观看下载 | 伊人午夜 | 久久久久久久久久久久久9999 | 黄色免费网站大全 | 九九久久国产 | 91精品在线免费视频 | 91在线永久 | 国产精品久久久久久久久毛片 | 色综合久久88| 欧亚久久| 丁香花中文在线免费观看 | 日韩成人高清在线 | 在线观看av大片 | 国产精品久久久久久欧美 | www狠狠操 | 中文字幕免费观看视频 | 黄色一区二区在线观看 | 久久精品一区二区三区中文字幕 | 99久久精品国产系列 | 97精品超碰一区二区三区 | 久久免费激情视频 | 久久久2o19精品 | 精品三级av | www.五月婷婷 | 亚洲aⅴ在线观看 | av午夜电影| 深夜激情影院 | 久久免费中文视频 | 深夜免费小视频 | 婷婷网站天天婷婷网站 | 欧美大片mv免费 | 亚洲精品视频免费在线 | 国产色视频一区二区三区qq号 | 国产va在线 | 最新中文字幕视频 | 久久久不卡影院 | 在线亚洲小视频 | 久久精品久久精品久久 | 最近免费中文字幕大全高清10 | 国产精品视频永久免费播放 | 99色免费视频 | 日日夜夜婷婷 | 欧美一级久久 | 99久久99久国产黄毛片 | 日韩网站在线观看 | 亚洲 欧美 日韩 综合 | 久草视频在线免费看 | 久久久久久久久久免费 | 深夜福利视频一区二区 | 免费在线观看成人 | 黄色一集片| 偷拍久久久| 91黄在线看 | 在线之家免费在线观看电影 | 一级性av| 国产精久久 | 精品国产一区二区三区久久 | 韩日电影在线观看 | 国色天香永久免费 | 日韩视频免费观看高清完整版在线 | 中文资源在线播放 | 亚洲欧美日本一区二区三区 | 天天综合天天做天天综合 | 丁香五月亚洲综合在线 | 伊人婷婷| 国产自在线 | 久久夜色精品国产亚洲aⅴ 91chinesexxx | 欧美日韩成人一区 | 国产日韩欧美网站 | 91看片在线免费观看 | 国产破处在线视频 | 高清在线一区二区 | 国产日韩精品一区二区三区 | 久久一及片 | 韩国视频一区二区三区 | 亚洲精品欧美成人 | 日本性高潮视频 | 黄色小网站免费看 | 免费精品在线 | 在线观看av大片 | 午夜精品成人一区二区三区 | 最近日本中文字幕a | 久久综合久久综合久久 | 天天干干| 99久久精品免费看 | 天天综合成人网 | 综合色综合色 | 日韩免费观看一区二区 | 五月在线 | 亚洲精品一区二区18漫画 | 香蕉91视频 | 欧美日本在线视频 | 美女精品久久久 | 99re视频在线观看 | 国产手机视频在线 | 色www精品视频在线观看 | 天天玩天天操天天射 | 美女视频永久黄网站免费观看国产 | 超碰人人av | 久久人人97超碰国产公开结果 | 91精品一区二区三区久久久久久 | 国产精品视频在线观看 | 日韩大片在线免费观看 | 黄色片网站av| 国产在线观看你懂得 | 91精品成人 | 欧美有色 | 国产69精品久久99的直播节目 | 国产黄色免费看 | av在线播放不卡 | 国产小视频在线看 | 精品在线一区二区三区 | 91亚洲精品在线观看 | 成人小电影在线看 | 国产中文字幕在线 | 91成人免费看 | 操操碰 | 国产最新视频在线 | 色噜噜在线观看视频 | 免费能看的av | 国产中文字幕三区 | 久久国产日韩 | av免费在线播放 | 成人免费av电影 | 免费网站色 | 日韩精品中文字幕av | 精品国精品自拍自在线 | av超碰免费在线 | 亚洲伊人第一页 | 亚洲国产精品影院 | 天海冀一区二区三区 | 天天干天天操天天入 | 精品国产免费一区二区三区五区 | 国产精品中文字幕在线观看 | 国产亚洲欧美在线视频 | 欧美成人性网 | 久草视频精品 | 亚洲综合色丁香婷婷六月图片 | 日韩精品久久久 | 美女在线国产 | 香蕉视频最新网址 | 九九热精品国产 | 国产aaa免费视频 | 天天操夜操视频 | 日韩在线免费不卡 | 久久高清av | 狠狠色2019综合网 | 在线只有精品 | 亚洲精品乱码久久久久久按摩 | 91人人视频在线观看 | 国产日韩欧美在线影视 | 久久久久久97三级 | 日韩免费高清 | 精品一二三四在线 | 91禁看片 | 亚洲高清免费在线 | 涩五月婷婷 | 成年人在线播放视频 | 国产一区二区成人 | 免费在线播放av电影 | 日韩av影片在线观看 | 免费看的毛片 | 久久超碰97 | 日韩一区二区三区观看 | 夜添久久精品亚洲国产精品 | 最近中文字幕mv免费高清在线 | 国产精品2018 | 懂色av一区二区在线播放 | 国际精品久久久久 | 最近中文字幕mv | 成人在线免费视频观看 | 免费看黄的视频 | 久久久久久久久久久影院 | 人人插人人看 | 日韩中文字幕免费电影 | 韩国精品福利一区二区三区 | 免费视频 三区 | 国产视频一 | 精品一区二区三区电影 | 中文在线天堂资源 | 色婷婷免费视频 | 国产一在线精品一区在线观看 | 欧美一级视频在线观看 | 天堂网在线视频 | 91天天操 | 福利av影院 | 亚洲在线激情 | 亚洲热视频| 九九视频一区 | 九九欧美| 午夜精品久久久久久久爽 | 久视频在线 | 玖玖视频免费在线 | 欧美一区二区精美视频 | 色婷婷综合久色 | 亚洲欧美va | 欧美久久综合 | 国产精品视频全国免费观看 | 激情丁香婷婷 | 亚洲在线视频观看 | 亚洲精品资源 | 国产精品视频免费在线观看 | 黄色com| 日韩两性视频 | 狠狠干在线| 亚洲精品午夜久久久 | 亚洲精品久久久久58 | 国产久草在线观看 | 欧美va日韩va| 日韩中文免费视频 | www.91成人 | 日韩免费一级a毛片在线播放一级 | 人人射人人插 | 在线观看国产区 | 狠狠色狠狠综合久久 | 在线免费观看麻豆视频 | 日韩在线免费视频观看 | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 日韩欧美视频在线播放 | 欧美一区日韩精品 | 国产精品一区二区久久国产 | 亚洲日本国产精品 | 免费的黄色的网站 | 亚洲播放一区 | 天天干视频在线 | 韩国精品福利一区二区三区 | 日日爱夜夜爱 | 天天射天天干天天插 | 中文字幕在线一区二区三区 | 男女视频国产 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 天天干天天插伊人网 | 精品a在线 | 99在线视频网站 | 草久久精品 | 少妇资源站 | 99久久久国产精品免费99 | 国产一级片久久 | 夜夜视频欧洲 | 99视频在线精品国自产拍免费观看 | 国产精彩在线视频 | 在线观看黄 | 天天干人人 | 国产在线观看地址 | 精品国产诱惑 | 亚洲爱爱视频 | 国产精品黄网站在线观看 | 国产亚洲高清视频 | 国产精品久久久久久模特 | 国产高清绿奴videos | 国产一级一片免费播放放a 一区二区三区国产欧美 | 国产成人99av超碰超爽 | 日韩精品视 | 欧美黑吊大战白妞欧美 | 国产97碰免费视频 | 视频成人永久免费视频 | 日韩激情片在线观看 | 香蕉视频免费看 | 中文字幕日韩无 | 国产精品成人一区二区 | 99精品国产视频 | 国产视频久久久久 | 国产精品 国产精品 | 中文字幕乱码亚洲精品一区 | 97成人精品视频在线播放 | 国产偷国产偷亚洲清高 | 中字幕视频在线永久在线观看免费 | 伊甸园av在线 | 婷婷丁香国产 | 少妇按摩av | 日韩视| 丁香激情综合国产 | 免费看特级毛片 | 99精品热视频 | 国产成人一区二区三区在线观看 | 97福利在线 | 国产综合精品久久 | www.婷婷色 | 天天操天天透 | 午夜99| 久久福利剧场 | 免费日韩一区 | 亚洲成人精品国产 | av电影免费观看 | 97在线超碰| 又黄又爽又湿又无遮挡的在线视频 | 国产亚洲婷婷免费 | 日韩av高清 | 日韩中文字幕网站 | 成人免费影院 | 国产麻豆果冻传媒在线观看 | 97av在线视频免费播放 | 天天狠狠干| 天天激情综合网 | 久久精品一二区 | 国产精品久久久久一区二区 | 国产高清视频在线播放一区 | 国产一区二区在线观看免费 | 国产亚洲成人精品 | 97综合在线 | 午夜影院一级 | 国产一区二区手机在线观看 | 国产色在线 | 久久99精品视频 | 久久精品亚洲一区二区三区观看模式 | 九九av | 日韩美女高潮 | 久久久久免费精品国产 | 91麻豆精品国产91久久久更新时间 | www日韩在线 | 久久久免费在线观看 | 日日操天天爽 | 涩涩爱夜夜爱 | 国产成人久久av977小说 | 国产精品久久久久国产精品日日 | 色欧美日韩 | 久久久久久久久黄色 | 三级av网 | 精品产品国产在线不卡 | 天天躁日日躁狠狠躁 | 中文字幕日本在线 | 欧美另类高清 videos | 国产资源精品 | 久久精品人 | 精品一区二区影视 | 国产精品精 | 亚洲一区美女视频在线观看免费 | 国产综合在线视频 | 8090yy亚洲精品久久 | 日韩欧美在线国产 | 午夜少妇av | 奇米影视999| 亚洲免费专区 | 在线一级片 | 中文字幕永久免费 | 精品国模一区二区 | 高清不卡免费视频 | 2019中文字幕网站 | 伊人久久一区 | 国产在线观看免费观看 | 成人午夜电影在线观看 | 国产91精品久久久久久 | 国产精品亚洲视频 | 亚洲精品免费观看 | 日韩精品一区二区在线视频 | 999色视频 | 久久免费毛片视频 | av在线免费观看网站 | 国产精品久久久久一区二区三区共 | 欧美日韩国产页 | 日韩一区二区三区不卡 | 亚洲精品午夜久久久久久久 | 正在播放国产91 | 久久成视频 | 欧美一区中文字幕 | 91麻豆精品国产自产在线游戏 | 9992tv成人免费看片 | 91在线视频精品 | 91人人揉日日捏人人看 | 亚洲一一在线 | 奇米7777狠狠狠琪琪视频 | 高清av网站 | 亚洲成av人影片在线观看 | 国产精品欧美日韩在线观看 | 91理论片午午伦夜理片久久 | 日韩理论在线观看 | 91豆花在线| 国产在线资源 | 最近最新中文字幕 | 美女免费视频一区二区 | 久久免费99 | 国产香蕉视频在线播放 | 婷婷丁香五 | 正在播放国产一区二区 | 国产乱对白刺激视频在线观看女王 | 欧美婷婷色 | 亚洲精品综合一二三区在线观看 | 97成人精品区在线播放 | 国产粉嫩在线 | 又黄又爽又无遮挡免费的网站 | av官网| 亚洲精品午夜久久久久久久 | 亚洲美女精品区人人人人 | 99电影456麻豆 | 亚洲激精日韩激精欧美精品 | 美女视频网站久久 | 国产精品99久久久 | 五月天婷亚洲天综合网鲁鲁鲁 | 伊人天天| 草久在线| 伊人天天综合 | 国产精品色在线 | wwxxx日本| 精品久久99 | 在线国产精品一区 | 精品国产欧美一区二区三区不卡 | 亚洲一区久久久 | 亚洲成人免费在线观看 | 久久久精品国产一区二区电影四季 | av九九 | 亚洲免费观看视频 | 国产精品igao视频网网址 | 色综合网在线 | 九九有精品 | 中文字幕高清有码 | 草久在线| 日韩中文字幕免费在线观看 | 五月av在线| 看污网站 | 欧美精品久久久久久久久久白贞 | 亚洲成a人片在线观看中文 中文字幕在线视频第一页 狠狠色丁香婷婷综合 | av中文天堂在线 | 在线观看福利网站 | 探花视频在线观看免费 | 日韩av在线一区二区 | 亚洲综合五月 | 96国产在线 | 亚洲va欧洲va国产va不卡 | 成人国产精品久久久春色 | 国产精品网站 | 久久视频免费观看 | 色婷婷综合久久久久中文字幕1 | 欧美激情h | 精品视频久久久久久 | 草久久久 | 三级黄色免费 | 日本久热 | 欧美一级片在线 | 久久精品99久久久久久2456 | 国产精品婷婷午夜在线观看 | 极品久久久久久久 | 亚洲国产福利视频 | 日本成址在线观看 | 欧美日韩国语 | 国产精品国产三级国产aⅴ9色 | 97色在线视频 | 国产精品久久 | 在线免费观看亚洲视频 | 人人干在线观看 | 日本中文字幕高清 | 欧美老人xxxx18 | 国产午夜精品一区二区三区四区 | 亚洲国产精品第一区二区 | 免费在线观看亚洲视频 | 97色在线观看 | 国产不卡网站 | 国产一级免费av | 欧美日韩国产高清视频 | av免费看看 | 视频一区在线播放 | 中文字幕丝袜 | 天天草天天插 | 国产在线观看av | 欧美色图另类 | 视频 天天草 | 超碰成人免费电影 | 成人黄色大片网站 | 日韩三级免费观看 | 99久久精品国产一区二区成人 | 男女免费av| 久久久久久久久久久成人 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 色综合狠狠干 | 欧美一级看片 | 91av看片| 天天操天天射天天操 | 蜜桃传媒一区二区 | 五月天激情视频在线观看 | 午夜黄色影院 | 色国产视频 | 久草精品在线播放 | 天天做日日爱夜夜爽 | 国产精品日韩欧美 | 丰满少妇在线观看网站 | 二区三区精品 | 亚洲国产成人精品在线观看 | 亚洲国产成人精品久久 | av丝袜天堂 | 丰满少妇麻豆av | 成人av在线直播 | 成人中文字幕在线 | 亚洲精品视频网 | 天天操天天舔天天干 | 成人免费视频网站在线观看 | 久久久久久久久久久精 | 国产精品黄色影片导航在线观看 | 97在线观看免费观看高清 | 狠狠干干 | 精品国产福利在线 | 91精品啪在线观看国产 | 免费在线国产黄色 | 国产成人免费 | 丁香六月婷婷 | 韩日av一区二区 | 久久婷婷一区 | 亚洲精品乱码久久久久 | 96视频免费在线观看 | 中文字幕国产在线 | 中文字幕成人av | 成人午夜电影久久影院 | 一级一片免费观看 | 久久久久久久久久免费 | www.久久com| 欧美小视频在线 | 久久女同性恋中文字幕 | 91成人免费观看视频 | 精品美女久久久久久免费 | 亚洲精选视频免费看 | 久久99深爱久久99精品 | 欧美日韩视频在线 | 涩涩成人在线 | 国产精品大片免费观看 | 日韩美av在线 | 香蕉视频在线播放 | 欧美激情另类 | 一区二区三区四区久久 | 在线观看视频你懂 | 婷婷在线网 | 欧美一区二区精美视频 | 韩国精品在线 | 中文字幕丝袜 | 狠狠色丁香婷婷综合久小说久 | 深夜免费小视频 | 国产成人精品在线 | 操一草 | 天天操天天摸天天射 | 久久久久久久久久久电影 | 国产无区一区二区三麻豆 | 成人毛片一区 | 嫩草av在线 | 精品视频区 | 久久久亚洲成人 | 久久不卡国产精品一区二区 | 免费观看91视频大全 | 一区二区精品在线观看 | 国产伦理久久精品久久久久_ | 国产精品久久久精品 | www.色的| 精品99999| 亚洲精品在线观看中文字幕 | 日韩精品在线免费观看 | 亚洲一二区视频 | 国产精品 欧美 日韩 | 国产精品一级在线 | 国产精品黄 | 伊人久在线| 亚洲涩涩一区 | 337p日本欧洲亚洲大胆裸体艺术 | 就要色综合 | 国产精品一区二区三区免费看 | 色中色亚洲 | 一区二区三区免费看 | 最近免费中文视频 | 最新av在线播放 | 中文字幕久久精品亚洲乱码 | www.色的| 久久精品电影院 | 麻豆精品传媒视频 | 国产在线观看网站 | 日韩欧美国产激情在线播放 | 久久男女视频 | 久久一区二区三区四区 | 日日夜夜精品免费观看 | 在线免费色视频 | 色是在线视频 | 色婷婷综合五月 | 亚洲高清av在线 | 日批视频国产 | 91精品视频在线看 | 免费网站看v片在线a | 久久免费在线观看 | 久久色网站 | 波多野结衣日韩 | 亚洲在线高清 | 日韩欧美在线影院 | 午夜精品福利一区二区三区蜜桃 | 日韩在线视频精品 | 精品毛片一区二区免费看 | 超碰97人人干 | 一区二区三区高清 |