springcloud gateway 맵 실효 솔 루 션

게 이 트 웨 이
해결 한 문제:
4.567917.자동 경로,역방향 대리,부하 균형 감 권,모니터링
  • spring cloud gateway 사용
  • 경로 가 predicate 와 일치 하고 지정 한 위치 에 도착 합 니 다.

    handler mapping 을 통 해 처리 할 수 있 는 지 여 부 를 판단 하고 handler 를 통 해 처리 할 수 있 습 니 다.처리 하기 전에 일련의 filter 를 거 칠 수 있 습 니 다.
    게 이 트 웨 이 설정
    id 는 특정한 규칙 을 대표 합 니 다uri 대표 목적지
  • predicate 는 경로 규칙 을 대표 하고 요청 헤드,요청 방법,요청 시간,요청 경로 등 요청 매개 변 수 를 분석 해 야 uri 의 목적지 로 갈 수 있 습 니 다
  • filter 는 필 터 를 대표 하 며 요청 과정 에서 파 라 메 터 를 추가 할 수 있 습 니 다
  • 사용:
    1.의존 도 추가
    
    	<dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-gateway</artifactId>
            </dependency>
    
    2.경로 설정 추가
    
    spring:
      cloud:
        gateway:
          routes:
            - id: query_route #   id
              uri: https://baidu.com #     
              predicates:
                - Query=url, baidu #     ,          
            - id: qq_test
              uri: https://qq.com
              predicates:
                - Query=url, qq
    
    3.구체 적 인 경로 참조공식 문서
    구덩이 밟 기:chrome 은 기본적으로 url 을 실패 한 후 https 로 시작 합 니 다.일반 로 컬 요청 은 http 로 인해 요청 이 잘못 되 었 습 니 다.
    springcloud 의 gateway 는 다음 과 같은 오 류 를 알 립 니 다.
    원인:
    spring cloud 버 전과 spring boot 버 전이 대응 하지 않 습 니 다.spring boot 버 전이 너무 낮 거나 spring cloud 버 전이 너무 높 기 때 문 일 수 있 습 니 다.spring cloud 홈 페이지 에서 spring boot 버 전 을 보고 다시 의존 하면 해결 할 수 있 습 니 다.
    오류 버 전:
    springcloud:Greenwich.SR5 springboot:2.1.4
    변경 후 버 전:
    springcloud:Greenwich.SR5 springboot:2.1.8(springboot 버 전이 2.2.0 이상 이면 오류 가 발생 합 니 다)
    
    java.lang.IllegalStateException: Failed to introspect Class [org.springframework.cloud.gateway.config.GatewayAutoConfiguration$NettyConfiguration] from ClassLoader [jdk.internal.loader.ClassLoaders$AppClassLoader@7b1d7fff]
    	at org.springframework.util.ReflectionUtils.getDeclaredMethods(ReflectionUtils.java:507) ~[spring-core-5.1.6.RELEASE.jar:5.1.6.RELEASE]
    	at org.springframework.util.ReflectionUtils.doWithMethods(ReflectionUtils.java:404) ~[spring-core-5.1.6.RELEASE.jar:5.1.6.RELEASE]
    	at org.springframework.util.ReflectionUtils.doWithMethods(ReflectionUtils.java:389) ~[spring-core-5.1.6.RELEASE.jar:5.1.6.RELEASE]
    	at org.springframework.util.ReflectionUtils.getUniqueDeclaredMethods(ReflectionUtils.java:447) ~[spring-core-5.1.6.RELEASE.jar:5.1.6.RELEASE]
    	at java.base/java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1705) ~[na:na]
    	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.getTypeForFactoryMethod(AbstractAutowireCapableBeanFactory.java:738) ~[spring-beans-5.1.6.RELEASE.jar:5.1.6.RELEASE]
    	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.determineTargetType(AbstractAutowireCapableBeanFactory.java:679) ~[spring-beans-5.1.6.RELEASE.jar:5.1.6.RELEASE]
    	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.predictBeanType(AbstractAutowireCapableBeanFactory.java:647) ~[spring-beans-5.1.6.RELEASE.jar:5.1.6.RELEASE]
    	at org.springframework.beans.factory.support.AbstractBeanFactory.isFactoryBean(AbstractBeanFactory.java:1518) ~[spring-beans-5.1.6.RELEASE.jar:5.1.6.RELEASE]
    	at org.springframework.beans.factory.support.DefaultListableBeanFactory.doGetBeanNamesForType(DefaultListableBeanFactory.java:507) ~[spring-beans-5.1.6.RELEASE.jar:5.1.6.RELEASE]
    	at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBeanNamesForType(DefaultListableBeanFactory.java:477) ~[spring-beans-5.1.6.RELEASE.jar:5.1.6.RELEASE]
    	at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBeansOfType(DefaultListableBeanFactory.java:598) ~[spring-beans-5.1.6.RELEASE.jar:5.1.6.RELEASE]
    	at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBeansOfType(DefaultListableBeanFactory.java:590) ~[spring-beans-5.1.6.RELEASE.jar:5.1.6.RELEASE]
    	at org.springframework.context.support.AbstractApplicationContext.getBeansOfType(AbstractApplicationContext.java:1226) ~[spring-context-5.1.6.RELEASE.jar:5.1.6.RELEASE]
    	at org.springframework.boot.SpringApplication.getExitCodeFromMappedException(SpringApplication.java:905) ~[spring-boot-2.1.4.RELEASE.jar:2.1.4.RELEASE]
    	at org.springframework.boot.SpringApplication.getExitCodeFromException(SpringApplication.java:891) ~[spring-boot-2.1.4.RELEASE.jar:2.1.4.RELEASE]
    	at org.springframework.boot.SpringApplication.handleExitCode(SpringApplication.java:877) ~[spring-boot-2.1.4.RELEASE.jar:2.1.4.RELEASE]
    	at org.springframework.boot.SpringApplication.handleRunFailure(SpringApplication.java:826) ~[spring-boot-2.1.4.RELEASE.jar:2.1.4.RELEASE]
    	at org.springframework.boot.SpringApplication.run(SpringApplication.java:327) ~[spring-boot-2.1.4.RELEASE.jar:2.1.4.RELEASE]
    	at org.springframework.boot.SpringApplication.run(SpringApplication.java:1260) ~[spring-boot-2.1.4.RELEASE.jar:2.1.4.RELEASE]
    	at org.springframework.boot.SpringApplication.run(SpringApplication.java:1248) ~[spring-boot-2.1.4.RELEASE.jar:2.1.4.RELEASE]
    	at com.changgou.GatewayWebApplication.main(GatewayWebApplication.java:15) ~[classes/:na]
    	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:na]
    	at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:na]
    	at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:na]
    	at java.base/java.lang.reflect.Method.invoke(Method.java:566) ~[na:na]
    	at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) ~[spring-boot-devtools-2.1.4.RELEASE.jar:2.1.4.RELEASE]
    Caused by: java.lang.NoClassDefFoundError: reactor/netty/http/client/HttpResponseDecoderSpec
    	at java.base/java.lang.Class.getDeclaredMethods0(Native Method) ~[na:na]
    	at java.base/java.lang.Class.privateGetDeclaredMethods(Class.java:3167) ~[na:na]
    	at java.base/java.lang.Class.getDeclaredMethods(Class.java:2310) ~[na:na]
    	at org.springframework.util.ReflectionUtils.getDeclaredMethods(ReflectionUtils.java:489) ~[spring-core-5.1.6.RELEASE.jar:5.1.6.RELEASE]
    	... 26 common frames omitted
    Caused by: java.lang.ClassNotFoundException: reactor.netty.http.client.HttpResponseDecoderSpec
    	at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:583) ~[na:na]
    	at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:178) ~[na:na]
    	at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:521) ~[na:na]
    	... 30 common frames omitted
    
    Process finished with exit code 0
    
    이상 은 개인 적 인 경험 이 므 로 여러분 에 게 참고 가 되 기 를 바 랍 니 다.여러분 들 도 저 희 를 많이 응원 해 주시 기 바 랍 니 다.

    좋은 웹페이지 즐겨찾기